Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/metrics/metrics_reporting_state.h" | 5 #include "chrome/browser/metrics/metrics_reporting_state.h" |
| 6 | 6 |
| 7 #include "base/callback.h" | 7 #include "base/callback.h" |
| 8 #include "base/metrics/histogram.h" | 8 #include "base/metrics/histogram.h" |
| 9 #include "base/prefs/pref_service.h" | 9 #include "base/prefs/pref_service.h" |
| 10 #include "chrome/browser/browser_process.h" | 10 #include "chrome/browser/browser_process.h" |
| 11 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" | 11 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" |
| 12 #include "chrome/installer/util/google_update_settings.h" | 12 #include "chrome/installer/util/google_update_settings.h" |
| 13 #include "components/metrics/metrics_pref_names.h" | 13 #include "components/metrics/metrics_pref_names.h" |
| 14 #include "components/metrics/metrics_service.h" | 14 #include "components/metrics/metrics_service.h" |
| 15 #include "content/public/browser/browser_thread.h" | 15 #include "content/public/browser/browser_thread.h" |
| 16 | 16 |
| 17 #if defined(OS_CHROMEOS) | |
| 18 #include "chrome/browser/chromeos/settings/cros_settings.h" | |
| 19 #include "chromeos/settings/cros_settings_names.h" | |
| 20 #endif // defined(OS_CHROMEOS) | |
| 21 | |
| 17 namespace { | 22 namespace { |
| 18 | 23 |
| 19 enum MetricsReportingChangeHistogramValue { | 24 enum MetricsReportingChangeHistogramValue { |
| 20 METRICS_REPORTING_ERROR, | 25 METRICS_REPORTING_ERROR, |
| 21 METRICS_REPORTING_DISABLED, | 26 METRICS_REPORTING_DISABLED, |
| 22 METRICS_REPORTING_ENABLED, | 27 METRICS_REPORTING_ENABLED, |
| 23 METRICS_REPORTING_MAX | 28 METRICS_REPORTING_MAX |
| 24 }; | 29 }; |
| 25 | 30 |
| 26 void RecordMetricsReportingHistogramValue( | 31 void RecordMetricsReportingHistogramValue( |
| (...skipping 24 matching lines...) Expand all Loading... | |
| 51 void SetMetricsReporting(bool to_update_pref, | 56 void SetMetricsReporting(bool to_update_pref, |
| 52 const OnMetricsReportingCallbackType& callback_fn, | 57 const OnMetricsReportingCallbackType& callback_fn, |
| 53 bool updated_pref) { | 58 bool updated_pref) { |
| 54 metrics::MetricsService* metrics = g_browser_process->metrics_service(); | 59 metrics::MetricsService* metrics = g_browser_process->metrics_service(); |
| 55 if (metrics) { | 60 if (metrics) { |
| 56 if (updated_pref) | 61 if (updated_pref) |
| 57 metrics->Start(); | 62 metrics->Start(); |
| 58 else | 63 else |
| 59 metrics->Stop(); | 64 metrics->Stop(); |
| 60 } | 65 } |
| 61 #if !defined(OS_CHROMEOS) && !defined(OS_ANDROID) | 66 |
| 67 #if !defined(OS_ANDROID) | |
| 62 g_browser_process->local_state()->SetBoolean( | 68 g_browser_process->local_state()->SetBoolean( |
| 63 metrics::prefs::kMetricsReportingEnabled, updated_pref); | 69 metrics::prefs::kMetricsReportingEnabled, updated_pref); |
| 64 #endif | 70 #endif // !defined(OS_ANDROID) |
| 71 | |
| 65 // When a user opts in to the metrics reporting service, the previously | 72 // When a user opts in to the metrics reporting service, the previously |
| 66 // collected data should be cleared to ensure that nothing is reported before | 73 // collected data should be cleared to ensure that nothing is reported before |
| 67 // a user opts in and all reported data is accurate. | 74 // a user opts in and all reported data is accurate. |
| 68 if (updated_pref && metrics) | 75 if (updated_pref && metrics) |
| 69 metrics->ClearSavedStabilityMetrics(); | 76 metrics->ClearSavedStabilityMetrics(); |
| 70 | 77 |
| 71 if (to_update_pref == updated_pref) { | 78 if (to_update_pref == updated_pref) { |
| 72 RecordMetricsReportingHistogramValue(updated_pref ? | 79 RecordMetricsReportingHistogramValue(updated_pref ? |
| 73 METRICS_REPORTING_ENABLED : METRICS_REPORTING_DISABLED); | 80 METRICS_REPORTING_ENABLED : METRICS_REPORTING_DISABLED); |
| 74 } else { | 81 } else { |
| 75 RecordMetricsReportingHistogramValue(METRICS_REPORTING_ERROR); | 82 RecordMetricsReportingHistogramValue(METRICS_REPORTING_ERROR); |
| 76 } | 83 } |
| 77 if (!callback_fn.is_null()) | 84 if (!callback_fn.is_null()) |
| 78 callback_fn.Run(updated_pref); | 85 callback_fn.Run(updated_pref); |
| 79 } | 86 } |
| 80 | 87 |
| 88 #if defined(OS_CHROMEOS) | |
| 89 // Callback function for Chrome OS device settings change. | |
|
Alexei Svitkine (slow)
2015/11/05 20:20:00
Nit: Expand comment.
e.g. (% wrapping)
// Callba
gayane -on leave until 09-2017
2015/11/06 21:41:13
Done.
| |
| 90 void OnDeviceSettingChange() { | |
| 91 bool enable_metrics = false; | |
| 92 chromeos::CrosSettings::Get()->GetBoolean(chromeos::kStatsReportingPref, | |
| 93 &enable_metrics); | |
| 94 InitiateMetricsReportingChange(enable_metrics, | |
| 95 OnMetricsReportingCallbackType()); | |
| 96 } | |
| 97 #endif | |
| 98 | |
| 81 } // namespace | 99 } // namespace |
| 82 | 100 |
| 101 // TODO(gayane): Instead of checking policy before setting the metrics pref set | |
| 102 // the pref and register for notifications for the rest of the changes. | |
| 83 void InitiateMetricsReportingChange( | 103 void InitiateMetricsReportingChange( |
| 84 bool enabled, | 104 bool enabled, |
| 85 const OnMetricsReportingCallbackType& callback_fn) { | 105 const OnMetricsReportingCallbackType& callback_fn) { |
| 86 #if !defined(OS_CHROMEOS) && !defined(OS_ANDROID) | 106 #if !defined(OS_ANDROID) |
| 87 if (!IsMetricsReportingUserChangable()) { | 107 if (IsMetricsReportingPolicyManaged()) { |
| 88 if (!callback_fn.is_null()) { | 108 if (!callback_fn.is_null()) { |
| 89 callback_fn.Run( | 109 callback_fn.Run( |
| 90 ChromeMetricsServiceAccessor::IsMetricsAndCrashReportingEnabled()); | 110 ChromeMetricsServiceAccessor::IsMetricsAndCrashReportingEnabled()); |
| 91 } | 111 } |
| 92 return; | 112 return; |
| 93 } | 113 } |
| 94 #endif | 114 #endif |
| 95 // Posts to FILE thread as SetGoogleUpdateSettings does IO operations. | 115 // Posts to FILE thread as SetGoogleUpdateSettings does IO operations. |
| 96 content::BrowserThread::PostTaskAndReplyWithResult( | 116 content::BrowserThread::PostTaskAndReplyWithResult( |
| 97 content::BrowserThread::FILE, | 117 content::BrowserThread::FILE, |
| 98 FROM_HERE, | 118 FROM_HERE, |
| 99 base::Bind(&SetGoogleUpdateSettings, enabled), | 119 base::Bind(&SetGoogleUpdateSettings, enabled), |
| 100 base::Bind(&SetMetricsReporting, enabled, callback_fn)); | 120 base::Bind(&SetMetricsReporting, enabled, callback_fn)); |
| 101 } | 121 } |
| 102 | 122 |
| 103 bool IsMetricsReportingUserChangable() { | 123 bool IsMetricsReportingPolicyManaged() { |
| 104 const PrefService* pref_service = g_browser_process->local_state(); | 124 const PrefService* pref_service = g_browser_process->local_state(); |
| 105 const PrefService::Preference* pref = | 125 const PrefService::Preference* pref = |
| 106 pref_service->FindPreference(metrics::prefs::kMetricsReportingEnabled); | 126 pref_service->FindPreference(metrics::prefs::kMetricsReportingEnabled); |
| 107 return pref && !pref->IsManaged(); | 127 return pref && pref->IsManaged(); |
| 108 } | 128 } |
| 129 | |
| 130 // TODO(gayane): Add unittest which will check that observer on device settings | |
| 131 // will trigger this function and kMetricsReportinEnabled as well as metrics | |
| 132 // service state will be updated accordingly. | |
| 133 void SetupMetricsStateForChromeOS() { | |
| 134 #if defined(OS_CHROMEOS) | |
| 135 chromeos::CrosSettings::Get()->AddSettingsObserver( | |
| 136 chromeos::kStatsReportingPref, base::Bind(&OnDeviceSettingChange)); | |
| 137 | |
| 138 OnDeviceSettingChange(); | |
| 139 #endif // defined(OS_CHROMEOS) | |
| 140 } | |
| OLD | NEW |