blob: 5680dec0618cb4ffe187d2f336ff078ff150693a [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[];
May Lippert60aa3ca2018-08-15 16:55:29 -070072extern const char kMetricSuccessfulUpdateDurationFromSeenDays[];
73extern const char kMetricSuccessfulUpdateDurationFromSeenTimeRestrictedDays[];
Tianjie Xu98333a82017-09-22 21:29:29 -070074extern const char kMetricSuccessfulUpdatePayloadType[];
75extern const char kMetricSuccessfulUpdatePayloadSizeMiB[];
76extern const char kMetricSuccessfulUpdateRebootCount[];
77extern const char kMetricSuccessfulUpdateTotalDurationMinutes[];
Sen Jiang8712e962018-05-08 12:12:28 -070078extern const char kMetricSuccessfulUpdateTotalDurationUptimeMinutes[];
Tianjie Xu98333a82017-09-22 21:29:29 -070079extern const char kMetricSuccessfulUpdateUpdatesAbandonedCount[];
80extern const char kMetricSuccessfulUpdateUrlSwitchCount[];
81
82// UpdateEngine.Rollback.* metric.
83extern const char kMetricRollbackResult[];
84
Marton Hunyadya0302682018-05-16 18:52:13 +020085// UpdateEngine.EnterpriseRollback.* metrics.
86extern const char kMetricEnterpriseRollbackFailure[];
87extern const char kMetricEnterpriseRollbackSuccess[];
88
Tianjie Xu98333a82017-09-22 21:29:29 -070089// UpdateEngine.CertificateCheck.* metrics.
90extern const char kMetricCertificateCheckUpdateCheck[];
91extern const char kMetricCertificateCheckDownload[];
92
Marton Hunyadyffbfdfb2018-05-30 13:03:29 +020093// UpdateEngine.KernelKey.* metrics.
94extern const char kMetricKernelMinVersion[];
95extern const char kMetricKernelMaxRollforwardVersion[];
96extern const char kMetricKernelMaxRollforwardSetSuccess[];
97
Tianjie Xu98333a82017-09-22 21:29:29 -070098// UpdateEngine.* metrics.
99extern const char kMetricFailedUpdateCount[];
100extern const char kMetricInstallDateProvisioningSource[];
101extern const char kMetricTimeToRebootMinutes[];
102
103} // namespace metrics
104
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700105class MetricsReporterOmaha : public MetricsReporterInterface {
106 public:
Tianjie Xu98333a82017-09-22 21:29:29 -0700107 MetricsReporterOmaha();
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700108
109 ~MetricsReporterOmaha() override = default;
110
111 void Initialize() override;
112
113 void ReportRollbackMetrics(metrics::RollbackResult result) override;
114
Marton Hunyadya0302682018-05-16 18:52:13 +0200115 void ReportEnterpriseRollbackMetrics(
116 bool success, const std::string& rollback_version) override;
117
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700118 void ReportDailyMetrics(base::TimeDelta os_age) override;
119
120 void ReportUpdateCheckMetrics(
121 SystemState* system_state,
122 metrics::CheckResult result,
123 metrics::CheckReaction reaction,
124 metrics::DownloadErrorCode download_error_code) override;
125
Tianjie Xu1f93d092017-10-09 12:13:29 -0700126 void ReportUpdateAttemptMetrics(SystemState* system_state,
127 int attempt_number,
128 PayloadType payload_type,
129 base::TimeDelta duration,
130 base::TimeDelta duration_uptime,
131 int64_t payload_size,
132 metrics::AttemptResult attempt_result,
133 ErrorCode internal_error_code) override;
134
135 void ReportUpdateAttemptDownloadMetrics(
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700136 int64_t payload_bytes_downloaded,
137 int64_t payload_download_speed_bps,
138 DownloadSource download_source,
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700139 metrics::DownloadErrorCode payload_download_error_code,
140 metrics::ConnectionType connection_type) override;
141
142 void ReportAbnormallyTerminatedUpdateAttemptMetrics() override;
143
144 void ReportSuccessfulUpdateMetrics(
145 int attempt_count,
146 int updates_abandoned_count,
147 PayloadType payload_type,
148 int64_t payload_size,
149 int64_t num_bytes_downloaded[kNumDownloadSources],
150 int download_overhead_percentage,
151 base::TimeDelta total_duration,
Sen Jiang8712e962018-05-08 12:12:28 -0700152 base::TimeDelta total_duration_uptime,
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700153 int reboot_count,
154 int url_switch_count) override;
155
156 void ReportCertificateCheckMetrics(ServerToCheck server_to_check,
157 CertificateCheckResult result) override;
158
159 void ReportFailedUpdateCount(int target_attempt) override;
160
161 void ReportTimeToReboot(int time_to_reboot_minutes) override;
162
163 void ReportInstallDateProvisioningSource(int source, int max) override;
164
Amin Hassani80f4d4c2018-05-16 13:34:00 -0700165 void ReportInternalErrorCode(ErrorCode error_code) override;
166
Marton Hunyadyffbfdfb2018-05-30 13:03:29 +0200167 void ReportKeyVersionMetrics(int kernel_min_version,
168 int kernel_max_rollforward_version,
169 bool kernel_max_rollforward_success) override;
170
May Lippert60aa3ca2018-08-15 16:55:29 -0700171 void ReportEnterpriseUpdateSeenToDownloadDays(
172 bool has_time_restriction_policy, int time_to_update_days) override;
173
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700174 private:
Tianjie Xu98333a82017-09-22 21:29:29 -0700175 friend class MetricsReporterOmahaTest;
176
177 std::unique_ptr<MetricsLibraryInterface> metrics_lib_;
Tianjie Xu282aa1f2017-09-05 13:42:45 -0700178
179 DISALLOW_COPY_AND_ASSIGN(MetricsReporterOmaha);
180}; // class metrics
181
182} // namespace chromeos_update_engine
183
184#endif // UPDATE_ENGINE_METRICS_REPORTER_OMAHA_H_