Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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_services_manager_client.h" | 5 #include "chrome/browser/metrics/chrome_metrics_services_manager_client.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/feature_list.h" | 8 #include "base/feature_list.h" |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/memory/ptr_util.h" | 10 #include "base/memory/ptr_util.h" |
| (...skipping 21 matching lines...) Expand all Loading... | |
| 32 | 32 |
| 33 // Metrics reporting feature. This feature, along with user consent, controls if | 33 // Metrics reporting feature. This feature, along with user consent, controls if |
| 34 // recording and reporting are enabled. If the feature is enabled, but no | 34 // recording and reporting are enabled. If the feature is enabled, but no |
| 35 // consent is given, then there will be no recording or reporting. | 35 // consent is given, then there will be no recording or reporting. |
| 36 const base::Feature kMetricsReportingFeature{"MetricsReporting", | 36 const base::Feature kMetricsReportingFeature{"MetricsReporting", |
| 37 base::FEATURE_ENABLED_BY_DEFAULT}; | 37 base::FEATURE_ENABLED_BY_DEFAULT}; |
| 38 | 38 |
| 39 // Posts |GoogleUpdateSettings::StoreMetricsClientInfo| on blocking pool thread | 39 // Posts |GoogleUpdateSettings::StoreMetricsClientInfo| on blocking pool thread |
| 40 // because it needs access to IO and cannot work from UI thread. | 40 // because it needs access to IO and cannot work from UI thread. |
| 41 void PostStoreMetricsClientInfo(const metrics::ClientInfo& client_info) { | 41 void PostStoreMetricsClientInfo(const metrics::ClientInfo& client_info) { |
| 42 content::BrowserThread::GetBlockingPool()->PostTask( | 42 content::BrowserThread::PostAfterStartupTask( |
| 43 FROM_HERE, | 43 FROM_HERE, content::BrowserThread::GetBlockingPool(), |
|
Alexei Svitkine (slow)
2016/08/12 18:28:18
Hmm, in the following CL I'm clearing the client i
gab
2016/08/15 19:39:56
If there is, the race condition already exists tod
| |
| 44 base::Bind(&GoogleUpdateSettings::StoreMetricsClientInfo, client_info)); | 44 base::Bind(&GoogleUpdateSettings::StoreMetricsClientInfo, client_info)); |
| 45 } | 45 } |
| 46 | 46 |
| 47 // Only clients that were given an opt-out metrics-reporting consent flow are | 47 // Only clients that were given an opt-out metrics-reporting consent flow are |
| 48 // eligible for sampling. | 48 // eligible for sampling. |
| 49 bool IsClientEligibleForSampling() { | 49 bool IsClientEligibleForSampling() { |
| 50 return metrics::GetMetricsReportingDefaultState( | 50 return metrics::GetMetricsReportingDefaultState( |
| 51 g_browser_process->local_state()) == | 51 g_browser_process->local_state()) == |
| 52 metrics::EnableMetricsDefault::OPT_OUT; | 52 metrics::EnableMetricsDefault::OPT_OUT; |
| 53 } | 53 } |
| (...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 175 ChromeMetricsServicesManagerClient::GetMetricsStateManager() { | 175 ChromeMetricsServicesManagerClient::GetMetricsStateManager() { |
| 176 DCHECK(thread_checker_.CalledOnValidThread()); | 176 DCHECK(thread_checker_.CalledOnValidThread()); |
| 177 if (!metrics_state_manager_) { | 177 if (!metrics_state_manager_) { |
| 178 metrics_state_manager_ = metrics::MetricsStateManager::Create( | 178 metrics_state_manager_ = metrics::MetricsStateManager::Create( |
| 179 local_state_, enabled_state_provider_.get(), | 179 local_state_, enabled_state_provider_.get(), |
| 180 base::Bind(&PostStoreMetricsClientInfo), | 180 base::Bind(&PostStoreMetricsClientInfo), |
| 181 base::Bind(&GoogleUpdateSettings::LoadMetricsClientInfo)); | 181 base::Bind(&GoogleUpdateSettings::LoadMetricsClientInfo)); |
| 182 } | 182 } |
| 183 return metrics_state_manager_.get(); | 183 return metrics_state_manager_.get(); |
| 184 } | 184 } |
| OLD | NEW |