blob: 99aa14edb27b859fa136e68664fa4e146ed1f795 [file] [log] [blame]
Alex Deymo5e3ea272016-01-28 13:42:23 -08001//
2// Copyright (C) 2016 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_UPDATE_ATTEMPTER_ANDROID_H_
18#define UPDATE_ENGINE_UPDATE_ATTEMPTER_ANDROID_H_
19
20#include <stdint.h>
21
22#include <memory>
23#include <string>
24#include <vector>
25
26#include <base/time/time.h>
27
28#include "update_engine/client_library/include/update_engine/update_status.h"
29#include "update_engine/common/action_processor.h"
30#include "update_engine/common/boot_control_interface.h"
Tianjie Xu90aaa102017-10-10 17:39:03 -070031#include "update_engine/common/clock.h"
Alex Deymo5e3ea272016-01-28 13:42:23 -080032#include "update_engine/common/hardware_interface.h"
33#include "update_engine/common/prefs_interface.h"
Alex Deymo03a4de72016-07-20 16:08:23 -070034#include "update_engine/daemon_state_interface.h"
Tianjie Xu1b661142017-09-28 14:03:42 -070035#include "update_engine/metrics_reporter_interface.h"
Tianjie Xu90aaa102017-10-10 17:39:03 -070036#include "update_engine/metrics_utils.h"
Alex Deymo87792ea2016-07-25 15:40:36 -070037#include "update_engine/network_selector_interface.h"
Alex Deymo5e3ea272016-01-28 13:42:23 -080038#include "update_engine/payload_consumer/download_action.h"
Alex Deymo0d298542016-03-30 18:31:49 -070039#include "update_engine/payload_consumer/postinstall_runner_action.h"
Alex Deymo5e3ea272016-01-28 13:42:23 -080040#include "update_engine/service_delegate_android_interface.h"
41#include "update_engine/service_observer_interface.h"
42
43namespace chromeos_update_engine {
44
Alex Deymo0d298542016-03-30 18:31:49 -070045class UpdateAttempterAndroid
46 : public ServiceDelegateAndroidInterface,
47 public ActionProcessorDelegate,
48 public DownloadActionDelegate,
49 public PostinstallRunnerAction::DelegateInterface {
Alex Deymo5e3ea272016-01-28 13:42:23 -080050 public:
51 using UpdateStatus = update_engine::UpdateStatus;
52
Alex Deymo03a4de72016-07-20 16:08:23 -070053 UpdateAttempterAndroid(DaemonStateInterface* daemon_state,
Alex Deymo5e3ea272016-01-28 13:42:23 -080054 PrefsInterface* prefs,
55 BootControlInterface* boot_control_,
56 HardwareInterface* hardware_);
57 ~UpdateAttempterAndroid() override;
58
59 // Further initialization to be done post construction.
60 void Init();
61
62 // ServiceDelegateAndroidInterface overrides.
63 bool ApplyPayload(const std::string& payload_url,
64 int64_t payload_offset,
65 int64_t payload_size,
66 const std::vector<std::string>& key_value_pair_headers,
67 brillo::ErrorPtr* error) override;
68 bool SuspendUpdate(brillo::ErrorPtr* error) override;
69 bool ResumeUpdate(brillo::ErrorPtr* error) override;
70 bool CancelUpdate(brillo::ErrorPtr* error) override;
Alex Deymo3b678db2016-02-09 11:50:06 -080071 bool ResetStatus(brillo::ErrorPtr* error) override;
Sen Jiang28d8ed92018-02-01 13:46:39 -080072 bool VerifyPayloadApplicable(const std::string& metadata_filename,
73 brillo::ErrorPtr* error) override;
Alex Deymo5e3ea272016-01-28 13:42:23 -080074
75 // ActionProcessorDelegate methods:
76 void ProcessingDone(const ActionProcessor* processor,
77 ErrorCode code) override;
78 void ProcessingStopped(const ActionProcessor* processor) override;
79 void ActionCompleted(ActionProcessor* processor,
80 AbstractAction* action,
81 ErrorCode code) override;
82
83 // DownloadActionDelegate overrides.
84 void BytesReceived(uint64_t bytes_progressed,
85 uint64_t bytes_received,
86 uint64_t total) override;
87 bool ShouldCancel(ErrorCode* cancel_reason) override;
88 void DownloadComplete() override;
89
Alex Deymo0d298542016-03-30 18:31:49 -070090 // PostinstallRunnerAction::DelegateInterface
91 void ProgressUpdate(double progress) override;
92
Alex Deymo5e3ea272016-01-28 13:42:23 -080093 private:
Tianjie Xu90aaa102017-10-10 17:39:03 -070094 friend class UpdateAttempterAndroidTest;
95
Alex Deymo5e3ea272016-01-28 13:42:23 -080096 // Asynchronously marks the current slot as successful if needed. If already
97 // marked as good, CompleteUpdateBootFlags() is called starting the action
98 // processor.
99 void UpdateBootFlags();
100
101 // Called when the boot flags have been updated.
102 void CompleteUpdateBootFlags(bool success);
103
104 // Schedules an event loop callback to start the action processor. This is
105 // scheduled asynchronously to unblock the event loop.
106 void ScheduleProcessingStart();
107
108 // Notifies an update request completed with the given error |code| to all
109 // observers.
110 void TerminateUpdateAndNotify(ErrorCode error_code);
111
112 // Sets the status to the given |status| and notifies a status update to
113 // all observers.
114 void SetStatusAndNotify(UpdateStatus status);
115
116 // Helper method to construct the sequence of actions to be performed for
Amin Hassani667cf7b2018-07-25 14:32:00 -0700117 // applying an update using a given HttpFetcher. The ownership of |fetcher| is
118 // passed to this function.
119 void BuildUpdateActions(HttpFetcher* fetcher);
Alex Deymo5e3ea272016-01-28 13:42:23 -0800120
Alex Deymo5e3ea272016-01-28 13:42:23 -0800121 // Writes to the processing completed marker. Does nothing if
122 // |update_completed_marker_| is empty.
123 bool WriteUpdateCompletedMarker();
124
125 // Returns whether an update was completed in the current boot.
126 bool UpdateCompletedOnThisBoot();
127
Tianjie Xu90aaa102017-10-10 17:39:03 -0700128 // Prefs to use for metrics report
129 // |kPrefsPayloadAttemptNumber|: number of update attempts for the current
130 // payload_id.
131 // |KprefsNumReboots|: number of reboots when applying the current update.
132 // |kPrefsSystemUpdatedMarker|: end timestamp of the last successful update.
133 // |kPrefsUpdateTimestampStart|: start timestamp of the current update.
Tianjie Xud4777a12017-10-24 14:54:18 -0700134 // |kPrefsCurrentBytesDownloaded|: number of bytes downloaded for the current
135 // payload_id.
136 // |kPrefsTotalBytesDownloaded|: number of bytes downloaded in total since
137 // the last successful update.
Tianjie Xu90aaa102017-10-10 17:39:03 -0700138
139 // Metrics report function to call:
140 // |ReportUpdateAttemptMetrics|
141 // |ReportSuccessfulUpdateMetrics|
142 // Prefs to update:
143 // |kPrefsSystemUpdatedMarker|
144 void CollectAndReportUpdateMetricsOnUpdateFinished(ErrorCode error_code);
145
146 // Metrics report function to call:
147 // |ReportAbnormallyTerminatedUpdateAttemptMetrics|
148 // |ReportTimeToRebootMetrics|
149 // Prefs to update:
150 // |kPrefsBootId|, |kPrefsPreviousVersion|
151 void UpdatePrefsAndReportUpdateMetricsOnReboot();
152
153 // Prefs to update:
154 // |kPrefsPayloadAttemptNumber|, |kPrefsUpdateTimestampStart|
155 void UpdatePrefsOnUpdateStart(bool is_resume);
156
157 // Prefs to delete:
158 // |kPrefsNumReboots|, |kPrefsPayloadAttemptNumber|,
Tianjie Xud4777a12017-10-24 14:54:18 -0700159 // |kPrefsSystemUpdatedMarker|, |kPrefsUpdateTimestampStart|,
160 // |kPrefsCurrentBytesDownloaded|
Tianjie Xu90aaa102017-10-10 17:39:03 -0700161 void ClearMetricsPrefs();
162
Alex Deymo03a4de72016-07-20 16:08:23 -0700163 DaemonStateInterface* daemon_state_;
Alex Deymo5e3ea272016-01-28 13:42:23 -0800164
165 // DaemonStateAndroid pointers.
166 PrefsInterface* prefs_;
167 BootControlInterface* boot_control_;
168 HardwareInterface* hardware_;
169
170 // Last status notification timestamp used for throttling. Use monotonic
171 // TimeTicks to ensure that notifications are sent even if the system clock is
172 // set back in the middle of an update.
173 base::TimeTicks last_notify_time_;
174
Amin Hassani04d41622018-12-20 15:35:41 -0800175 // Only direct proxy supported.
176 DirectProxyResolver proxy_resolver_;
177
Amin Hassani667cf7b2018-07-25 14:32:00 -0700178 // The processor for running Actions.
Alex Deymo5e3ea272016-01-28 13:42:23 -0800179 std::unique_ptr<ActionProcessor> processor_;
180
Alex Deymo5e3ea272016-01-28 13:42:23 -0800181 // Whether there is an ongoing update. This implies that an update was started
182 // but not finished yet. This value will be true even if the update was
183 // suspended.
184 bool ongoing_update_{false};
185
186 // The InstallPlan used during the ongoing update.
187 InstallPlan install_plan_;
188
189 // For status:
190 UpdateStatus status_{UpdateStatus::IDLE};
191 double download_progress_{0.0};
192
Alex Deymo0fd51ff2016-02-03 14:22:43 -0800193 // The offset in the payload file where the CrAU part starts.
194 int64_t base_offset_{0};
195
Alex Deymo87792ea2016-07-25 15:40:36 -0700196 // Helper class to select the network to use during the update.
197 std::unique_ptr<NetworkSelectorInterface> network_selector_;
198
Tianjie Xu90aaa102017-10-10 17:39:03 -0700199 std::unique_ptr<ClockInterface> clock_;
200
Tianjie Xu1b661142017-09-28 14:03:42 -0700201 std::unique_ptr<MetricsReporterInterface> metrics_reporter_;
202
Alex Deymo5e3ea272016-01-28 13:42:23 -0800203 DISALLOW_COPY_AND_ASSIGN(UpdateAttempterAndroid);
204};
205
206} // namespace chromeos_update_engine
207
208#endif // UPDATE_ENGINE_UPDATE_ATTEMPTER_ANDROID_H_