| 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_client.h" | 5 #include "chrome/browser/metrics/chrome_metrics_service_client.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 | 8 |
| 9 #include <set> | 9 #include <set> |
| 10 #include <utility> | 10 #include <utility> |
| (...skipping 159 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 170 #endif | 170 #endif |
| 171 } | 171 } |
| 172 | 172 |
| 173 // Constructs the name of a persistent metrics file from a directory and metrics | 173 // Constructs the name of a persistent metrics file from a directory and metrics |
| 174 // name, and either registers that file as associated with a previous run if | 174 // name, and either registers that file as associated with a previous run if |
| 175 // metrics reporting is enabled, or deletes it if not. | 175 // metrics reporting is enabled, or deletes it if not. |
| 176 void RegisterOrRemovePreviousRunMetricsFile( | 176 void RegisterOrRemovePreviousRunMetricsFile( |
| 177 bool metrics_reporting_enabled, | 177 bool metrics_reporting_enabled, |
| 178 const base::FilePath& dir, | 178 const base::FilePath& dir, |
| 179 base::StringPiece metrics_name, | 179 base::StringPiece metrics_name, |
| 180 bool require_internal_profile, |
| 180 scoped_refptr<base::TaskRunner> task_runner, | 181 scoped_refptr<base::TaskRunner> task_runner, |
| 181 metrics::FileMetricsProvider* file_metrics_provider) { | 182 metrics::FileMetricsProvider* file_metrics_provider) { |
| 182 base::FilePath metrics_file; | 183 base::FilePath metrics_file; |
| 183 base::GlobalHistogramAllocator::ConstructFilePaths( | 184 base::GlobalHistogramAllocator::ConstructFilePaths( |
| 184 dir, metrics_name, &metrics_file, nullptr, nullptr); | 185 dir, metrics_name, &metrics_file, nullptr, nullptr); |
| 185 | 186 |
| 186 if (metrics_reporting_enabled) { | 187 if (metrics_reporting_enabled) { |
| 187 // Enable reading any existing saved metrics. | 188 // Enable reading any existing saved metrics. |
| 188 file_metrics_provider->RegisterSource( | 189 file_metrics_provider->RegisterSource( |
| 189 metrics_file, | 190 metrics_file, |
| 190 metrics::FileMetricsProvider::SOURCE_HISTOGRAMS_ATOMIC_FILE, | 191 metrics::FileMetricsProvider::SOURCE_HISTOGRAMS_ATOMIC_FILE, |
| 191 metrics::FileMetricsProvider::ASSOCIATE_PREVIOUS_RUN, metrics_name); | 192 require_internal_profile |
| 193 ? metrics::FileMetricsProvider::ASSOCIATE_INTERNAL_PROFILE |
| 194 : metrics::FileMetricsProvider:: |
| 195 ASSOCIATE_INTERNAL_PROFILE_OR_PREVIOUS_RUN, |
| 196 metrics_name); |
| 192 } else { | 197 } else { |
| 193 // When metrics reporting is not enabled, any existing file should be | 198 // When metrics reporting is not enabled, any existing file should be |
| 194 // deleted in order to preserve user privacy. | 199 // deleted in order to preserve user privacy. |
| 195 task_runner->PostTask(FROM_HERE, | 200 task_runner->PostTask(FROM_HERE, |
| 196 base::BindOnce(base::IgnoreResult(&base::DeleteFile), | 201 base::BindOnce(base::IgnoreResult(&base::DeleteFile), |
| 197 metrics_file, /*recursive=*/false)); | 202 metrics_file, /*recursive=*/false)); |
| 198 } | 203 } |
| 199 } | 204 } |
| 200 | 205 |
| 201 std::unique_ptr<metrics::FileMetricsProvider> CreateFileMetricsProvider( | 206 std::unique_ptr<metrics::FileMetricsProvider> CreateFileMetricsProvider( |
| (...skipping 14 matching lines...) Expand all Loading... |
| 216 if (base::PathService::Get(chrome::DIR_USER_DATA, &user_data_dir)) { | 221 if (base::PathService::Get(chrome::DIR_USER_DATA, &user_data_dir)) { |
| 217 // Reporting of persistent histograms from last session is controlled by | 222 // Reporting of persistent histograms from last session is controlled by |
| 218 // a feature param. TODO(bcwhite): The current default is not to upload | 223 // a feature param. TODO(bcwhite): The current default is not to upload |
| 219 // until some issues are resolved. See crbug.com/706422 for details. | 224 // until some issues are resolved. See crbug.com/706422 for details. |
| 220 std::string send_unreported = base::GetFieldTrialParamValueByFeature( | 225 std::string send_unreported = base::GetFieldTrialParamValueByFeature( |
| 221 base::kPersistentHistogramsFeature, "send_unreported_metrics"); | 226 base::kPersistentHistogramsFeature, "send_unreported_metrics"); |
| 222 bool report_previous_persistent_histograms = | 227 bool report_previous_persistent_histograms = |
| 223 metrics_reporting_enabled && (send_unreported == "yes"); | 228 metrics_reporting_enabled && (send_unreported == "yes"); |
| 224 RegisterOrRemovePreviousRunMetricsFile( | 229 RegisterOrRemovePreviousRunMetricsFile( |
| 225 report_previous_persistent_histograms, user_data_dir, | 230 report_previous_persistent_histograms, user_data_dir, |
| 226 ChromeMetricsServiceClient::kBrowserMetricsName, task_runner, | 231 ChromeMetricsServiceClient::kBrowserMetricsName, true, task_runner, |
| 227 file_metrics_provider.get()); | 232 file_metrics_provider.get()); |
| 228 | 233 |
| 229 // Register the Crashpad metrics files. | 234 // Register the Crashpad metrics files. |
| 230 // Register the data from the previous run if crashpad_handler didn't exit | 235 // Register the data from the previous run if crashpad_handler didn't exit |
| 231 // cleanly. | 236 // cleanly. |
| 232 RegisterOrRemovePreviousRunMetricsFile( | 237 RegisterOrRemovePreviousRunMetricsFile( |
| 233 metrics_reporting_enabled, user_data_dir, | 238 metrics_reporting_enabled, user_data_dir, |
| 234 kCrashpadHistogramAllocatorName, task_runner, | 239 kCrashpadHistogramAllocatorName, false, task_runner, |
| 235 file_metrics_provider.get()); | 240 file_metrics_provider.get()); |
| 236 if (metrics_reporting_enabled) { | 241 if (metrics_reporting_enabled) { |
| 237 base::FilePath active_path; | 242 base::FilePath active_path; |
| 238 base::GlobalHistogramAllocator::ConstructFilePaths( | 243 base::GlobalHistogramAllocator::ConstructFilePaths( |
| 239 user_data_dir, kCrashpadHistogramAllocatorName, nullptr, &active_path, | 244 user_data_dir, kCrashpadHistogramAllocatorName, nullptr, &active_path, |
| 240 nullptr); | 245 nullptr); |
| 241 // Register data that will be populated for the current run. "Active" | 246 // Register data that will be populated for the current run. "Active" |
| 242 // files need an empty "prefs_key" because they update the file itself. | 247 // files need an empty "prefs_key" because they update the file itself. |
| 243 file_metrics_provider->RegisterSource( | 248 file_metrics_provider->RegisterSource( |
| 244 active_path, | 249 active_path, |
| (...skipping 748 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 993 ukm_service_->Purge(); | 998 ukm_service_->Purge(); |
| 994 ukm_service_->ResetClientId(); | 999 ukm_service_->ResetClientId(); |
| 995 } | 1000 } |
| 996 // Signal service manager to enable/disable UKM based on new state. | 1001 // Signal service manager to enable/disable UKM based on new state. |
| 997 UpdateRunningServices(); | 1002 UpdateRunningServices(); |
| 998 } | 1003 } |
| 999 | 1004 |
| 1000 bool ChromeMetricsServiceClient::IsHistorySyncEnabledOnAllProfiles() { | 1005 bool ChromeMetricsServiceClient::IsHistorySyncEnabledOnAllProfiles() { |
| 1001 return SyncDisableObserver::IsHistorySyncEnabledOnAllProfiles(); | 1006 return SyncDisableObserver::IsHistorySyncEnabledOnAllProfiles(); |
| 1002 } | 1007 } |
| OLD | NEW |