blob: 13ccabd4ca0918f7dfa783461d5802a3f981f9e6 [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
manzagop14aff5d2016-11-23 17:27:0010#include <deque>
dcheng1edb03a2016-04-14 17:20:2911#include <memory>
huangse0fa6fd2016-11-04 20:41:1012#include <queue>
[email protected]5bdaa2d2014-05-19 14:59:5113#include <string>
14
[email protected]4b4892b2014-05-22 15:06:1515#include "base/callback.h"
avi6846aef2015-12-26 01:09:3816#include "base/macros.h"
[email protected]4b4892b2014-05-22 15:06:1517#include "base/memory/weak_ptr.h"
[email protected]d7ea39e2014-05-22 03:59:1818#include "base/threading/thread_checker.h"
avi6846aef2015-12-26 01:09:3819#include "build/build_config.h"
asvitkine89406d1f2015-01-17 06:57:1020#include "chrome/browser/metrics/metrics_memory_details.h"
rkaplow9c420822017-02-24 15:29:5721#include "components/metrics/metrics_log_uploader.h"
[email protected]5bdaa2d2014-05-19 14:59:5122#include "components/metrics/metrics_service_client.h"
gunsch840bc412014-09-18 19:38:0623#include "components/metrics/profiler/tracking_synchronizer_observer.h"
manzagopa5d6688d2016-10-25 20:16:0324#include "components/metrics/proto/system_profile.pb.h"
blundell26b95242015-08-17 10:29:2425#include "components/omnibox/browser/omnibox_event_global_tracker.h"
holte7b74c622017-01-23 23:13:0726#include "components/ukm/observers/history_delete_observer.h"
holte1334c0aa2017-02-09 22:52:4127#include "components/ukm/observers/sync_disable_observer.h"
[email protected]d7ea39e2014-05-22 03:59:1828#include "content/public/browser/notification_observer.h"
29#include "content/public/browser/notification_registrar.h"
brettw4b461082016-11-19 18:55:1630#include "ppapi/features/features.h"
[email protected]d7ea39e2014-05-22 03:59:1831
wfhc768983fa2016-06-08 16:40:3332class AntiVirusMetricsProvider;
[email protected]51994b22014-05-30 13:24:2133class ChromeOSMetricsProvider;
[email protected]4a55a712014-06-08 16:50:3434class GoogleUpdateMetricsProviderWin;
[email protected]4a55a712014-06-08 16:50:3435class PluginMetricsProvider;
holte7b74c622017-01-23 23:13:0736class Profile;
[email protected]4a55a712014-06-08 16:50:3437class PrefRegistrySimple;
[email protected]7aee4f7e2014-08-12 01:15:0338
manzagopf2322662016-09-27 11:39:5939namespace browser_watcher {
40class WatcherMetricsProviderWin;
41} // namespace browser_watcher
42
[email protected]037642f2014-05-29 20:40:5043namespace metrics {
blundellb5c6b5a2015-07-30 20:18:3044class DriveMetricsProvider;
asvitkinecbd420732014-08-26 22:15:4045class MetricsService;
[email protected]037642f2014-05-29 20:40:5046class MetricsStateManager;
gunsch840bc412014-09-18 19:38:0647class ProfilerMetricsProvider;
siggi5e62f7e2014-11-21 21:55:4548} // namespace metrics
[email protected]037642f2014-05-29 20:40:5049
[email protected]5bdaa2d2014-05-19 14:59:5150// ChromeMetricsServiceClient provides an implementation of MetricsServiceClient
51// that depends on chrome/.
holte7b74c622017-01-23 23:13:0752class ChromeMetricsServiceClient : public metrics::MetricsServiceClient,
53 public metrics::TrackingSynchronizerObserver,
54 public content::NotificationObserver,
holte1334c0aa2017-02-09 22:52:4155 public ukm::HistoryDeleteObserver,
56 public ukm::SyncDisableObserver {
[email protected]5bdaa2d2014-05-19 14:59:5157 public:
Daniel Chenga542fca2014-10-21 09:51:2958 ~ChromeMetricsServiceClient() override;
[email protected]5bdaa2d2014-05-19 14:59:5159
[email protected]037642f2014-05-29 20:40:5060 // Factory function.
dcheng1edb03a2016-04-14 17:20:2961 static std::unique_ptr<ChromeMetricsServiceClient> Create(
calvimei5b30e0d2016-08-17 21:24:3362 metrics::MetricsStateManager* state_manager);
[email protected]037642f2014-05-29 20:40:5063
[email protected]4a55a712014-06-08 16:50:3464 // Registers local state prefs used by this class.
65 static void RegisterPrefs(PrefRegistrySimple* registry);
66
[email protected]5bdaa2d2014-05-19 14:59:5167 // metrics::MetricsServiceClient:
blundellfecea528d2015-10-21 10:10:2268 metrics::MetricsService* GetMetricsService() override;
holte7b74c622017-01-23 23:13:0769 ukm::UkmService* GetUkmService() override;
Daniel Chenga542fca2014-10-21 09:51:2970 void SetMetricsClientId(const std::string& client_id) override;
avi6846aef2015-12-26 01:09:3871 int32_t GetProduct() override;
Daniel Chenga542fca2014-10-21 09:51:2972 std::string GetApplicationLocale() override;
73 bool GetBrand(std::string* brand_code) override;
74 metrics::SystemProfileProto::Channel GetChannel() override;
75 std::string GetVersionString() override;
manzagopa5d6688d2016-10-25 20:16:0376 void OnEnvironmentUpdate(std::string* serialized_environment) override;
manzagop14aff5d2016-11-23 17:27:0077 void OnLogCleanShutdown() override;
ishermanb6705682015-08-29 00:01:0078 void InitializeSystemProfileMetrics(
79 const base::Closure& done_callback) override;
80 void CollectFinalMetricsForLog(const base::Closure& done_callback) override;
dcheng1edb03a2016-04-14 17:20:2981 std::unique_ptr<metrics::MetricsLogUploader> CreateUploader(
holte4ae63f52017-03-08 00:25:0882 base::StringPiece server_url,
83 base::StringPiece mime_type,
rkaplow9c420822017-02-24 15:29:5784 metrics::MetricsLogUploader::MetricServiceType service_type,
mostynb2b52d1db2014-10-07 02:47:1785 const base::Callback<void(int)>& on_upload_complete) override;
gunsch7cbdcb22015-03-13 17:02:0586 base::TimeDelta GetStandardUploadInterval() override;
Daniel Chenga542fca2014-10-21 09:51:2987 base::string16 GetRegistryBackupKey() override;
blundellfecea528d2015-10-21 10:10:2288 void OnPluginLoadingError(const base::FilePath& plugin_path) override;
jwd421086f2016-03-21 14:40:4289 bool IsReportingPolicyManaged() override;
gayanedaaf3a02016-06-15 16:30:2190 metrics::EnableMetricsDefault GetMetricsReportingDefaultState() override;
gayane0b46091c2016-04-07 21:01:0591 bool IsUMACellularUploadLogicEnabled() override;
holte08137d792017-02-15 21:43:5692 bool IsHistorySyncEnabledOnAllProfiles() override;
[email protected]4a55a712014-06-08 16:50:3493
holte1334c0aa2017-02-09 22:52:4194 // ukm::HistoryDeleteObserver:
holte7b74c622017-01-23 23:13:0795 void OnHistoryDeleted() override;
96
holte1334c0aa2017-02-09 22:52:4197 // ukm::SyncDisableObserver:
98 void OnSyncPrefsChanged(bool must_purge) override;
99
bcwhite374d5fe2016-05-20 17:03:24100 // Persistent browser metrics need to be persisted somewhere. This constant
101 // provides a known string to be used for both the allocator's internal name
102 // and for a file on disk (relative to chrome::DIR_USER_DATA) to which they
103 // can be saved.
104 static const char kBrowserMetricsName[];
105
[email protected]5bdaa2d2014-05-19 14:59:51106 private:
[email protected]037642f2014-05-29 20:40:50107 explicit ChromeMetricsServiceClient(
108 metrics::MetricsStateManager* state_manager);
109
[email protected]51994b22014-05-30 13:24:21110 // Completes the two-phase initialization of ChromeMetricsServiceClient.
111 void Initialize();
112
rkaplowb8d63f432017-02-06 19:00:42113 // Registers providers to the MetricsService. These provide data from
114 // alternate sources.
115 void RegisterMetricsServiceProviders();
116
117 // Registers providers to the UkmService. These provide data from alternate
118 // sources.
119 void RegisterUKMProviders();
120
huangse0fa6fd2016-11-04 20:41:10121 // Callback to chain init tasks: Pops and executes the next init task from
122 // |initialize_task_queue_|, then passes itself as callback for each init task
123 // to call upon completion.
124 void OnInitNextTask();
manzagopf2322662016-09-27 11:39:59125
isherman213b47c2015-08-28 08:20:46126 // Returns true iff profiler data should be included in the next metrics log.
127 // NOTE: This method is probabilistic and also updates internal state as a
128 // side-effect when called, so it should only be called once per log.
129 bool ShouldIncludeProfilerDataInLog();
130
[email protected]4a55a712014-06-08 16:50:34131 // TrackingSynchronizerObserver:
Daniel Chenga542fca2014-10-21 09:51:29132 void ReceivedProfilerData(
vadimte2de4732015-04-27 21:43:02133 const metrics::ProfilerDataAttributes& attributes,
vadimt379d7fe2015-04-01 00:09:35134 const tracked_objects::ProcessDataPhaseSnapshot& process_data_phase,
vadimt379d7fe2015-04-01 00:09:35135 const metrics::ProfilerEvents& past_profiler_events) override;
Daniel Chenga542fca2014-10-21 09:51:29136 void FinishedReceivingProfilerData() override;
[email protected]4a55a712014-06-08 16:50:34137
[email protected]4b4892b2014-05-22 15:06:15138 // Callbacks for various stages of final log info collection. Do not call
139 // these directly.
ishermanfcf4639e82015-08-26 00:33:49140 void CollectFinalHistograms();
[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
holte1334c0aa2017-02-09 22:52:41153 // Call to listen for events on the selected profile's services.
154 void RegisterForProfileEvents(Profile* profile);
holte7b74c622017-01-23 23:13:07155
[email protected]d7ea39e2014-05-22 03:59:18156 // content::NotificationObserver:
Daniel Chenga542fca2014-10-21 09:51:29157 void Observe(int type,
158 const content::NotificationSource& source,
159 const content::NotificationDetails& details) override;
[email protected]d7ea39e2014-05-22 03:59:18160
blundell26b95242015-08-17 10:29:24161 // Called when a URL is opened from the Omnibox.
162 void OnURLOpenedFromOmnibox(OmniboxLog* log);
163
[email protected]e2481a702014-05-23 21:06:50164#if defined(OS_WIN)
165 // Counts (and removes) the browser crash dump attempt signals left behind by
166 // any previous browser processes which generated a crash dump.
167 void CountBrowserCrashDumpAttempts();
168#endif // OS_WIN
169
[email protected]4b4892b2014-05-22 15:06:15170 base::ThreadChecker thread_checker_;
171
[email protected]51994b22014-05-30 13:24:21172 // Weak pointer to the MetricsStateManager.
173 metrics::MetricsStateManager* metrics_state_manager_;
174
[email protected]037642f2014-05-29 20:40:50175 // The MetricsService that |this| is a client of.
dcheng1edb03a2016-04-14 17:20:29176 std::unique_ptr<metrics::MetricsService> metrics_service_;
[email protected]d7ea39e2014-05-22 03:59:18177
holte7b74c622017-01-23 23:13:07178 // The UkmService that |this| is a client of.
179 std::unique_ptr<ukm::UkmService> ukm_service_;
180
[email protected]d7ea39e2014-05-22 03:59:18181 content::NotificationRegistrar registrar_;
[email protected]d7ea39e2014-05-22 03:59:18182
mlamouriba00ad12016-01-16 15:06:08183#if defined(OS_CHROMEOS)
[email protected]51994b22014-05-30 13:24:21184 // On ChromeOS, holds a weak pointer to the ChromeOSMetricsProvider instance
185 // that has been registered with MetricsService. On other platforms, is NULL.
186 ChromeOSMetricsProvider* chromeos_metrics_provider_;
mlamouriba00ad12016-01-16 15:06:08187#endif
[email protected]51994b22014-05-30 13:24:21188
huangse0fa6fd2016-11-04 20:41:10189 // A queue of tasks for initial metrics gathering. These may be asynchronous
190 // or synchronous.
191 std::deque<base::Closure> initialize_task_queue_;
192
ishermanb6705682015-08-29 00:01:00193 // Saved callback received from CollectFinalMetricsForLog().
[email protected]4b4892b2014-05-22 15:06:15194 base::Closure collect_final_metrics_done_callback_;
195
196 // Indicates that collect final metrics step is running.
197 bool waiting_for_collect_final_metrics_step_;
198
199 // Number of async histogram fetch requests in progress.
200 int num_async_histogram_fetches_in_progress_;
201
[email protected]4a55a712014-06-08 16:50:34202 // The ProfilerMetricsProvider instance that was registered with
203 // MetricsService. Has the same lifetime as |metrics_service_|.
gunsch840bc412014-09-18 19:38:06204 metrics::ProfilerMetricsProvider* profiler_metrics_provider_;
[email protected]4a55a712014-06-08 16:50:34205
brettw4b461082016-11-19 18:55:16206#if BUILDFLAG(ENABLE_PLUGINS)
[email protected]4a55a712014-06-08 16:50:34207 // The PluginMetricsProvider instance that was registered with
208 // MetricsService. Has the same lifetime as |metrics_service_|.
209 PluginMetricsProvider* plugin_metrics_provider_;
210#endif
211
212#if defined(OS_WIN)
213 // The GoogleUpdateMetricsProviderWin instance that was registered with
214 // MetricsService. Has the same lifetime as |metrics_service_|.
215 GoogleUpdateMetricsProviderWin* google_update_metrics_provider_;
wfhc768983fa2016-06-08 16:40:33216
manzagopf2322662016-09-27 11:39:59217 // The WatcherMetricsProviderWin instance that was registered with
218 // MetricsService. Has the same lifetime as |metrics_service_|.
219 browser_watcher::WatcherMetricsProviderWin* watcher_metrics_provider_;
220
wfhc768983fa2016-06-08 16:40:33221 // The AntiVirusMetricsProvider instance that was registered with
222 // MetricsService. Has the same lifetime as |metrics_service_|.
223 AntiVirusMetricsProvider* antivirus_metrics_provider_;
[email protected]4a55a712014-06-08 16:50:34224#endif
225
dbeam64c37842015-03-18 02:23:35226 // The DriveMetricsProvider instance that was registered with MetricsService.
227 // Has the same lifetime as |metrics_service_|.
blundellb5c6b5a2015-07-30 20:18:30228 metrics::DriveMetricsProvider* drive_metrics_provider_;
dbeam64c37842015-03-18 02:23:35229
[email protected]8a5b2da2014-07-07 10:56:51230 // The MemoryGrowthTracker instance that tracks memory usage growth in
231 // MemoryDetails.
232 MemoryGrowthTracker memory_growth_tracker_;
233
gunsch7cbdcb22015-03-13 17:02:05234 // Callback to determine whether or not a cellular network is currently being
235 // used.
236 base::Callback<void(bool*)> cellular_callback_;
237
vadimte2de4732015-04-27 21:43:02238 // Time of this object's creation.
239 const base::TimeTicks start_time_;
240
blundell26b95242015-08-17 10:29:24241 // Subscription for receiving callbacks that a URL was opened from the
242 // omnibox.
dcheng1edb03a2016-04-14 17:20:29243 std::unique_ptr<base::CallbackList<void(OmniboxLog*)>::Subscription>
blundell26b95242015-08-17 10:29:24244 omnibox_url_opened_subscription_;
245
isherman213b47c2015-08-28 08:20:46246 // Whether this client has already uploaded profiler data during this session.
247 // Profiler data is uploaded at most once per session.
248 bool has_uploaded_profiler_data_;
249
[email protected]4b4892b2014-05-22 15:06:15250 base::WeakPtrFactory<ChromeMetricsServiceClient> weak_ptr_factory_;
251
[email protected]5bdaa2d2014-05-19 14:59:51252 DISALLOW_COPY_AND_ASSIGN(ChromeMetricsServiceClient);
253};
254
255#endif // CHROME_BROWSER_METRICS_CHROME_METRICS_SERVICE_CLIENT_H_