xref: /aosp_15_r20/external/cronet/components/metrics/metrics_service_client.cc (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker // Copyright 2014 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker 
5*6777b538SAndroid Build Coastguard Worker #include "components/metrics/metrics_service_client.h"
6*6777b538SAndroid Build Coastguard Worker 
7*6777b538SAndroid Build Coastguard Worker #include <algorithm>
8*6777b538SAndroid Build Coastguard Worker #include <string>
9*6777b538SAndroid Build Coastguard Worker 
10*6777b538SAndroid Build Coastguard Worker #include "base/command_line.h"
11*6777b538SAndroid Build Coastguard Worker #include "base/logging.h"
12*6777b538SAndroid Build Coastguard Worker #include "base/strings/string_number_conversions.h"
13*6777b538SAndroid Build Coastguard Worker #include "base/strings/string_util.h"
14*6777b538SAndroid Build Coastguard Worker #include "build/build_config.h"
15*6777b538SAndroid Build Coastguard Worker #include "components/metrics/metrics_features.h"
16*6777b538SAndroid Build Coastguard Worker #include "components/metrics/metrics_switches.h"
17*6777b538SAndroid Build Coastguard Worker #include "components/metrics/url_constants.h"
18*6777b538SAndroid Build Coastguard Worker #include "metrics_service_client.h"
19*6777b538SAndroid Build Coastguard Worker 
20*6777b538SAndroid Build Coastguard Worker namespace metrics {
21*6777b538SAndroid Build Coastguard Worker 
22*6777b538SAndroid Build Coastguard Worker namespace {
23*6777b538SAndroid Build Coastguard Worker 
24*6777b538SAndroid Build Coastguard Worker // The number of initial/ongoing logs to persist in the queue before logs are
25*6777b538SAndroid Build Coastguard Worker // dropped.
26*6777b538SAndroid Build Coastguard Worker // Note: Both the count threshold and the bytes threshold (see
27*6777b538SAndroid Build Coastguard Worker // `kLogBytesTrimThreshold` below) must be reached for logs to be
28*6777b538SAndroid Build Coastguard Worker // dropped/trimmed.
29*6777b538SAndroid Build Coastguard Worker //
30*6777b538SAndroid Build Coastguard Worker // Note that each ongoing log may be pretty large, since "initial" logs must
31*6777b538SAndroid Build Coastguard Worker // first be sent before any ongoing logs are transmitted. "Initial" logs will
32*6777b538SAndroid Build Coastguard Worker // not be sent if a user is offline. As a result, the current ongoing log will
33*6777b538SAndroid Build Coastguard Worker // accumulate until the "initial" log can be transmitted. We don't want to save
34*6777b538SAndroid Build Coastguard Worker // too many of these mega-logs (this should be capped by
35*6777b538SAndroid Build Coastguard Worker // kLogBytesTrimThreshold).
36*6777b538SAndroid Build Coastguard Worker //
37*6777b538SAndroid Build Coastguard Worker // A "standard shutdown" will create a small log, including just the data that
38*6777b538SAndroid Build Coastguard Worker // was not yet been transmitted, and that is normal (to have exactly one
39*6777b538SAndroid Build Coastguard Worker // ongoing log at startup).
40*6777b538SAndroid Build Coastguard Worker //
41*6777b538SAndroid Build Coastguard Worker // Refer to //components/metrics/unsent_log_store.h for more details on when
42*6777b538SAndroid Build Coastguard Worker // logs are dropped.
43*6777b538SAndroid Build Coastguard Worker const base::FeatureParam<int> kInitialLogCountTrimThreshold{
44*6777b538SAndroid Build Coastguard Worker     &features::kMetricsLogTrimming, "initial_log_count_trim_threshold", 20};
45*6777b538SAndroid Build Coastguard Worker const base::FeatureParam<int> kOngoingLogCountTrimThreshold{
46*6777b538SAndroid Build Coastguard Worker     &features::kMetricsLogTrimming, "ongoing_log_count_trim_threshold", 8};
47*6777b538SAndroid Build Coastguard Worker 
48*6777b538SAndroid Build Coastguard Worker // The number bytes of the queue to be persisted before logs are dropped. This
49*6777b538SAndroid Build Coastguard Worker // will be applied to both log queues (initial/ongoing). This ensures that a
50*6777b538SAndroid Build Coastguard Worker // reasonable amount of history will be stored even if there is a long series of
51*6777b538SAndroid Build Coastguard Worker // very small logs.
52*6777b538SAndroid Build Coastguard Worker // Note: Both the count threshold (see `kInitialLogCountTrimThreshold` and
53*6777b538SAndroid Build Coastguard Worker // `kOngoingLogCountTrimThreshold` above) and the bytes threshold must be
54*6777b538SAndroid Build Coastguard Worker // reached for logs to be dropped/trimmed.
55*6777b538SAndroid Build Coastguard Worker //
56*6777b538SAndroid Build Coastguard Worker // Refer to //components/metrics/unsent_log_store.h for more details on when
57*6777b538SAndroid Build Coastguard Worker // logs are dropped.
58*6777b538SAndroid Build Coastguard Worker const base::FeatureParam<int> kLogBytesTrimThreshold{
59*6777b538SAndroid Build Coastguard Worker     &features::kMetricsLogTrimming, "log_bytes_trim_threshold",
60*6777b538SAndroid Build Coastguard Worker     300 * 1024  // 300 KiB
61*6777b538SAndroid Build Coastguard Worker };
62*6777b538SAndroid Build Coastguard Worker 
63*6777b538SAndroid Build Coastguard Worker // If an initial/ongoing metrics log upload fails, and the transmission is over
64*6777b538SAndroid Build Coastguard Worker // this byte count, then we will discard the log, and not try to retransmit it.
65*6777b538SAndroid Build Coastguard Worker // We also don't persist the log to the prefs for transmission during the next
66*6777b538SAndroid Build Coastguard Worker // chrome session if this limit is exceeded.
67*6777b538SAndroid Build Coastguard Worker const base::FeatureParam<int> kMaxInitialLogSizeBytes{
68*6777b538SAndroid Build Coastguard Worker     &features::kMetricsLogTrimming, "max_initial_log_size_bytes",
69*6777b538SAndroid Build Coastguard Worker     0  // Initial logs can be of any size.
70*6777b538SAndroid Build Coastguard Worker };
71*6777b538SAndroid Build Coastguard Worker const base::FeatureParam<int> kMaxOngoingLogSizeBytes{
72*6777b538SAndroid Build Coastguard Worker     &features::kMetricsLogTrimming, "max_ongoing_log_size_bytes",
73*6777b538SAndroid Build Coastguard Worker #if BUILDFLAG(IS_CHROMEOS)
74*6777b538SAndroid Build Coastguard Worker     // Increase CrOS limit to accommodate SampledProfile data (crbug/1210595).
75*6777b538SAndroid Build Coastguard Worker     1024 * 1024  // 1 MiB
76*6777b538SAndroid Build Coastguard Worker #else
77*6777b538SAndroid Build Coastguard Worker     100 * 1024  // 100 KiB
78*6777b538SAndroid Build Coastguard Worker #endif  // BUILDFLAG(IS_CHROMEOS)
79*6777b538SAndroid Build Coastguard Worker };
80*6777b538SAndroid Build Coastguard Worker 
81*6777b538SAndroid Build Coastguard Worker // The minimum time in seconds between consecutive metrics report uploads.
82*6777b538SAndroid Build Coastguard Worker constexpr int kMetricsUploadIntervalSecMinimum = 20;
83*6777b538SAndroid Build Coastguard Worker 
84*6777b538SAndroid Build Coastguard Worker }  // namespace
85*6777b538SAndroid Build Coastguard Worker 
86*6777b538SAndroid Build Coastguard Worker MetricsServiceClient::MetricsServiceClient() = default;
87*6777b538SAndroid Build Coastguard Worker 
88*6777b538SAndroid Build Coastguard Worker MetricsServiceClient::~MetricsServiceClient() = default;
89*6777b538SAndroid Build Coastguard Worker 
GetUkmService()90*6777b538SAndroid Build Coastguard Worker ukm::UkmService* MetricsServiceClient::GetUkmService() {
91*6777b538SAndroid Build Coastguard Worker   return nullptr;
92*6777b538SAndroid Build Coastguard Worker }
93*6777b538SAndroid Build Coastguard Worker 
94*6777b538SAndroid Build Coastguard Worker IdentifiabilityStudyState*
GetIdentifiabilityStudyState()95*6777b538SAndroid Build Coastguard Worker MetricsServiceClient::GetIdentifiabilityStudyState() {
96*6777b538SAndroid Build Coastguard Worker   return nullptr;
97*6777b538SAndroid Build Coastguard Worker }
98*6777b538SAndroid Build Coastguard Worker 
99*6777b538SAndroid Build Coastguard Worker structured::StructuredMetricsService*
GetStructuredMetricsService()100*6777b538SAndroid Build Coastguard Worker MetricsServiceClient::GetStructuredMetricsService() {
101*6777b538SAndroid Build Coastguard Worker   return nullptr;
102*6777b538SAndroid Build Coastguard Worker }
103*6777b538SAndroid Build Coastguard Worker 
ShouldUploadMetricsForUserId(uint64_t user_id)104*6777b538SAndroid Build Coastguard Worker bool MetricsServiceClient::ShouldUploadMetricsForUserId(uint64_t user_id) {
105*6777b538SAndroid Build Coastguard Worker   return true;
106*6777b538SAndroid Build Coastguard Worker }
107*6777b538SAndroid Build Coastguard Worker 
GetMetricsServerUrl()108*6777b538SAndroid Build Coastguard Worker GURL MetricsServiceClient::GetMetricsServerUrl() {
109*6777b538SAndroid Build Coastguard Worker   base::CommandLine* command_line = base::CommandLine::ForCurrentProcess();
110*6777b538SAndroid Build Coastguard Worker   if (command_line->HasSwitch(switches::kUmaServerUrl)) {
111*6777b538SAndroid Build Coastguard Worker     return GURL(command_line->GetSwitchValueASCII(switches::kUmaServerUrl));
112*6777b538SAndroid Build Coastguard Worker   }
113*6777b538SAndroid Build Coastguard Worker   return GURL(kNewMetricsServerUrl);
114*6777b538SAndroid Build Coastguard Worker }
115*6777b538SAndroid Build Coastguard Worker 
GetInsecureMetricsServerUrl()116*6777b538SAndroid Build Coastguard Worker GURL MetricsServiceClient::GetInsecureMetricsServerUrl() {
117*6777b538SAndroid Build Coastguard Worker   base::CommandLine* command_line = base::CommandLine::ForCurrentProcess();
118*6777b538SAndroid Build Coastguard Worker   if (command_line->HasSwitch(switches::kUmaInsecureServerUrl)) {
119*6777b538SAndroid Build Coastguard Worker     return GURL(
120*6777b538SAndroid Build Coastguard Worker         command_line->GetSwitchValueASCII(switches::kUmaInsecureServerUrl));
121*6777b538SAndroid Build Coastguard Worker   }
122*6777b538SAndroid Build Coastguard Worker   return GURL(kNewMetricsServerUrlInsecure);
123*6777b538SAndroid Build Coastguard Worker }
124*6777b538SAndroid Build Coastguard Worker 
GetUploadInterval()125*6777b538SAndroid Build Coastguard Worker base::TimeDelta MetricsServiceClient::GetUploadInterval() {
126*6777b538SAndroid Build Coastguard Worker   const base::CommandLine* command_line =
127*6777b538SAndroid Build Coastguard Worker       base::CommandLine::ForCurrentProcess();
128*6777b538SAndroid Build Coastguard Worker   // If an upload interval is set from the command line, use that value but
129*6777b538SAndroid Build Coastguard Worker   // subject it to a minimum threshold to mitigate the risk of DDoS attack.
130*6777b538SAndroid Build Coastguard Worker   if (command_line->HasSwitch(metrics::switches::kMetricsUploadIntervalSec)) {
131*6777b538SAndroid Build Coastguard Worker     const std::string switch_value = command_line->GetSwitchValueASCII(
132*6777b538SAndroid Build Coastguard Worker         metrics::switches::kMetricsUploadIntervalSec);
133*6777b538SAndroid Build Coastguard Worker     int custom_upload_interval;
134*6777b538SAndroid Build Coastguard Worker     if (base::StringToInt(switch_value, &custom_upload_interval)) {
135*6777b538SAndroid Build Coastguard Worker       return base::Seconds(
136*6777b538SAndroid Build Coastguard Worker           std::max(custom_upload_interval, kMetricsUploadIntervalSecMinimum));
137*6777b538SAndroid Build Coastguard Worker     }
138*6777b538SAndroid Build Coastguard Worker     LOG(DFATAL) << "Malformed value for --metrics-upload-interval. "
139*6777b538SAndroid Build Coastguard Worker                 << "Expected int, got: " << switch_value;
140*6777b538SAndroid Build Coastguard Worker   }
141*6777b538SAndroid Build Coastguard Worker   return GetStandardUploadInterval();
142*6777b538SAndroid Build Coastguard Worker }
143*6777b538SAndroid Build Coastguard Worker 
ShouldStartUpFastForTesting() const144*6777b538SAndroid Build Coastguard Worker bool MetricsServiceClient::ShouldStartUpFastForTesting() const {
145*6777b538SAndroid Build Coastguard Worker   return false;
146*6777b538SAndroid Build Coastguard Worker }
147*6777b538SAndroid Build Coastguard Worker 
IsReportingPolicyManaged()148*6777b538SAndroid Build Coastguard Worker bool MetricsServiceClient::IsReportingPolicyManaged() {
149*6777b538SAndroid Build Coastguard Worker   return false;
150*6777b538SAndroid Build Coastguard Worker }
151*6777b538SAndroid Build Coastguard Worker 
GetMetricsReportingDefaultState()152*6777b538SAndroid Build Coastguard Worker EnableMetricsDefault MetricsServiceClient::GetMetricsReportingDefaultState() {
153*6777b538SAndroid Build Coastguard Worker   return EnableMetricsDefault::DEFAULT_UNKNOWN;
154*6777b538SAndroid Build Coastguard Worker }
155*6777b538SAndroid Build Coastguard Worker 
IsOnCellularConnection()156*6777b538SAndroid Build Coastguard Worker bool MetricsServiceClient::IsOnCellularConnection() {
157*6777b538SAndroid Build Coastguard Worker   return false;
158*6777b538SAndroid Build Coastguard Worker }
159*6777b538SAndroid Build Coastguard Worker 
IsUkmAllowedForAllProfiles()160*6777b538SAndroid Build Coastguard Worker bool MetricsServiceClient::IsUkmAllowedForAllProfiles() {
161*6777b538SAndroid Build Coastguard Worker   return false;
162*6777b538SAndroid Build Coastguard Worker }
163*6777b538SAndroid Build Coastguard Worker 
AreNotificationListenersEnabledOnAllProfiles()164*6777b538SAndroid Build Coastguard Worker bool MetricsServiceClient::AreNotificationListenersEnabledOnAllProfiles() {
165*6777b538SAndroid Build Coastguard Worker   return false;
166*6777b538SAndroid Build Coastguard Worker }
167*6777b538SAndroid Build Coastguard Worker 
GetAppPackageNameIfLoggable()168*6777b538SAndroid Build Coastguard Worker std::string MetricsServiceClient::GetAppPackageNameIfLoggable() {
169*6777b538SAndroid Build Coastguard Worker   return std::string();
170*6777b538SAndroid Build Coastguard Worker }
171*6777b538SAndroid Build Coastguard Worker 
GetUploadSigningKey()172*6777b538SAndroid Build Coastguard Worker std::string MetricsServiceClient::GetUploadSigningKey() {
173*6777b538SAndroid Build Coastguard Worker   return std::string();
174*6777b538SAndroid Build Coastguard Worker }
175*6777b538SAndroid Build Coastguard Worker 
ShouldResetClientIdsOnClonedInstall()176*6777b538SAndroid Build Coastguard Worker bool MetricsServiceClient::ShouldResetClientIdsOnClonedInstall() {
177*6777b538SAndroid Build Coastguard Worker   return false;
178*6777b538SAndroid Build Coastguard Worker }
179*6777b538SAndroid Build Coastguard Worker 
180*6777b538SAndroid Build Coastguard Worker base::CallbackListSubscription
AddOnClonedInstallDetectedCallback(base::OnceClosure callback)181*6777b538SAndroid Build Coastguard Worker MetricsServiceClient::AddOnClonedInstallDetectedCallback(
182*6777b538SAndroid Build Coastguard Worker     base::OnceClosure callback) {
183*6777b538SAndroid Build Coastguard Worker   return base::CallbackListSubscription();
184*6777b538SAndroid Build Coastguard Worker }
185*6777b538SAndroid Build Coastguard Worker 
GetStorageLimits() const186*6777b538SAndroid Build Coastguard Worker MetricsLogStore::StorageLimits MetricsServiceClient::GetStorageLimits() const {
187*6777b538SAndroid Build Coastguard Worker   return {
188*6777b538SAndroid Build Coastguard Worker       .initial_log_queue_limits =
189*6777b538SAndroid Build Coastguard Worker           UnsentLogStore::UnsentLogStoreLimits{
190*6777b538SAndroid Build Coastguard Worker               .min_log_count =
191*6777b538SAndroid Build Coastguard Worker                   static_cast<size_t>(kInitialLogCountTrimThreshold.Get()),
192*6777b538SAndroid Build Coastguard Worker               .min_queue_size_bytes =
193*6777b538SAndroid Build Coastguard Worker                   static_cast<size_t>(kLogBytesTrimThreshold.Get()),
194*6777b538SAndroid Build Coastguard Worker               .max_log_size_bytes =
195*6777b538SAndroid Build Coastguard Worker                   static_cast<size_t>(kMaxInitialLogSizeBytes.Get()),
196*6777b538SAndroid Build Coastguard Worker           },
197*6777b538SAndroid Build Coastguard Worker       .ongoing_log_queue_limits =
198*6777b538SAndroid Build Coastguard Worker           UnsentLogStore::UnsentLogStoreLimits{
199*6777b538SAndroid Build Coastguard Worker               .min_log_count =
200*6777b538SAndroid Build Coastguard Worker                   static_cast<size_t>(kOngoingLogCountTrimThreshold.Get()),
201*6777b538SAndroid Build Coastguard Worker               .min_queue_size_bytes =
202*6777b538SAndroid Build Coastguard Worker                   static_cast<size_t>(kLogBytesTrimThreshold.Get()),
203*6777b538SAndroid Build Coastguard Worker               .max_log_size_bytes =
204*6777b538SAndroid Build Coastguard Worker                   static_cast<size_t>(kMaxOngoingLogSizeBytes.Get()),
205*6777b538SAndroid Build Coastguard Worker           },
206*6777b538SAndroid Build Coastguard Worker   };
207*6777b538SAndroid Build Coastguard Worker }
208*6777b538SAndroid Build Coastguard Worker 
SetUpdateRunningServicesCallback(const base::RepeatingClosure & callback)209*6777b538SAndroid Build Coastguard Worker void MetricsServiceClient::SetUpdateRunningServicesCallback(
210*6777b538SAndroid Build Coastguard Worker     const base::RepeatingClosure& callback) {
211*6777b538SAndroid Build Coastguard Worker   update_running_services_ = callback;
212*6777b538SAndroid Build Coastguard Worker }
213*6777b538SAndroid Build Coastguard Worker 
UpdateRunningServices()214*6777b538SAndroid Build Coastguard Worker void MetricsServiceClient::UpdateRunningServices() {
215*6777b538SAndroid Build Coastguard Worker   if (update_running_services_) {
216*6777b538SAndroid Build Coastguard Worker     update_running_services_.Run();
217*6777b538SAndroid Build Coastguard Worker   }
218*6777b538SAndroid Build Coastguard Worker }
219*6777b538SAndroid Build Coastguard Worker 
IsMetricsReportingForceEnabled() const220*6777b538SAndroid Build Coastguard Worker bool MetricsServiceClient::IsMetricsReportingForceEnabled() const {
221*6777b538SAndroid Build Coastguard Worker   return ::metrics::IsMetricsReportingForceEnabled();
222*6777b538SAndroid Build Coastguard Worker }
223*6777b538SAndroid Build Coastguard Worker 
GetCurrentUserMetricsConsent() const224*6777b538SAndroid Build Coastguard Worker std::optional<bool> MetricsServiceClient::GetCurrentUserMetricsConsent() const {
225*6777b538SAndroid Build Coastguard Worker   return std::nullopt;
226*6777b538SAndroid Build Coastguard Worker }
227*6777b538SAndroid Build Coastguard Worker 
GetCurrentUserId() const228*6777b538SAndroid Build Coastguard Worker std::optional<std::string> MetricsServiceClient::GetCurrentUserId() const {
229*6777b538SAndroid Build Coastguard Worker   return std::nullopt;
230*6777b538SAndroid Build Coastguard Worker }
231*6777b538SAndroid Build Coastguard Worker 
232*6777b538SAndroid Build Coastguard Worker }  // namespace metrics
233