blob: 10aef865b7059761fe14b14ef4e790165e70626f [file] [log] [blame]
Tianjie Xu282aa1f2017-09-05 13:42:45 -07001//
2// Copyright (C) 2017 The Android Open Source Project
3//
4// Licensed under the Apache License, Version 2.0 (the "License");
5// you may not use this file except in compliance with the License.
6// You may obtain a copy of the License at
7//
8// http://www.apache.org/licenses/LICENSE-2.0
9//
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13// See the License for the specific language governing permissions and
14// limitations under the License.
15//
16
17#ifndef UPDATE_ENGINE_METRICS_REPORTER_OMAHA_H_
18#define UPDATE_ENGINE_METRICS_REPORTER_OMAHA_H_
19
Tianjie Xu98333a82017-09-22 21:29:29 -070020#include <memory>
Marton Hunyadya0302682018-05-16 18:52:13 +020021#include <string>
Tianjie Xu98333a82017-09-22 21:29:29 -070022
Tianjie Xu282aa1f2017-09-05 13:42:45 -070023#include <base/time/time.h>
24#include <metrics/metrics_library.h>
25
26#include "update_engine/certificate_checker.h"
27#include "update_engine/common/constants.h"
28#include "update_engine/common/error_code.h"
29#include "update_engine/metrics_constants.h"
30#include "update_engine/metrics_reporter_interface.h"
31#include "update_engine/system_state.h"
32
33namespace chromeos_update_engine {
34
35class SystemState;
36
Tianjie Xu98333a82017-09-22 21:29:29 -070037namespace metrics {
38
39// UpdateEngine.Daily.* metrics.
40extern const char kMetricDailyOSAgeDays[];
41
42// UpdateEngine.Check.* metrics.
43extern const char kMetricCheckDownloadErrorCode[];
44extern const char kMetricCheckReaction[];
45extern const char kMetricCheckResult[];
Marton Hunyadya0302682018-05-16 18:52:13 +020046extern const char kMetricCheckTargetVersion[];
47extern const char kMetricCheckRollbackTargetVersion[];
Tianjie Xu98333a82017-09-22 21:29:29 -070048extern const char kMetricCheckTimeSinceLastCheckMinutes[];
49extern const char kMetricCheckTimeSinceLastCheckUptimeMinutes[];
50
51// UpdateEngine.Attempt.* metrics.
52extern const char kMetricAttemptNumber[];
53extern const char kMetricAttemptPayloadType[];
54extern const char kMetricAttemptPayloadSizeMiB[];
55extern const char kMetricAttemptConnectionType[];
56extern const char kMetricAttemptDurationMinutes[];
57extern const char kMetricAttemptDurationUptimeMinutes[];
58extern const char kMetricAttemptTimeSinceLastAttemptMinutes[];
59extern const char kMetricAttemptTimeSinceLastAttemptUptimeMinutes[];
60extern const char kMetricAttemptPayloadBytesDownloadedMiB[];
61extern const char kMetricAttemptPayloadDownloadSpeedKBps[];
62extern const char kMetricAttemptDownloadSource[];
63extern const char kMetricAttemptResult[];
64extern const char kMetricAttemptInternalErrorCode[];
65extern const char kMetricAttemptDownloadErrorCode[];
66
67// UpdateEngine.SuccessfulUpdate.* metrics.
68extern const char kMetricSuccessfulUpdateAttemptCount[];
69extern const char kMetricSuccessfulUpdateBytesDownloadedMiB[];
70extern const char kMetricSuccessfulUpdateDownloadOverheadPercentage[];
71extern const char kMetricSuccessfulUpdateDownloadSourcesUsed[];
72extern const char kMetricSuccessfulUpdatePayloadType[];
73extern const char kMetricSuccessfulUpdatePayloadSizeMiB[];
74extern const char kMetricSuccessfulUpdateRebootCount[];
75extern const char kMetricSuccessfulUpdateTotalDurationMinutes[];
Sen Jiang8712e962018-05-08 12:12:28 -070076extern const char kMetricSuccessfulUpdateTotalDurationUptimeMinutes[];
Tianjie Xu98333a82017-09-22 21:29:29 -070077extern const char kMetricSuccessfulUpdateUpdatesAbandonedCount[];
78extern const char kMetricSuccessfulUpdateUrlSwitchCount[];
79
80// UpdateEngine.Rollback.* metric.
81extern const char kMetricRollbackResult[];
82
Marton Hunyadya0302682018-05-16 18:52:13 +020083// UpdateEngine.EnterpriseRollback.* metrics.
84extern const char kMetricEnterpriseRollbackFailure[];
85extern const char kMetricEnterpriseRollbackSuccess[];
86
Tianjie Xu98333a82017-09-22 21:29:29 -070087// UpdateEngine.CertificateCheck.* metrics.
88extern const char kMetricCertificateCheckUpdateCheck[];
89extern const char kMetricCertificateCheckDownload[];
90
Marton Hunyadyffbfdfb2018-05-30 13:03:29 +020091// UpdateEngine.KernelKey.* metrics.
92extern const char kMetricKernelMinVersion[];
93extern const char kMetricKernelMaxRollforwardVersion[];
94extern const char kMetricKernelMaxRollforwardSetSuccess[];
95
Tianjie Xu98333a82017-09-22 21:29:29 -070096// UpdateEngine.* metrics.
97extern const char kMetricFailedUpdateCount[];
98extern const char kMetricInstallDateProvisioningSource[];
99extern const char kMetricTimeToRebootMinutes[];
100
101} // namespace metrics
102
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700103class MetricsReporterOmaha : public MetricsReporterInterface {
104 public:
Tianjie Xu98333a82017-09-22 21:29:29 -0700105 MetricsReporterOmaha();
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700106
107 ~MetricsReporterOmaha() override = default;
108
109 void Initialize() override;
110
111 void ReportRollbackMetrics(metrics::RollbackResult result) override;
112
Marton Hunyadya0302682018-05-16 18:52:13 +0200113 void ReportEnterpriseRollbackMetrics(
114 bool success, const std::string& rollback_version) override;
115
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700116 void ReportDailyMetrics(base::TimeDelta os_age) override;
117
118 void ReportUpdateCheckMetrics(
119 SystemState* system_state,
120 metrics::CheckResult result,
121 metrics::CheckReaction reaction,
122 metrics::DownloadErrorCode download_error_code) override;
123
Tianjie Xu1f93d092017-10-09 12:13:29 -0700124 void ReportUpdateAttemptMetrics(SystemState* system_state,
125 int attempt_number,
126 PayloadType payload_type,
127 base::TimeDelta duration,
128 base::TimeDelta duration_uptime,
129 int64_t payload_size,
130 metrics::AttemptResult attempt_result,
131 ErrorCode internal_error_code) override;
132
133 void ReportUpdateAttemptDownloadMetrics(
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700134 int64_t payload_bytes_downloaded,
135 int64_t payload_download_speed_bps,
136 DownloadSource download_source,
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700137 metrics::DownloadErrorCode payload_download_error_code,
138 metrics::ConnectionType connection_type) override;
139
140 void ReportAbnormallyTerminatedUpdateAttemptMetrics() override;
141
142 void ReportSuccessfulUpdateMetrics(
143 int attempt_count,
144 int updates_abandoned_count,
145 PayloadType payload_type,
146 int64_t payload_size,
147 int64_t num_bytes_downloaded[kNumDownloadSources],
148 int download_overhead_percentage,
149 base::TimeDelta total_duration,
Sen Jiang8712e962018-05-08 12:12:28 -0700150 base::TimeDelta total_duration_uptime,
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700151 int reboot_count,
152 int url_switch_count) override;
153
154 void ReportCertificateCheckMetrics(ServerToCheck server_to_check,
155 CertificateCheckResult result) override;
156
157 void ReportFailedUpdateCount(int target_attempt) override;
158
159 void ReportTimeToReboot(int time_to_reboot_minutes) override;
160
161 void ReportInstallDateProvisioningSource(int source, int max) override;
162
Amin Hassani80f4d4c2018-05-16 13:34:00 -0700163 void ReportInternalErrorCode(ErrorCode error_code) override;
164
Marton Hunyadyffbfdfb2018-05-30 13:03:29 +0200165 void ReportKeyVersionMetrics(int kernel_min_version,
166 int kernel_max_rollforward_version,
167 bool kernel_max_rollforward_success) override;
168
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700169 private:
Tianjie Xu98333a82017-09-22 21:29:29 -0700170 friend class MetricsReporterOmahaTest;
171
172 std::unique_ptr<MetricsLibraryInterface> metrics_lib_;
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700173
174 DISALLOW_COPY_AND_ASSIGN(MetricsReporterOmaha);
175}; // class metrics
176
177} // namespace chromeos_update_engine
178
179#endif // UPDATE_ENGINE_METRICS_REPORTER_OMAHA_H_