blob: abd603d40b8896b18b9f2f3883f5c91e95a718ed [file] [log] [blame]
[email protected]5bdaa2d2014-05-19 14:59:511// Copyright 2014 The Chromium Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef CHROME_BROWSER_METRICS_CHROME_METRICS_SERVICE_CLIENT_H_
6#define CHROME_BROWSER_METRICS_CHROME_METRICS_SERVICE_CLIENT_H_
7
avi6846aef2015-12-26 01:09:388#include <stdint.h>
9
dcheng1edb03a2016-04-14 17:20:2910#include <memory>
[email protected]5bdaa2d2014-05-19 14:59:5111#include <string>
12
[email protected]4b4892b2014-05-22 15:06:1513#include "base/callback.h"
avi6846aef2015-12-26 01:09:3814#include "base/macros.h"
[email protected]4b4892b2014-05-22 15:06:1515#include "base/memory/weak_ptr.h"
[email protected]d7ea39e2014-05-22 03:59:1816#include "base/threading/thread_checker.h"
avi6846aef2015-12-26 01:09:3817#include "build/build_config.h"
asvitkine89406d1f2015-01-17 06:57:1018#include "chrome/browser/metrics/metrics_memory_details.h"
[email protected]5bdaa2d2014-05-19 14:59:5119#include "components/metrics/metrics_service_client.h"
gunsch840bc412014-09-18 19:38:0620#include "components/metrics/profiler/tracking_synchronizer_observer.h"
manzagopa5d6688d2016-10-25 20:16:0321#include "components/metrics/proto/system_profile.pb.h"
blundell26b95242015-08-17 10:29:2422#include "components/omnibox/browser/omnibox_event_global_tracker.h"
[email protected]d7ea39e2014-05-22 03:59:1823#include "content/public/browser/notification_observer.h"
24#include "content/public/browser/notification_registrar.h"
25
wfhc768983fa2016-06-08 16:40:3326class AntiVirusMetricsProvider;
[email protected]51994b22014-05-30 13:24:2127class ChromeOSMetricsProvider;
[email protected]4a55a712014-06-08 16:50:3428class GoogleUpdateMetricsProviderWin;
[email protected]4a55a712014-06-08 16:50:3429class PluginMetricsProvider;
30class PrefRegistrySimple;
ishermanfc021e912015-03-25 23:33:3331class PrefService;
[email protected]4a55a712014-06-08 16:50:3432
jam1c5a91492016-02-24 20:47:5333#if !defined(OS_CHROMEOS)
[email protected]7aee4f7e2014-08-12 01:15:0334class SigninStatusMetricsProvider;
35#endif
36
manzagopf2322662016-09-27 11:39:5937namespace browser_watcher {
38class WatcherMetricsProviderWin;
39} // namespace browser_watcher
40
[email protected]037642f2014-05-29 20:40:5041namespace metrics {
blundellb5c6b5a2015-07-30 20:18:3042class DriveMetricsProvider;
asvitkinecbd420732014-08-26 22:15:4043class MetricsService;
[email protected]037642f2014-05-29 20:40:5044class MetricsStateManager;
gunsch840bc412014-09-18 19:38:0645class ProfilerMetricsProvider;
siggi5e62f7e2014-11-21 21:55:4546} // namespace metrics
[email protected]037642f2014-05-29 20:40:5047
[email protected]5bdaa2d2014-05-19 14:59:5148// ChromeMetricsServiceClient provides an implementation of MetricsServiceClient
49// that depends on chrome/.
[email protected]4a55a712014-06-08 16:50:3450class ChromeMetricsServiceClient
51 : public metrics::MetricsServiceClient,
gunsch840bc412014-09-18 19:38:0652 public metrics::TrackingSynchronizerObserver,
[email protected]4a55a712014-06-08 16:50:3453 public content::NotificationObserver {
[email protected]5bdaa2d2014-05-19 14:59:5154 public:
Daniel Chenga542fca2014-10-21 09:51:2955 ~ChromeMetricsServiceClient() override;
[email protected]5bdaa2d2014-05-19 14:59:5156
[email protected]037642f2014-05-29 20:40:5057 // Factory function.
dcheng1edb03a2016-04-14 17:20:2958 static std::unique_ptr<ChromeMetricsServiceClient> Create(
calvimei5b30e0d2016-08-17 21:24:3359 metrics::MetricsStateManager* state_manager);
[email protected]037642f2014-05-29 20:40:5060
[email protected]4a55a712014-06-08 16:50:3461 // Registers local state prefs used by this class.
62 static void RegisterPrefs(PrefRegistrySimple* registry);
63
[email protected]5bdaa2d2014-05-19 14:59:5164 // metrics::MetricsServiceClient:
blundellfecea528d2015-10-21 10:10:2265 metrics::MetricsService* GetMetricsService() override;
Daniel Chenga542fca2014-10-21 09:51:2966 void SetMetricsClientId(const std::string& client_id) override;
avi6846aef2015-12-26 01:09:3867 int32_t GetProduct() override;
Daniel Chenga542fca2014-10-21 09:51:2968 std::string GetApplicationLocale() override;
69 bool GetBrand(std::string* brand_code) override;
70 metrics::SystemProfileProto::Channel GetChannel() override;
71 std::string GetVersionString() override;
manzagopa5d6688d2016-10-25 20:16:0372 void OnEnvironmentUpdate(std::string* serialized_environment) override;
Daniel Chenga542fca2014-10-21 09:51:2973 void OnLogUploadComplete() override;
ishermanb6705682015-08-29 00:01:0074 void InitializeSystemProfileMetrics(
75 const base::Closure& done_callback) override;
76 void CollectFinalMetricsForLog(const base::Closure& done_callback) override;
dcheng1edb03a2016-04-14 17:20:2977 std::unique_ptr<metrics::MetricsLogUploader> CreateUploader(
mostynb2b52d1db2014-10-07 02:47:1778 const base::Callback<void(int)>& on_upload_complete) override;
gunsch7cbdcb22015-03-13 17:02:0579 base::TimeDelta GetStandardUploadInterval() override;
Daniel Chenga542fca2014-10-21 09:51:2980 base::string16 GetRegistryBackupKey() override;
blundellfecea528d2015-10-21 10:10:2281 void OnPluginLoadingError(const base::FilePath& plugin_path) override;
jwd421086f2016-03-21 14:40:4282 bool IsReportingPolicyManaged() override;
gayanedaaf3a02016-06-15 16:30:2183 metrics::EnableMetricsDefault GetMetricsReportingDefaultState() override;
gayane0b46091c2016-04-07 21:01:0584 bool IsUMACellularUploadLogicEnabled() override;
[email protected]4a55a712014-06-08 16:50:3485
bcwhite374d5fe2016-05-20 17:03:2486 // Persistent browser metrics need to be persisted somewhere. This constant
87 // provides a known string to be used for both the allocator's internal name
88 // and for a file on disk (relative to chrome::DIR_USER_DATA) to which they
89 // can be saved.
90 static const char kBrowserMetricsName[];
91
[email protected]5bdaa2d2014-05-19 14:59:5192 private:
[email protected]037642f2014-05-29 20:40:5093 explicit ChromeMetricsServiceClient(
94 metrics::MetricsStateManager* state_manager);
95
[email protected]51994b22014-05-30 13:24:2196 // Completes the two-phase initialization of ChromeMetricsServiceClient.
97 void Initialize();
98
ortuno4958ca4f2016-02-26 02:15:4399 // Callback that continues the init task by getting a Bluetooth Adapter.
[email protected]4a55a712014-06-08 16:50:34100 void OnInitTaskGotHardwareClass();
101
ortuno4958ca4f2016-02-26 02:15:43102 // Callback that continues the init task by loading plugin information.
103 void OnInitTaskGotBluetoothAdapter();
104
[email protected]4a55a712014-06-08 16:50:34105 // Called after the Plugin init task has been completed that continues the
106 // init task by launching a task to gather Google Update statistics.
107 void OnInitTaskGotPluginInfo();
108
109 // Called after GoogleUpdate init task has been completed that continues the
wfhc768983fa2016-06-08 16:40:33110 // init task by loading AntiVirus metrics.
[email protected]4a55a712014-06-08 16:50:34111 void OnInitTaskGotGoogleUpdateData();
112
wfhc768983fa2016-06-08 16:40:33113 // Called after AntiVirus init task has been completed that continues the
114 // init task by loading drive metrics.
115 void OnInitTaskGotAntiVirusData();
116
manzagopf2322662016-09-27 11:39:59117 // Called after the drive metrics init task has been completed to continue
118 // the init task by optionally collecting postmortem reports.
ishermanfcf4639e82015-08-26 00:33:49119 void OnInitTaskGotDriveMetrics();
amistry9e2a8b42015-06-13 01:11:27120
manzagopf2322662016-09-27 11:39:59121 // Called after the postmortem report collection task has been completed to
122 // continue the init task by loading profiler data.
123 void OnInitTaskCollectedPostmortemReports();
124
isherman213b47c2015-08-28 08:20:46125 // Returns true iff profiler data should be included in the next metrics log.
126 // NOTE: This method is probabilistic and also updates internal state as a
127 // side-effect when called, so it should only be called once per log.
128 bool ShouldIncludeProfilerDataInLog();
129
[email protected]4a55a712014-06-08 16:50:34130 // TrackingSynchronizerObserver:
Daniel Chenga542fca2014-10-21 09:51:29131 void ReceivedProfilerData(
vadimte2de4732015-04-27 21:43:02132 const metrics::ProfilerDataAttributes& attributes,
vadimt379d7fe2015-04-01 00:09:35133 const tracked_objects::ProcessDataPhaseSnapshot& process_data_phase,
vadimt379d7fe2015-04-01 00:09:35134 const metrics::ProfilerEvents& past_profiler_events) override;
Daniel Chenga542fca2014-10-21 09:51:29135 void FinishedReceivingProfilerData() override;
[email protected]4a55a712014-06-08 16:50:34136
[email protected]4b4892b2014-05-22 15:06:15137 // Callbacks for various stages of final log info collection. Do not call
138 // these directly.
ishermanfcf4639e82015-08-26 00:33:49139 void CollectFinalHistograms();
bcwhite81e14852016-08-01 19:30:23140 void MergeHistogramDeltas();
[email protected]4b4892b2014-05-22 15:06:15141 void OnMemoryDetailCollectionDone();
142 void OnHistogramSynchronizationDone();
143
[email protected]daed87e2014-05-22 19:41:22144 // Records metrics about the switches present on the command line.
145 void RecordCommandLineMetrics();
146
[email protected]d7ea39e2014-05-22 03:59:18147 // Registers |this| as an observer for notifications which indicate that a
148 // user is performing work. This is useful to allow some features to sleep,
149 // until the machine becomes active, such as precluding UMA uploads unless
150 // there was recent activity.
151 void RegisterForNotifications();
152
153 // content::NotificationObserver:
Daniel Chenga542fca2014-10-21 09:51:29154 void Observe(int type,
155 const content::NotificationSource& source,
156 const content::NotificationDetails& details) override;
[email protected]d7ea39e2014-05-22 03:59:18157
blundell26b95242015-08-17 10:29:24158 // Called when a URL is opened from the Omnibox.
159 void OnURLOpenedFromOmnibox(OmniboxLog* log);
160
[email protected]e2481a702014-05-23 21:06:50161#if defined(OS_WIN)
162 // Counts (and removes) the browser crash dump attempt signals left behind by
163 // any previous browser processes which generated a crash dump.
164 void CountBrowserCrashDumpAttempts();
165#endif // OS_WIN
166
[email protected]4b4892b2014-05-22 15:06:15167 base::ThreadChecker thread_checker_;
168
[email protected]51994b22014-05-30 13:24:21169 // Weak pointer to the MetricsStateManager.
170 metrics::MetricsStateManager* metrics_state_manager_;
171
[email protected]037642f2014-05-29 20:40:50172 // The MetricsService that |this| is a client of.
dcheng1edb03a2016-04-14 17:20:29173 std::unique_ptr<metrics::MetricsService> metrics_service_;
[email protected]d7ea39e2014-05-22 03:59:18174
175 content::NotificationRegistrar registrar_;
[email protected]d7ea39e2014-05-22 03:59:18176
mlamouriba00ad12016-01-16 15:06:08177#if defined(OS_CHROMEOS)
[email protected]51994b22014-05-30 13:24:21178 // On ChromeOS, holds a weak pointer to the ChromeOSMetricsProvider instance
179 // that has been registered with MetricsService. On other platforms, is NULL.
180 ChromeOSMetricsProvider* chromeos_metrics_provider_;
mlamouriba00ad12016-01-16 15:06:08181#endif
[email protected]51994b22014-05-30 13:24:21182
ishermanb6705682015-08-29 00:01:00183 // Saved callback received from CollectFinalMetricsForLog().
[email protected]4b4892b2014-05-22 15:06:15184 base::Closure collect_final_metrics_done_callback_;
185
186 // Indicates that collect final metrics step is running.
187 bool waiting_for_collect_final_metrics_step_;
188
189 // Number of async histogram fetch requests in progress.
190 int num_async_histogram_fetches_in_progress_;
191
[email protected]4a55a712014-06-08 16:50:34192 // The ProfilerMetricsProvider instance that was registered with
193 // MetricsService. Has the same lifetime as |metrics_service_|.
gunsch840bc412014-09-18 19:38:06194 metrics::ProfilerMetricsProvider* profiler_metrics_provider_;
[email protected]4a55a712014-06-08 16:50:34195
196#if defined(ENABLE_PLUGINS)
197 // The PluginMetricsProvider instance that was registered with
198 // MetricsService. Has the same lifetime as |metrics_service_|.
199 PluginMetricsProvider* plugin_metrics_provider_;
200#endif
201
202#if defined(OS_WIN)
203 // The GoogleUpdateMetricsProviderWin instance that was registered with
204 // MetricsService. Has the same lifetime as |metrics_service_|.
205 GoogleUpdateMetricsProviderWin* google_update_metrics_provider_;
wfhc768983fa2016-06-08 16:40:33206
manzagopf2322662016-09-27 11:39:59207 // The WatcherMetricsProviderWin instance that was registered with
208 // MetricsService. Has the same lifetime as |metrics_service_|.
209 browser_watcher::WatcherMetricsProviderWin* watcher_metrics_provider_;
210
wfhc768983fa2016-06-08 16:40:33211 // The AntiVirusMetricsProvider instance that was registered with
212 // MetricsService. Has the same lifetime as |metrics_service_|.
213 AntiVirusMetricsProvider* antivirus_metrics_provider_;
[email protected]4a55a712014-06-08 16:50:34214#endif
215
dbeam64c37842015-03-18 02:23:35216 // The DriveMetricsProvider instance that was registered with MetricsService.
217 // Has the same lifetime as |metrics_service_|.
blundellb5c6b5a2015-07-30 20:18:30218 metrics::DriveMetricsProvider* drive_metrics_provider_;
dbeam64c37842015-03-18 02:23:35219
[email protected]4a55a712014-06-08 16:50:34220 // Callback that is called when initial metrics gathering is complete.
ishermanb6705682015-08-29 00:01:00221 base::Closure finished_init_task_callback_;
[email protected]4a55a712014-06-08 16:50:34222
[email protected]8a5b2da2014-07-07 10:56:51223 // The MemoryGrowthTracker instance that tracks memory usage growth in
224 // MemoryDetails.
225 MemoryGrowthTracker memory_growth_tracker_;
226
gunsch7cbdcb22015-03-13 17:02:05227 // Callback to determine whether or not a cellular network is currently being
228 // used.
229 base::Callback<void(bool*)> cellular_callback_;
230
vadimte2de4732015-04-27 21:43:02231 // Time of this object's creation.
232 const base::TimeTicks start_time_;
233
blundell26b95242015-08-17 10:29:24234 // Subscription for receiving callbacks that a URL was opened from the
235 // omnibox.
dcheng1edb03a2016-04-14 17:20:29236 std::unique_ptr<base::CallbackList<void(OmniboxLog*)>::Subscription>
blundell26b95242015-08-17 10:29:24237 omnibox_url_opened_subscription_;
238
isherman213b47c2015-08-28 08:20:46239 // Whether this client has already uploaded profiler data during this session.
240 // Profiler data is uploaded at most once per session.
241 bool has_uploaded_profiler_data_;
242
[email protected]4b4892b2014-05-22 15:06:15243 base::WeakPtrFactory<ChromeMetricsServiceClient> weak_ptr_factory_;
244
[email protected]5bdaa2d2014-05-19 14:59:51245 DISALLOW_COPY_AND_ASSIGN(ChromeMetricsServiceClient);
246};
247
248#endif // CHROME_BROWSER_METRICS_CHROME_METRICS_SERVICE_CLIENT_H_