blob: a3730b4b38699e2ed93a4fbc569a04cdfa008f98 [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
8#include <string>
9
10#include "base/basictypes.h"
[email protected]4b4892b2014-05-22 15:06:1511#include "base/callback.h"
amistry9e2a8b42015-06-13 01:11:2712#include "base/containers/scoped_ptr_map.h"
[email protected]037642f2014-05-29 20:40:5013#include "base/memory/scoped_ptr.h"
[email protected]4b4892b2014-05-22 15:06:1514#include "base/memory/weak_ptr.h"
[email protected]d7ea39e2014-05-22 03:59:1815#include "base/threading/thread_checker.h"
asvitkine89406d1f2015-01-17 06:57:1016#include "chrome/browser/metrics/metrics_memory_details.h"
[email protected]5bdaa2d2014-05-19 14:59:5117#include "components/metrics/metrics_service_client.h"
gunsch840bc412014-09-18 19:38:0618#include "components/metrics/profiler/tracking_synchronizer_observer.h"
blundell26b95242015-08-17 10:29:2419#include "components/omnibox/browser/omnibox_event_global_tracker.h"
[email protected]d7ea39e2014-05-22 03:59:1820#include "content/public/browser/notification_observer.h"
21#include "content/public/browser/notification_registrar.h"
22
[email protected]51994b22014-05-30 13:24:2123class ChromeOSMetricsProvider;
[email protected]4a55a712014-06-08 16:50:3424class GoogleUpdateMetricsProviderWin;
[email protected]4a55a712014-06-08 16:50:3425class PluginMetricsProvider;
26class PrefRegistrySimple;
ishermanfc021e912015-03-25 23:33:3327class PrefService;
amistry9e2a8b42015-06-13 01:11:2728class ProcessResourceUsage;
[email protected]4a55a712014-06-08 16:50:3429
[email protected]1e39b642014-08-15 04:55:4730#if !defined(OS_CHROMEOS) && !defined(OS_IOS)
[email protected]7aee4f7e2014-08-12 01:15:0331class SigninStatusMetricsProvider;
32#endif
33
[email protected]4a55a712014-06-08 16:50:3434namespace base {
35class FilePath;
siggi5e62f7e2014-11-21 21:55:4536} // namespace base
[email protected]5bdaa2d2014-05-19 14:59:5137
[email protected]037642f2014-05-29 20:40:5038namespace metrics {
blundellb5c6b5a2015-07-30 20:18:3039class DriveMetricsProvider;
asvitkinecbd420732014-08-26 22:15:4040class MetricsService;
[email protected]037642f2014-05-29 20:40:5041class MetricsStateManager;
gunsch840bc412014-09-18 19:38:0642class ProfilerMetricsProvider;
siggi5e62f7e2014-11-21 21:55:4543} // namespace metrics
[email protected]037642f2014-05-29 20:40:5044
[email protected]5bdaa2d2014-05-19 14:59:5145// ChromeMetricsServiceClient provides an implementation of MetricsServiceClient
46// that depends on chrome/.
[email protected]4a55a712014-06-08 16:50:3447class ChromeMetricsServiceClient
48 : public metrics::MetricsServiceClient,
gunsch840bc412014-09-18 19:38:0649 public metrics::TrackingSynchronizerObserver,
[email protected]4a55a712014-06-08 16:50:3450 public content::NotificationObserver {
[email protected]5bdaa2d2014-05-19 14:59:5151 public:
Daniel Chenga542fca2014-10-21 09:51:2952 ~ChromeMetricsServiceClient() override;
[email protected]5bdaa2d2014-05-19 14:59:5153
[email protected]037642f2014-05-29 20:40:5054 // Factory function.
55 static scoped_ptr<ChromeMetricsServiceClient> Create(
56 metrics::MetricsStateManager* state_manager,
57 PrefService* local_state);
58
[email protected]4a55a712014-06-08 16:50:3459 // Registers local state prefs used by this class.
60 static void RegisterPrefs(PrefRegistrySimple* registry);
61
[email protected]5bdaa2d2014-05-19 14:59:5162 // metrics::MetricsServiceClient:
Daniel Chenga542fca2014-10-21 09:51:2963 void SetMetricsClientId(const std::string& client_id) override;
Mark Mentovaic67fa64f2015-03-24 14:00:0664 void OnRecordingDisabled() override;
Daniel Chenga542fca2014-10-21 09:51:2965 bool IsOffTheRecordSessionActive() override;
66 int32 GetProduct() override;
67 std::string GetApplicationLocale() override;
68 bool GetBrand(std::string* brand_code) override;
69 metrics::SystemProfileProto::Channel GetChannel() override;
70 std::string GetVersionString() override;
71 void OnLogUploadComplete() override;
72 void StartGatheringMetrics(const base::Closure& done_callback) override;
73 void CollectFinalMetrics(const base::Closure& done_callback) override;
74 scoped_ptr<metrics::MetricsLogUploader> CreateUploader(
mostynb2b52d1db2014-10-07 02:47:1775 const base::Callback<void(int)>& on_upload_complete) override;
gunsch7cbdcb22015-03-13 17:02:0576 base::TimeDelta GetStandardUploadInterval() override;
Daniel Chenga542fca2014-10-21 09:51:2977 base::string16 GetRegistryBackupKey() override;
[email protected]5bdaa2d2014-05-19 14:59:5178
asvitkinecbd420732014-08-26 22:15:4079 metrics::MetricsService* metrics_service() { return metrics_service_.get(); }
[email protected]d7ea39e2014-05-22 03:59:1880
[email protected]4a55a712014-06-08 16:50:3481 void LogPluginLoadingError(const base::FilePath& plugin_path);
82
[email protected]5bdaa2d2014-05-19 14:59:5183 private:
[email protected]037642f2014-05-29 20:40:5084 explicit ChromeMetricsServiceClient(
85 metrics::MetricsStateManager* state_manager);
86
[email protected]51994b22014-05-30 13:24:2187 // Completes the two-phase initialization of ChromeMetricsServiceClient.
88 void Initialize();
89
[email protected]4a55a712014-06-08 16:50:3490 // Callback that continues the init task by loading plugin information.
91 void OnInitTaskGotHardwareClass();
92
93 // Called after the Plugin init task has been completed that continues the
94 // init task by launching a task to gather Google Update statistics.
95 void OnInitTaskGotPluginInfo();
96
97 // Called after GoogleUpdate init task has been completed that continues the
ishermanfcf4639e82015-08-26 00:33:4998 // init task by loading drive metrics.
[email protected]4a55a712014-06-08 16:50:3499 void OnInitTaskGotGoogleUpdateData();
100
ishermanfcf4639e82015-08-26 00:33:49101 // Called after the drive metrics init task has been completed that continues
102 // the init task by loading profiler data.
103 void OnInitTaskGotDriveMetrics();
amistry9e2a8b42015-06-13 01:11:27104
isherman213b47c2015-08-28 08:20:46105 // Returns true iff profiler data should be included in the next metrics log.
106 // NOTE: This method is probabilistic and also updates internal state as a
107 // side-effect when called, so it should only be called once per log.
108 bool ShouldIncludeProfilerDataInLog();
109
[email protected]4a55a712014-06-08 16:50:34110 // TrackingSynchronizerObserver:
Daniel Chenga542fca2014-10-21 09:51:29111 void ReceivedProfilerData(
vadimte2de4732015-04-27 21:43:02112 const metrics::ProfilerDataAttributes& attributes,
vadimt379d7fe2015-04-01 00:09:35113 const tracked_objects::ProcessDataPhaseSnapshot& process_data_phase,
vadimt379d7fe2015-04-01 00:09:35114 const metrics::ProfilerEvents& past_profiler_events) override;
Daniel Chenga542fca2014-10-21 09:51:29115 void FinishedReceivingProfilerData() override;
[email protected]4a55a712014-06-08 16:50:34116
[email protected]4b4892b2014-05-22 15:06:15117 // Callbacks for various stages of final log info collection. Do not call
118 // these directly.
ishermanfcf4639e82015-08-26 00:33:49119 void CollectFinalHistograms();
[email protected]4b4892b2014-05-22 15:06:15120 void OnMemoryDetailCollectionDone();
121 void OnHistogramSynchronizationDone();
122
ishermanfcf4639e82015-08-26 00:33:49123 // Called after WebCache statistics have been received from a renderer
124 // process.
125 void OnWebCacheStatsRefresh(int host_id);
126
[email protected]daed87e2014-05-22 19:41:22127 // Records metrics about the switches present on the command line.
128 void RecordCommandLineMetrics();
129
[email protected]d7ea39e2014-05-22 03:59:18130 // Registers |this| as an observer for notifications which indicate that a
131 // user is performing work. This is useful to allow some features to sleep,
132 // until the machine becomes active, such as precluding UMA uploads unless
133 // there was recent activity.
134 void RegisterForNotifications();
135
136 // content::NotificationObserver:
Daniel Chenga542fca2014-10-21 09:51:29137 void Observe(int type,
138 const content::NotificationSource& source,
139 const content::NotificationDetails& details) override;
[email protected]d7ea39e2014-05-22 03:59:18140
blundell26b95242015-08-17 10:29:24141 // Called when a URL is opened from the Omnibox.
142 void OnURLOpenedFromOmnibox(OmniboxLog* log);
143
[email protected]e2481a702014-05-23 21:06:50144#if defined(OS_WIN)
145 // Counts (and removes) the browser crash dump attempt signals left behind by
146 // any previous browser processes which generated a crash dump.
147 void CountBrowserCrashDumpAttempts();
148#endif // OS_WIN
149
[email protected]4b4892b2014-05-22 15:06:15150 base::ThreadChecker thread_checker_;
151
[email protected]51994b22014-05-30 13:24:21152 // Weak pointer to the MetricsStateManager.
153 metrics::MetricsStateManager* metrics_state_manager_;
154
[email protected]037642f2014-05-29 20:40:50155 // The MetricsService that |this| is a client of.
asvitkinecbd420732014-08-26 22:15:40156 scoped_ptr<metrics::MetricsService> metrics_service_;
[email protected]d7ea39e2014-05-22 03:59:18157
158 content::NotificationRegistrar registrar_;
[email protected]d7ea39e2014-05-22 03:59:18159
[email protected]51994b22014-05-30 13:24:21160 // On ChromeOS, holds a weak pointer to the ChromeOSMetricsProvider instance
161 // that has been registered with MetricsService. On other platforms, is NULL.
162 ChromeOSMetricsProvider* chromeos_metrics_provider_;
163
[email protected]4b4892b2014-05-22 15:06:15164 // Saved callback received from CollectFinalMetrics().
165 base::Closure collect_final_metrics_done_callback_;
166
167 // Indicates that collect final metrics step is running.
168 bool waiting_for_collect_final_metrics_step_;
169
170 // Number of async histogram fetch requests in progress.
171 int num_async_histogram_fetches_in_progress_;
172
[email protected]4a55a712014-06-08 16:50:34173 // The ProfilerMetricsProvider instance that was registered with
174 // MetricsService. Has the same lifetime as |metrics_service_|.
gunsch840bc412014-09-18 19:38:06175 metrics::ProfilerMetricsProvider* profiler_metrics_provider_;
[email protected]4a55a712014-06-08 16:50:34176
177#if defined(ENABLE_PLUGINS)
178 // The PluginMetricsProvider instance that was registered with
179 // MetricsService. Has the same lifetime as |metrics_service_|.
180 PluginMetricsProvider* plugin_metrics_provider_;
181#endif
182
183#if defined(OS_WIN)
184 // The GoogleUpdateMetricsProviderWin instance that was registered with
185 // MetricsService. Has the same lifetime as |metrics_service_|.
186 GoogleUpdateMetricsProviderWin* google_update_metrics_provider_;
187#endif
188
dbeam64c37842015-03-18 02:23:35189 // The DriveMetricsProvider instance that was registered with MetricsService.
190 // Has the same lifetime as |metrics_service_|.
blundellb5c6b5a2015-07-30 20:18:30191 metrics::DriveMetricsProvider* drive_metrics_provider_;
dbeam64c37842015-03-18 02:23:35192
[email protected]4a55a712014-06-08 16:50:34193 // Callback that is called when initial metrics gathering is complete.
194 base::Closure finished_gathering_initial_metrics_callback_;
195
[email protected]8a5b2da2014-07-07 10:56:51196 // The MemoryGrowthTracker instance that tracks memory usage growth in
197 // MemoryDetails.
198 MemoryGrowthTracker memory_growth_tracker_;
199
gunsch7cbdcb22015-03-13 17:02:05200 // Callback to determine whether or not a cellular network is currently being
201 // used.
202 base::Callback<void(bool*)> cellular_callback_;
203
vadimte2de4732015-04-27 21:43:02204 // Time of this object's creation.
205 const base::TimeTicks start_time_;
206
amistry9e2a8b42015-06-13 01:11:27207 // Map of ProcessResourceUsage from render process host IDs.
mgiucad6af3212015-06-24 09:45:45208 base::ScopedPtrMap<int, scoped_ptr<ProcessResourceUsage>>
209 host_resource_usage_map_;
amistry9e2a8b42015-06-13 01:11:27210
blundell26b95242015-08-17 10:29:24211 // Subscription for receiving callbacks that a URL was opened from the
212 // omnibox.
213 scoped_ptr<base::CallbackList<void(OmniboxLog*)>::Subscription>
214 omnibox_url_opened_subscription_;
215
isherman213b47c2015-08-28 08:20:46216 // Whether this client has already uploaded profiler data during this session.
217 // Profiler data is uploaded at most once per session.
218 bool has_uploaded_profiler_data_;
219
[email protected]4b4892b2014-05-22 15:06:15220 base::WeakPtrFactory<ChromeMetricsServiceClient> weak_ptr_factory_;
221
[email protected]5bdaa2d2014-05-19 14:59:51222 DISALLOW_COPY_AND_ASSIGN(ChromeMetricsServiceClient);
223};
224
225#endif // CHROME_BROWSER_METRICS_CHROME_METRICS_SERVICE_CLIENT_H_