Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/chrome_metrics_service_accessor.h" | 5 #include "chrome/browser/metrics/chrome_metrics_service_accessor.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | |
| 7 #include "base/prefs/pref_service.h" | 8 #include "base/prefs/pref_service.h" |
| 8 #include "chrome/browser/browser_process.h" | 9 #include "chrome/browser/browser_process.h" |
| 10 #include "chrome/browser/metrics/metrics_services_manager.h" | |
| 11 #include "chrome/common/chrome_switches.h" | |
| 9 #include "chrome/common/pref_names.h" | 12 #include "chrome/common/pref_names.h" |
| 10 #include "components/metrics/metrics_service.h" | 13 #include "components/metrics/metrics_service.h" |
| 11 #include "components/variations/metrics_util.h" | 14 #include "components/variations/metrics_util.h" |
| 12 | 15 |
| 13 #if defined(OS_CHROMEOS) | 16 #if defined(OS_CHROMEOS) |
| 14 #include "chrome/browser/chromeos/settings/cros_settings.h" | 17 #include "chrome/browser/chromeos/settings/cros_settings.h" |
| 15 #endif | 18 #endif |
| 16 | 19 |
| 17 // static | 20 // static |
| 18 bool ChromeMetricsServiceAccessor::IsMetricsReportingEnabled() { | 21 bool ChromeMetricsServiceAccessor::IsMetricsReportingEnabled() { |
| 19 bool result = false; | 22 // If the user permits metrics reporting with the checkbox in the |
| 20 const PrefService* local_state = g_browser_process->local_state(); | 23 // prefs, we turn on recording. We disable metrics completely for |
| 21 if (local_state) { | 24 // non-official builds, or when field trials are forced. |
| 22 const PrefService::Preference* uma_pref = | 25 if (base::CommandLine::ForCurrentProcess()->HasSwitch( |
| 23 local_state->FindPreference(prefs::kMetricsReportingEnabled); | 26 switches::kForceFieldTrials)) |
|
Alexei Svitkine (slow)
2015/02/12 15:58:46
Nit: While you're touching this, add {}'s here.
anthonyvd
2015/02/12 16:29:19
Done.
| |
| 24 if (uma_pref) { | 27 return false; |
| 25 bool success = uma_pref->GetValue()->GetAsBoolean(&result); | 28 |
| 26 DCHECK(success); | 29 bool enabled = false; |
| 27 } | 30 #if defined(GOOGLE_CHROME_BUILD) |
| 28 } | 31 #if defined(OS_CHROMEOS) |
| 29 return result; | 32 chromeos::CrosSettings::Get()->GetBoolean(chromeos::kStatsReportingPref, |
| 33 &enabled); | |
| 34 #else | |
| 35 enabled = local_state_->GetBoolean(prefs::kMetricsReportingEnabled); | |
|
Alexei Svitkine (slow)
2015/02/12 15:58:46
I don't think this will compile, since there's no
anthonyvd
2015/02/12 16:29:19
Done.
| |
| 36 #endif // #if defined(OS_CHROMEOS) | |
| 37 #endif // defined(GOOGLE_CHROME_BUILD) | |
| 38 return enabled; | |
| 30 } | 39 } |
| 31 | 40 |
| 32 bool ChromeMetricsServiceAccessor::IsCrashReportingEnabled() { | 41 bool ChromeMetricsServiceAccessor::IsCrashReportingEnabled() { |
| 33 #if defined(GOOGLE_CHROME_BUILD) | 42 #if defined(GOOGLE_CHROME_BUILD) |
| 34 #if defined(OS_CHROMEOS) | 43 #if defined(OS_ANDROID) |
| 35 bool reporting_enabled = false; | |
| 36 chromeos::CrosSettings::Get()->GetBoolean(chromeos::kStatsReportingPref, | |
| 37 &reporting_enabled); | |
| 38 return reporting_enabled; | |
| 39 #elif defined(OS_ANDROID) | |
| 40 // Android has its own settings for metrics / crash uploading. | 44 // Android has its own settings for metrics / crash uploading. |
| 41 const PrefService* prefs = g_browser_process->local_state(); | 45 const PrefService* prefs = g_browser_process->local_state(); |
| 42 return prefs->GetBoolean(prefs::kCrashReportingEnabled); | 46 return prefs->GetBoolean(prefs::kCrashReportingEnabled); |
| 43 #else | 47 #else |
| 44 return ChromeMetricsServiceAccessor::IsMetricsReportingEnabled(); | 48 return ChromeMetricsServiceAccessor::IsMetricsReportingEnabled(); |
| 45 #endif | 49 #endif |
| 46 #else | 50 #else |
| 47 return false; | 51 return false; |
| 48 #endif | 52 #endif |
| 49 } | 53 } |
| 50 | 54 |
| 51 // static | 55 // static |
| 52 bool ChromeMetricsServiceAccessor::RegisterSyntheticFieldTrial( | 56 bool ChromeMetricsServiceAccessor::RegisterSyntheticFieldTrial( |
| 53 const std::string& trial_name, | 57 const std::string& trial_name, |
| 54 const std::string& group_name) { | 58 const std::string& group_name) { |
| 55 return RegisterSyntheticFieldTrialWithNameHash(metrics::HashName(trial_name), | 59 return RegisterSyntheticFieldTrialWithNameHash(metrics::HashName(trial_name), |
| 56 group_name); | 60 group_name); |
| 57 } | 61 } |
| 58 | 62 |
| 59 // static | 63 // static |
| 60 bool ChromeMetricsServiceAccessor::RegisterSyntheticFieldTrialWithNameHash( | 64 bool ChromeMetricsServiceAccessor::RegisterSyntheticFieldTrialWithNameHash( |
| 61 uint32_t trial_name_hash, | 65 uint32_t trial_name_hash, |
| 62 const std::string& group_name) { | 66 const std::string& group_name) { |
| 63 return metrics::MetricsServiceAccessor::RegisterSyntheticFieldTrial( | 67 return metrics::MetricsServiceAccessor::RegisterSyntheticFieldTrial( |
| 64 g_browser_process->metrics_service(), | 68 g_browser_process->metrics_service(), |
| 65 trial_name_hash, | 69 trial_name_hash, |
| 66 metrics::HashName(group_name)); | 70 metrics::HashName(group_name)); |
| 67 } | 71 } |
| OLD | NEW |