blob: 6a5c227c61afaf0c0da4afd0c39e612ede88c08a [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"
Alex Deymo5e3ea272016-01-28 13:42:23 -080031#include "update_engine/common/hardware_interface.h"
32#include "update_engine/common/prefs_interface.h"
Alex Deymo03a4de72016-07-20 16:08:23 -070033#include "update_engine/daemon_state_interface.h"
Alex Deymo87792ea2016-07-25 15:40:36 -070034#include "update_engine/network_selector_interface.h"
Alex Deymo5e3ea272016-01-28 13:42:23 -080035#include "update_engine/payload_consumer/download_action.h"
Alex Deymo0d298542016-03-30 18:31:49 -070036#include "update_engine/payload_consumer/postinstall_runner_action.h"
Alex Deymo5e3ea272016-01-28 13:42:23 -080037#include "update_engine/service_delegate_android_interface.h"
38#include "update_engine/service_observer_interface.h"
39
40namespace chromeos_update_engine {
41
Alex Deymo0d298542016-03-30 18:31:49 -070042class UpdateAttempterAndroid
43 : public ServiceDelegateAndroidInterface,
44 public ActionProcessorDelegate,
45 public DownloadActionDelegate,
46 public PostinstallRunnerAction::DelegateInterface {
Alex Deymo5e3ea272016-01-28 13:42:23 -080047 public:
48 using UpdateStatus = update_engine::UpdateStatus;
49
Alex Deymo03a4de72016-07-20 16:08:23 -070050 UpdateAttempterAndroid(DaemonStateInterface* daemon_state,
Alex Deymo5e3ea272016-01-28 13:42:23 -080051 PrefsInterface* prefs,
52 BootControlInterface* boot_control_,
53 HardwareInterface* hardware_);
54 ~UpdateAttempterAndroid() override;
55
56 // Further initialization to be done post construction.
57 void Init();
58
59 // ServiceDelegateAndroidInterface overrides.
60 bool ApplyPayload(const std::string& payload_url,
61 int64_t payload_offset,
62 int64_t payload_size,
63 const std::vector<std::string>& key_value_pair_headers,
64 brillo::ErrorPtr* error) override;
65 bool SuspendUpdate(brillo::ErrorPtr* error) override;
66 bool ResumeUpdate(brillo::ErrorPtr* error) override;
67 bool CancelUpdate(brillo::ErrorPtr* error) override;
Alex Deymo3b678db2016-02-09 11:50:06 -080068 bool ResetStatus(brillo::ErrorPtr* error) override;
Alex Deymo5e3ea272016-01-28 13:42:23 -080069
70 // ActionProcessorDelegate methods:
71 void ProcessingDone(const ActionProcessor* processor,
72 ErrorCode code) override;
73 void ProcessingStopped(const ActionProcessor* processor) override;
74 void ActionCompleted(ActionProcessor* processor,
75 AbstractAction* action,
76 ErrorCode code) override;
77
78 // DownloadActionDelegate overrides.
79 void BytesReceived(uint64_t bytes_progressed,
80 uint64_t bytes_received,
81 uint64_t total) override;
82 bool ShouldCancel(ErrorCode* cancel_reason) override;
83 void DownloadComplete() override;
84
Alex Deymo0d298542016-03-30 18:31:49 -070085 // PostinstallRunnerAction::DelegateInterface
86 void ProgressUpdate(double progress) override;
87
Alex Deymo5e3ea272016-01-28 13:42:23 -080088 private:
89 // Asynchronously marks the current slot as successful if needed. If already
90 // marked as good, CompleteUpdateBootFlags() is called starting the action
91 // processor.
92 void UpdateBootFlags();
93
94 // Called when the boot flags have been updated.
95 void CompleteUpdateBootFlags(bool success);
96
97 // Schedules an event loop callback to start the action processor. This is
98 // scheduled asynchronously to unblock the event loop.
99 void ScheduleProcessingStart();
100
101 // Notifies an update request completed with the given error |code| to all
102 // observers.
103 void TerminateUpdateAndNotify(ErrorCode error_code);
104
105 // Sets the status to the given |status| and notifies a status update to
106 // all observers.
107 void SetStatusAndNotify(UpdateStatus status);
108
109 // Helper method to construct the sequence of actions to be performed for
Alex Deymo2c131bb2016-05-26 16:43:13 -0700110 // applying an update from the given |url|.
111 void BuildUpdateActions(const std::string& url);
Alex Deymo5e3ea272016-01-28 13:42:23 -0800112
113 // Sets up the download parameters based on the update requested on the
114 // |install_plan_|.
115 void SetupDownload();
116
117 // Writes to the processing completed marker. Does nothing if
118 // |update_completed_marker_| is empty.
119 bool WriteUpdateCompletedMarker();
120
121 // Returns whether an update was completed in the current boot.
122 bool UpdateCompletedOnThisBoot();
123
Alex Deymo03a4de72016-07-20 16:08:23 -0700124 DaemonStateInterface* daemon_state_;
Alex Deymo5e3ea272016-01-28 13:42:23 -0800125
126 // DaemonStateAndroid pointers.
127 PrefsInterface* prefs_;
128 BootControlInterface* boot_control_;
129 HardwareInterface* hardware_;
130
131 // Last status notification timestamp used for throttling. Use monotonic
132 // TimeTicks to ensure that notifications are sent even if the system clock is
133 // set back in the middle of an update.
134 base::TimeTicks last_notify_time_;
135
136 // The list of actions and action processor that runs them asynchronously.
137 // Only used when |ongoing_update_| is true.
138 std::vector<std::shared_ptr<AbstractAction>> actions_;
139 std::unique_ptr<ActionProcessor> processor_;
140
141 // Pointer to the DownloadAction in the actions_ vector.
142 std::shared_ptr<DownloadAction> download_action_;
143
144 // Whether there is an ongoing update. This implies that an update was started
145 // but not finished yet. This value will be true even if the update was
146 // suspended.
147 bool ongoing_update_{false};
148
149 // The InstallPlan used during the ongoing update.
150 InstallPlan install_plan_;
151
152 // For status:
153 UpdateStatus status_{UpdateStatus::IDLE};
154 double download_progress_{0.0};
155
Alex Deymo0fd51ff2016-02-03 14:22:43 -0800156 // The offset in the payload file where the CrAU part starts.
157 int64_t base_offset_{0};
158
Alex Deymo5e3ea272016-01-28 13:42:23 -0800159 // Only direct proxy supported.
160 DirectProxyResolver proxy_resolver_;
161
Alex Deymo87792ea2016-07-25 15:40:36 -0700162 // Helper class to select the network to use during the update.
163 std::unique_ptr<NetworkSelectorInterface> network_selector_;
164
Alex Deymo5e3ea272016-01-28 13:42:23 -0800165 // Whether we have marked the current slot as good. This step is required
166 // before applying an update to the other slot.
167 bool updated_boot_flags_ = false;
168
169 DISALLOW_COPY_AND_ASSIGN(UpdateAttempterAndroid);
170};
171
172} // namespace chromeos_update_engine
173
174#endif // UPDATE_ENGINE_UPDATE_ATTEMPTER_ANDROID_H_