Alex Deymo | aea4c1c | 2015-08-19 20:24:43 -0700 | [diff] [blame] | 1 | // |
| 2 | // Copyright (C) 2012 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 | // |
Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 16 | |
Gilad Arnold | cf175a0 | 2014-07-10 16:48:47 -0700 | [diff] [blame] | 17 | #ifndef UPDATE_ENGINE_UPDATE_ATTEMPTER_H_ |
| 18 | #define UPDATE_ENGINE_UPDATE_ATTEMPTER_H_ |
Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 19 | |
Andrew de los Reyes | 63b96d7 | 2010-05-10 13:08:54 -0700 | [diff] [blame] | 20 | #include <time.h> |
Darin Petkov | c6c135c | 2010-08-11 13:36:18 -0700 | [diff] [blame] | 21 | |
Alex Deymo | bc91a27 | 2014-05-20 16:45:33 -0700 | [diff] [blame] | 22 | #include <memory> |
Alex Deymo | fa78f14 | 2016-01-26 21:36:16 -0800 | [diff] [blame] | 23 | #include <set> |
Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 24 | #include <string> |
Alex Vakulenko | d2779df | 2014-06-16 13:19:00 -0700 | [diff] [blame] | 25 | #include <utility> |
Alex Vakulenko | 44cab30 | 2014-07-23 13:12:15 -0700 | [diff] [blame] | 26 | #include <vector> |
Darin Petkov | c6c135c | 2010-08-11 13:36:18 -0700 | [diff] [blame] | 27 | |
Gilad Arnold | 44dc3bf | 2014-07-18 23:39:38 -0700 | [diff] [blame] | 28 | #include <base/bind.h> |
Jae Hoon Kim | edb6550 | 2019-06-14 11:52:17 -0700 | [diff] [blame] | 29 | #include <base/guid.h> |
Alex Vakulenko | 75039d7 | 2014-03-25 12:36:28 -0700 | [diff] [blame] | 30 | #include <base/time/time.h> |
Darin Petkov | f42cc1c | 2010-09-01 09:03:02 -0700 | [diff] [blame] | 31 | #include <gtest/gtest_prod.h> // for FRIEND_TEST |
Darin Petkov | c6c135c | 2010-08-11 13:36:18 -0700 | [diff] [blame] | 32 | |
Amin Hassani | e94ece5 | 2017-08-01 15:03:08 -0700 | [diff] [blame] | 33 | #if USE_CHROME_NETWORK_PROXY |
Andrew de los Reyes | 000d895 | 2011-03-02 15:21:14 -0800 | [diff] [blame] | 34 | #include "update_engine/chrome_browser_proxy_resolver.h" |
Amin Hassani | e94ece5 | 2017-08-01 15:03:08 -0700 | [diff] [blame] | 35 | #endif // USE_CHROME_NETWORK_PROXY |
Alex Deymo | 14c0da8 | 2016-07-20 16:45:45 -0700 | [diff] [blame] | 36 | #include "update_engine/certificate_checker.h" |
Alex Deymo | 906191f | 2015-10-12 12:22:44 -0700 | [diff] [blame] | 37 | #include "update_engine/client_library/include/update_engine/update_status.h" |
Alex Deymo | 39910dc | 2015-11-09 17:04:30 -0800 | [diff] [blame] | 38 | #include "update_engine/common/action_processor.h" |
Alex Deymo | ab0d976 | 2016-02-02 10:52:56 -0800 | [diff] [blame] | 39 | #include "update_engine/common/cpu_limiter.h" |
Jae Hoon Kim | 5e8e30b | 2020-05-06 14:59:06 -0700 | [diff] [blame] | 40 | #include "update_engine/common/excluder_interface.h" |
Sen Jiang | d8be4b5 | 2018-09-18 16:06:57 -0700 | [diff] [blame] | 41 | #include "update_engine/common/proxy_resolver.h" |
Amin Hassani | 7fca286 | 2019-03-28 16:09:22 -0700 | [diff] [blame] | 42 | #include "update_engine/omaha_request_builder_xml.h" |
Darin Petkov | a4a8a8c | 2010-07-15 22:21:12 -0700 | [diff] [blame] | 43 | #include "update_engine/omaha_request_params.h" |
Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 44 | #include "update_engine/omaha_response_handler_action.h" |
Alex Deymo | 39910dc | 2015-11-09 17:04:30 -0800 | [diff] [blame] | 45 | #include "update_engine/payload_consumer/download_action.h" |
Alex Deymo | 0d29854 | 2016-03-30 18:31:49 -0700 | [diff] [blame] | 46 | #include "update_engine/payload_consumer/postinstall_runner_action.h" |
Alex Deymo | fa78f14 | 2016-01-26 21:36:16 -0800 | [diff] [blame] | 47 | #include "update_engine/service_observer_interface.h" |
Jay Srinivasan | 4348879 | 2012-06-19 00:25:31 -0700 | [diff] [blame] | 48 | #include "update_engine/system_state.h" |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 49 | #include "update_engine/update_manager/policy.h" |
Adolfo Victoria | 497044c | 2018-07-18 07:51:42 -0700 | [diff] [blame] | 50 | #include "update_engine/update_manager/staging_utils.h" |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 51 | #include "update_engine/update_manager/update_manager.h" |
Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 52 | |
Patrick Dubroy | 7fbbe8a | 2011-08-01 17:28:22 +0200 | [diff] [blame] | 53 | namespace policy { |
Alex Vakulenko | 157fe30 | 2014-08-11 15:59:58 -0700 | [diff] [blame] | 54 | class PolicyProvider; |
Patrick Dubroy | 7fbbe8a | 2011-08-01 17:28:22 +0200 | [diff] [blame] | 55 | } |
| 56 | |
Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 57 | namespace chromeos_update_engine { |
| 58 | |
Andrew de los Reyes | 63b96d7 | 2010-05-10 13:08:54 -0700 | [diff] [blame] | 59 | class UpdateAttempter : public ActionProcessorDelegate, |
Alex Deymo | c1c17b4 | 2015-11-23 03:53:15 -0300 | [diff] [blame] | 60 | public DownloadActionDelegate, |
Alex Deymo | f7ead81 | 2015-10-23 17:37:27 -0700 | [diff] [blame] | 61 | public CertificateChecker::Observer, |
Alex Deymo | 0d29854 | 2016-03-30 18:31:49 -0700 | [diff] [blame] | 62 | public PostinstallRunnerAction::DelegateInterface { |
Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 63 | public: |
Christopher Wiley | cc8ce0e | 2015-10-01 16:48:47 -0700 | [diff] [blame] | 64 | using UpdateStatus = update_engine::UpdateStatus; |
Aaron Wood | bf5a252 | 2017-10-04 10:58:36 -0700 | [diff] [blame] | 65 | using UpdateAttemptFlags = update_engine::UpdateAttemptFlags; |
Darin Petkov | 3627577 | 2010-10-01 11:40:57 -0700 | [diff] [blame] | 66 | static const int kMaxDeltaUpdateFailures; |
| 67 | |
Jeffrey Kardatzke | cf5f1f1 | 2017-10-02 16:08:44 -0700 | [diff] [blame] | 68 | UpdateAttempter(SystemState* system_state, CertificateChecker* cert_checker); |
Alex Deymo | 610277e | 2014-11-11 21:18:11 -0800 | [diff] [blame] | 69 | ~UpdateAttempter() override; |
Darin Petkov | c6c135c | 2010-08-11 13:36:18 -0700 | [diff] [blame] | 70 | |
Gilad Arnold | 1f84723 | 2014-04-07 12:07:49 -0700 | [diff] [blame] | 71 | // Further initialization to be done post construction. |
| 72 | void Init(); |
| 73 | |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 74 | // Initiates scheduling of update checks. |
Xiaochu Liu | 88d9038 | 2018-08-29 16:09:11 -0700 | [diff] [blame] | 75 | // Returns true if update check is scheduled. |
| 76 | virtual bool ScheduleUpdates(); |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 77 | |
Gilad Arnold | 1ebd813 | 2012-03-05 10:19:29 -0800 | [diff] [blame] | 78 | // Checks for update and, if a newer version is available, attempts to update |
| 79 | // the system. Non-empty |in_app_version| or |in_update_url| prevents |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 80 | // automatic detection of the parameter. |target_channel| denotes a |
| 81 | // policy-mandated channel we are updating to, if not empty. If |obey_proxies| |
| 82 | // is true, the update will likely respect Chrome's proxy setting. For |
| 83 | // security reasons, we may still not honor them. |interactive| should be true |
| 84 | // if this was called from the user (ie dbus). |
Darin Petkov | 1023a60 | 2010-08-30 13:47:51 -0700 | [diff] [blame] | 85 | virtual void Update(const std::string& app_version, |
Andrew de los Reyes | 4516810 | 2010-11-22 11:13:50 -0800 | [diff] [blame] | 86 | const std::string& omaha_url, |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 87 | const std::string& target_channel, |
| 88 | const std::string& target_version_prefix, |
Marton Hunyady | ba51c3f | 2018-04-25 15:18:10 +0200 | [diff] [blame] | 89 | bool rollback_allowed, |
Zentaro Kavanagh | 28def4f | 2019-01-15 17:15:01 -0800 | [diff] [blame] | 90 | bool rollback_data_save_requested, |
Zentaro Kavanagh | 0ef9a2f | 2018-07-02 12:05:07 -0700 | [diff] [blame] | 91 | int rollback_allowed_milestones, |
Andrew de los Reyes | fb2f461 | 2011-06-09 18:21:49 -0700 | [diff] [blame] | 92 | bool obey_proxies, |
Nam T. Nguyen | 7d623eb | 2014-05-13 16:06:28 -0700 | [diff] [blame] | 93 | bool interactive); |
Darin Petkov | a4a8a8c | 2010-07-15 22:21:12 -0700 | [diff] [blame] | 94 | |
Andrew de los Reyes | 63b96d7 | 2010-05-10 13:08:54 -0700 | [diff] [blame] | 95 | // ActionProcessorDelegate methods: |
Alex Deymo | 610277e | 2014-11-11 21:18:11 -0800 | [diff] [blame] | 96 | void ProcessingDone(const ActionProcessor* processor, |
| 97 | ErrorCode code) override; |
| 98 | void ProcessingStopped(const ActionProcessor* processor) override; |
Andrew de los Reyes | 63b96d7 | 2010-05-10 13:08:54 -0700 | [diff] [blame] | 99 | void ActionCompleted(ActionProcessor* processor, |
| 100 | AbstractAction* action, |
Alex Deymo | 610277e | 2014-11-11 21:18:11 -0800 | [diff] [blame] | 101 | ErrorCode code) override; |
Darin Petkov | a4a8a8c | 2010-07-15 22:21:12 -0700 | [diff] [blame] | 102 | |
Alex Deymo | 0d29854 | 2016-03-30 18:31:49 -0700 | [diff] [blame] | 103 | // PostinstallRunnerAction::DelegateInterface |
| 104 | void ProgressUpdate(double progress) override; |
| 105 | |
Jay Srinivasan | c1ba09a | 2012-08-14 14:15:57 -0700 | [diff] [blame] | 106 | // Resets the current state to UPDATE_STATUS_IDLE. |
| 107 | // Used by update_engine_client for restarting a new update without |
| 108 | // having to reboot once the previous update has reached |
| 109 | // UPDATE_STATUS_UPDATED_NEED_REBOOT state. This is used only |
| 110 | // for testing purposes. |
Alex Deymo | 560ae1d | 2014-10-28 02:17:54 -0700 | [diff] [blame] | 111 | virtual bool ResetStatus(); |
Jay Srinivasan | c1ba09a | 2012-08-14 14:15:57 -0700 | [diff] [blame] | 112 | |
Aaron Wood | 7f92e2b | 2017-08-28 14:51:21 -0700 | [diff] [blame] | 113 | // Returns the current status in the out param. Returns true on success. |
| 114 | virtual bool GetStatus(update_engine::UpdateEngineStatus* out_status); |
Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 115 | |
Darin Petkov | 1023a60 | 2010-08-30 13:47:51 -0700 | [diff] [blame] | 116 | UpdateStatus status() const { return status_; } |
| 117 | |
| 118 | int http_response_code() const { return http_response_code_; } |
| 119 | void set_http_response_code(int code) { http_response_code_ = code; } |
| 120 | |
Aaron Wood | bf5a252 | 2017-10-04 10:58:36 -0700 | [diff] [blame] | 121 | // Set flags that influence how updates and checks are performed. These |
| 122 | // influence all future checks and updates until changed or the device |
| 123 | // reboots. |
| 124 | void SetUpdateAttemptFlags(UpdateAttemptFlags flags) { |
| 125 | update_attempt_flags_ = flags; |
| 126 | } |
| 127 | |
| 128 | // Returns the update attempt flags that are in place for the current update |
| 129 | // attempt. These are cached at the start of an update attempt so that they |
| 130 | // remain constant throughout the process. |
Sen Jiang | daeaa43 | 2018-10-09 18:18:45 -0700 | [diff] [blame] | 131 | virtual UpdateAttemptFlags GetCurrentUpdateAttemptFlags() const { |
Aaron Wood | bf5a252 | 2017-10-04 10:58:36 -0700 | [diff] [blame] | 132 | return current_update_attempt_flags_; |
| 133 | } |
| 134 | |
Jay Srinivasan | e73acab | 2012-07-10 14:34:03 -0700 | [diff] [blame] | 135 | // This is the internal entry point for going through an |
Darin Petkov | 5a7f565 | 2010-07-22 21:40:09 -0700 | [diff] [blame] | 136 | // update. If the current status is idle invokes Update. |
Jay Srinivasan | e73acab | 2012-07-10 14:34:03 -0700 | [diff] [blame] | 137 | // This is called by the DBus implementation. |
Aaron Wood | 081c023 | 2017-10-19 17:14:58 -0700 | [diff] [blame] | 138 | // This returns true if an update check was started, false if a check or an |
| 139 | // update was already in progress. |
| 140 | virtual bool CheckForUpdate(const std::string& app_version, |
Alex Deymo | 560ae1d | 2014-10-28 02:17:54 -0700 | [diff] [blame] | 141 | const std::string& omaha_url, |
Aaron Wood | 081c023 | 2017-10-19 17:14:58 -0700 | [diff] [blame] | 142 | UpdateAttemptFlags flags); |
Andrew de los Reyes | 63b96d7 | 2010-05-10 13:08:54 -0700 | [diff] [blame] | 143 | |
Xiaochu Liu | 88d9038 | 2018-08-29 16:09:11 -0700 | [diff] [blame] | 144 | // This is the version of CheckForUpdate called by AttemptInstall API. |
Amin Hassani | 2b68e6b | 2020-04-17 10:49:12 -0700 | [diff] [blame] | 145 | virtual bool CheckForInstall(const std::vector<std::string>& dlc_ids, |
Xiaochu Liu | 88d9038 | 2018-08-29 16:09:11 -0700 | [diff] [blame] | 146 | const std::string& omaha_url); |
| 147 | |
Chris Sosa | d317e40 | 2013-06-12 13:47:09 -0700 | [diff] [blame] | 148 | // This is the internal entry point for going through a rollback. This will |
| 149 | // attempt to run the postinstall on the non-active partition and set it as |
| 150 | // the partition to boot from. If |powerwash| is True, perform a powerwash |
Chris Sosa | 44b9b7e | 2014-04-02 13:53:46 -0700 | [diff] [blame] | 151 | // as part of rollback. Returns True on success. |
| 152 | bool Rollback(bool powerwash); |
Chris Sosa | d317e40 | 2013-06-12 13:47:09 -0700 | [diff] [blame] | 153 | |
Chris Sosa | 44b9b7e | 2014-04-02 13:53:46 -0700 | [diff] [blame] | 154 | // This is the internal entry point for checking if we can rollback. |
Alex Vakulenko | 59e253e | 2014-02-24 10:40:21 -0800 | [diff] [blame] | 155 | bool CanRollback() const; |
| 156 | |
Alex Vakulenko | 2bddadd | 2014-03-27 13:23:46 -0700 | [diff] [blame] | 157 | // This is the internal entry point for getting a rollback partition name, |
| 158 | // if one exists. It returns the bootable rollback kernel device partition |
| 159 | // name or empty string if none is available. |
Alex Deymo | 763e7db | 2015-08-27 21:08:08 -0700 | [diff] [blame] | 160 | BootControlInterface::Slot GetRollbackSlot() const; |
Alex Vakulenko | 2bddadd | 2014-03-27 13:23:46 -0700 | [diff] [blame] | 161 | |
Darin Petkov | 296889c | 2010-07-23 16:20:54 -0700 | [diff] [blame] | 162 | // Initiates a reboot if the current state is |
Sen Jiang | 771f648 | 2018-04-04 17:59:10 -0700 | [diff] [blame] | 163 | // UPDATED_NEED_REBOOT. Returns true on success, false otherwise. |
Darin Petkov | 296889c | 2010-07-23 16:20:54 -0700 | [diff] [blame] | 164 | bool RebootIfNeeded(); |
| 165 | |
Andrew | a8d7df3 | 2020-03-15 20:10:01 -0700 | [diff] [blame] | 166 | // Sets the DLC as active or inactive. See common_service.h |
| 167 | virtual bool SetDlcActiveValue(bool is_active, const std::string& dlc_id); |
| 168 | |
Alex Deymo | 542c19b | 2015-12-03 07:43:31 -0300 | [diff] [blame] | 169 | // DownloadActionDelegate methods: |
| 170 | void BytesReceived(uint64_t bytes_progressed, |
| 171 | uint64_t bytes_received, |
| 172 | uint64_t total) override; |
| 173 | |
| 174 | // Returns that the update should be canceled when the download channel was |
| 175 | // changed. |
| 176 | bool ShouldCancel(ErrorCode* cancel_reason) override; |
| 177 | |
| 178 | void DownloadComplete() override; |
Andrew de los Reyes | 63b96d7 | 2010-05-10 13:08:54 -0700 | [diff] [blame] | 179 | |
Alex Deymo | fa78f14 | 2016-01-26 21:36:16 -0800 | [diff] [blame] | 180 | // Broadcasts the current status to all observers. |
Darin Petkov | 61635a9 | 2011-05-18 16:20:36 -0700 | [diff] [blame] | 181 | void BroadcastStatus(); |
| 182 | |
Sen Jiang | 3978ddd | 2018-03-22 18:05:44 -0700 | [diff] [blame] | 183 | ErrorCode GetAttemptErrorCode() const { return attempt_error_code_; } |
| 184 | |
David Zeuthen | e4c58bf | 2013-06-18 17:26:50 -0700 | [diff] [blame] | 185 | // Called at update_engine startup to do various house-keeping. |
| 186 | void UpdateEngineStarted(); |
| 187 | |
Jae Hoon Kim | 5e8e30b | 2020-05-06 14:59:06 -0700 | [diff] [blame] | 188 | // Returns the |Excluder| that is currently held onto. |
| 189 | virtual ExcluderInterface* GetExcluder() const { return excluder_.get(); } |
| 190 | |
Alex Vakulenko | 1bab5a8 | 2015-10-27 11:47:28 -0700 | [diff] [blame] | 191 | // Reloads the device policy from libbrillo. Note: This method doesn't |
Alex Deymo | f4867c4 | 2013-06-28 14:41:39 -0700 | [diff] [blame] | 192 | // cause a real-time policy fetch from the policy server. It just reloads the |
Alex Vakulenko | 1bab5a8 | 2015-10-27 11:47:28 -0700 | [diff] [blame] | 193 | // latest value that libbrillo has cached. libbrillo fetches the policies |
Alex Deymo | f4867c4 | 2013-06-28 14:41:39 -0700 | [diff] [blame] | 194 | // from the server asynchronously at its own frequency. |
Alex Deymo | 560ae1d | 2014-10-28 02:17:54 -0700 | [diff] [blame] | 195 | virtual void RefreshDevicePolicy(); |
Alex Deymo | f4867c4 | 2013-06-28 14:41:39 -0700 | [diff] [blame] | 196 | |
Alex Deymo | 906191f | 2015-10-12 12:22:44 -0700 | [diff] [blame] | 197 | // Stores in |out_boot_time| the boottime (CLOCK_BOOTTIME) recorded at the |
| 198 | // time of the last successful update in the current boot. Returns false if |
| 199 | // there wasn't a successful update in the current boot. |
Amin Hassani | 7cc8bb0 | 2019-01-14 16:29:47 -0800 | [diff] [blame] | 200 | virtual bool GetBootTimeAtUpdate(base::Time* out_boot_time); |
David Zeuthen | 3c55abd | 2013-10-14 12:48:03 -0700 | [diff] [blame] | 201 | |
Alex Vakulenko | dea2eac | 2014-03-14 15:56:59 -0700 | [diff] [blame] | 202 | // Returns a version OS version that was being used before the last reboot, |
Sen Jiang | 771f648 | 2018-04-04 17:59:10 -0700 | [diff] [blame] | 203 | // and if that reboot happened to be into an update (current version). |
Alex Vakulenko | dea2eac | 2014-03-14 15:56:59 -0700 | [diff] [blame] | 204 | // This will return an empty string otherwise. |
Sen Jiang | daeaa43 | 2018-10-09 18:18:45 -0700 | [diff] [blame] | 205 | const std::string& GetPrevVersion() const { return prev_version_; } |
Alex Vakulenko | dea2eac | 2014-03-14 15:56:59 -0700 | [diff] [blame] | 206 | |
Gilad Arnold | a0258a5 | 2014-07-10 16:21:19 -0700 | [diff] [blame] | 207 | // Returns the number of consecutive failed update checks. |
Gilad Arnold | a6dab94 | 2014-04-25 11:46:03 -0700 | [diff] [blame] | 208 | virtual unsigned int consecutive_failed_update_checks() const { |
| 209 | return consecutive_failed_update_checks_; |
| 210 | } |
| 211 | |
Gilad Arnold | a0258a5 | 2014-07-10 16:21:19 -0700 | [diff] [blame] | 212 | // Returns the poll interval dictated by Omaha, if provided; zero otherwise. |
| 213 | virtual unsigned int server_dictated_poll_interval() const { |
| 214 | return server_dictated_poll_interval_; |
| 215 | } |
| 216 | |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 217 | // Sets a callback to be used when either a forced update request is received |
| 218 | // (first argument set to true) or cleared by an update attempt (first |
| 219 | // argument set to false). The callback further encodes whether the forced |
| 220 | // check is an interactive one (second argument set to true). Takes ownership |
| 221 | // of the callback object. A null value disables callback on these events. |
| 222 | // Note that only one callback can be set, so effectively at most one client |
| 223 | // can be notified. |
| 224 | virtual void set_forced_update_pending_callback( |
Sen Jiang | daeaa43 | 2018-10-09 18:18:45 -0700 | [diff] [blame] | 225 | base::Callback<void(bool, bool)>* callback) { |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 226 | forced_update_pending_callback_.reset(callback); |
Gilad Arnold | 44dc3bf | 2014-07-18 23:39:38 -0700 | [diff] [blame] | 227 | } |
| 228 | |
David Pursell | 02c1864 | 2014-11-06 11:26:11 -0800 | [diff] [blame] | 229 | // Returns true if we should allow updates from any source. In official builds |
| 230 | // we want to restrict updates to known safe sources, but under certain |
| 231 | // conditions it's useful to allow updating from anywhere (e.g. to allow |
| 232 | // 'cros flash' to function properly). |
Sen Jiang | daeaa43 | 2018-10-09 18:18:45 -0700 | [diff] [blame] | 233 | bool IsAnyUpdateSourceAllowed() const; |
David Pursell | 02c1864 | 2014-11-06 11:26:11 -0800 | [diff] [blame] | 234 | |
Alex Deymo | fa78f14 | 2016-01-26 21:36:16 -0800 | [diff] [blame] | 235 | // Add and remove a service observer. |
| 236 | void AddObserver(ServiceObserverInterface* observer) { |
| 237 | service_observers_.insert(observer); |
| 238 | } |
| 239 | void RemoveObserver(ServiceObserverInterface* observer) { |
| 240 | service_observers_.erase(observer); |
| 241 | } |
| 242 | |
Alex Deymo | 03a4de7 | 2016-07-20 16:08:23 -0700 | [diff] [blame] | 243 | const std::set<ServiceObserverInterface*>& service_observers() { |
| 244 | return service_observers_; |
| 245 | } |
| 246 | |
Alex Deymo | fa78f14 | 2016-01-26 21:36:16 -0800 | [diff] [blame] | 247 | // Remove all the observers. |
| 248 | void ClearObservers() { service_observers_.clear(); } |
| 249 | |
Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 250 | private: |
Alex Deymo | 906191f | 2015-10-12 12:22:44 -0700 | [diff] [blame] | 251 | // Friend declarations for testing purposes. |
Gilad Arnold | 70e476e | 2013-07-30 16:01:13 -0700 | [diff] [blame] | 252 | friend class UpdateAttempterUnderTest; |
Darin Petkov | f42cc1c | 2010-09-01 09:03:02 -0700 | [diff] [blame] | 253 | friend class UpdateAttempterTest; |
Darin Petkov | 1b00310 | 2010-11-30 10:18:36 -0800 | [diff] [blame] | 254 | FRIEND_TEST(UpdateAttempterTest, ActionCompletedDownloadTest); |
| 255 | FRIEND_TEST(UpdateAttempterTest, ActionCompletedErrorTest); |
| 256 | FRIEND_TEST(UpdateAttempterTest, ActionCompletedOmahaRequestTest); |
Aaron Wood | 9321f50 | 2017-09-07 11:18:54 -0700 | [diff] [blame] | 257 | FRIEND_TEST(UpdateAttempterTest, BootTimeInUpdateMarkerFile); |
| 258 | FRIEND_TEST(UpdateAttempterTest, BroadcastCompleteDownloadTest); |
Andrew | e045aef | 2020-01-08 16:29:22 -0800 | [diff] [blame] | 259 | FRIEND_TEST(UpdateAttempterTest, CalculateDlcParamsInstallTest); |
| 260 | FRIEND_TEST(UpdateAttempterTest, CalculateDlcParamsNoPrefFilesTest); |
| 261 | FRIEND_TEST(UpdateAttempterTest, CalculateDlcParamsNonParseableValuesTest); |
| 262 | FRIEND_TEST(UpdateAttempterTest, CalculateDlcParamsValidValuesTest); |
Andrew | a8d7df3 | 2020-03-15 20:10:01 -0700 | [diff] [blame] | 263 | FRIEND_TEST(UpdateAttempterTest, CalculateDlcParamsRemoveStaleMetadata); |
Aaron Wood | 9321f50 | 2017-09-07 11:18:54 -0700 | [diff] [blame] | 264 | FRIEND_TEST(UpdateAttempterTest, ChangeToDownloadingOnReceivedBytesTest); |
Jae Hoon Kim | c437ea5 | 2019-07-11 11:20:38 -0700 | [diff] [blame] | 265 | FRIEND_TEST(UpdateAttempterTest, CheckForInstallNotIdleFails); |
Xiaochu Liu | 8ba486f | 2018-11-06 11:14:10 -0800 | [diff] [blame] | 266 | FRIEND_TEST(UpdateAttempterTest, CheckForUpdateAUDlcTest); |
Darin Petkov | 18c7bce | 2011-06-16 14:07:00 -0700 | [diff] [blame] | 267 | FRIEND_TEST(UpdateAttempterTest, CreatePendingErrorEventTest); |
| 268 | FRIEND_TEST(UpdateAttempterTest, CreatePendingErrorEventResumedTest); |
Darin Petkov | 3627577 | 2010-10-01 11:40:57 -0700 | [diff] [blame] | 269 | FRIEND_TEST(UpdateAttempterTest, DisableDeltaUpdateIfNeededTest); |
Aaron Wood | 9321f50 | 2017-09-07 11:18:54 -0700 | [diff] [blame] | 270 | FRIEND_TEST(UpdateAttempterTest, DownloadProgressAccumulationTest); |
Colin Howes | ac170d9 | 2018-11-20 16:29:28 -0800 | [diff] [blame] | 271 | FRIEND_TEST(UpdateAttempterTest, InstallSetsStatusIdle); |
Amin Hassani | 9be122e | 2019-08-29 09:20:12 -0700 | [diff] [blame] | 272 | FRIEND_TEST(UpdateAttempterTest, IsEnterpriseRollbackInGetStatusTrue); |
| 273 | FRIEND_TEST(UpdateAttempterTest, IsEnterpriseRollbackInGetStatusFalse); |
Miriam Polzer | 0cf1acb | 2020-04-29 17:39:51 +0200 | [diff] [blame] | 274 | FRIEND_TEST(UpdateAttempterTest, |
| 275 | PowerwashInGetStatusTrueBecausePowerwashRequired); |
| 276 | FRIEND_TEST(UpdateAttempterTest, PowerwashInGetStatusTrueBecauseRollback); |
Darin Petkov | 3627577 | 2010-10-01 11:40:57 -0700 | [diff] [blame] | 277 | FRIEND_TEST(UpdateAttempterTest, MarkDeltaUpdateFailureTest); |
Darin Petkov | 18c7bce | 2011-06-16 14:07:00 -0700 | [diff] [blame] | 278 | FRIEND_TEST(UpdateAttempterTest, PingOmahaTest); |
Jae Hoon Kim | ed3fcc0 | 2019-07-11 14:35:38 -0700 | [diff] [blame] | 279 | FRIEND_TEST(UpdateAttempterTest, ProcessingDoneInstallError); |
| 280 | FRIEND_TEST(UpdateAttempterTest, ProcessingDoneUpdateError); |
Aaron Wood | 9321f50 | 2017-09-07 11:18:54 -0700 | [diff] [blame] | 281 | FRIEND_TEST(UpdateAttempterTest, ReportDailyMetrics); |
Marton Hunyady | ba51c3f | 2018-04-25 15:18:10 +0200 | [diff] [blame] | 282 | FRIEND_TEST(UpdateAttempterTest, RollbackNotAllowed); |
Colin Howes | 978c108 | 2018-12-03 11:46:12 -0800 | [diff] [blame] | 283 | FRIEND_TEST(UpdateAttempterTest, RollbackAfterInstall); |
Marton Hunyady | ba51c3f | 2018-04-25 15:18:10 +0200 | [diff] [blame] | 284 | FRIEND_TEST(UpdateAttempterTest, RollbackAllowed); |
| 285 | FRIEND_TEST(UpdateAttempterTest, RollbackAllowedSetAndReset); |
Marton Hunyady | a030268 | 2018-05-16 18:52:13 +0200 | [diff] [blame] | 286 | FRIEND_TEST(UpdateAttempterTest, RollbackMetricsNotRollbackFailure); |
| 287 | FRIEND_TEST(UpdateAttempterTest, RollbackMetricsNotRollbackSuccess); |
| 288 | FRIEND_TEST(UpdateAttempterTest, RollbackMetricsRollbackFailure); |
| 289 | FRIEND_TEST(UpdateAttempterTest, RollbackMetricsRollbackSuccess); |
Darin Petkov | 1b00310 | 2010-11-30 10:18:36 -0800 | [diff] [blame] | 290 | FRIEND_TEST(UpdateAttempterTest, ScheduleErrorEventActionNoEventTest); |
| 291 | FRIEND_TEST(UpdateAttempterTest, ScheduleErrorEventActionTest); |
Jae Hoon Kim | edb6550 | 2019-06-14 11:52:17 -0700 | [diff] [blame] | 292 | FRIEND_TEST(UpdateAttempterTest, SessionIdTestEnforceEmptyStrPingOmaha); |
| 293 | FRIEND_TEST(UpdateAttempterTest, SessionIdTestOnOmahaRequestActions); |
Marton Hunyady | 199152d | 2018-05-07 19:08:48 +0200 | [diff] [blame] | 294 | FRIEND_TEST(UpdateAttempterTest, SetRollbackHappenedNotRollback); |
| 295 | FRIEND_TEST(UpdateAttempterTest, SetRollbackHappenedRollback); |
Xiyuan Xia | c0e8f9a | 2017-02-22 13:19:35 -0800 | [diff] [blame] | 296 | FRIEND_TEST(UpdateAttempterTest, TargetVersionPrefixSetAndReset); |
Colin Howes | 978c108 | 2018-12-03 11:46:12 -0800 | [diff] [blame] | 297 | FRIEND_TEST(UpdateAttempterTest, UpdateAfterInstall); |
Aaron Wood | bf5a252 | 2017-10-04 10:58:36 -0700 | [diff] [blame] | 298 | FRIEND_TEST(UpdateAttempterTest, UpdateAttemptFlagsCachedAtUpdateStart); |
Aaron Wood | 23bd339 | 2017-10-06 14:48:25 -0700 | [diff] [blame] | 299 | FRIEND_TEST(UpdateAttempterTest, UpdateDeferredByPolicyTest); |
| 300 | FRIEND_TEST(UpdateAttempterTest, UpdateIsNotRunningWhenUpdateAvailable); |
Jae Hoon Kim | 7fdfbf1 | 2020-04-10 18:15:50 -0700 | [diff] [blame] | 301 | FRIEND_TEST(UpdateAttempterTest, GetSuccessfulDlcIds); |
Sen Jiang | daeaa43 | 2018-10-09 18:18:45 -0700 | [diff] [blame] | 302 | |
| 303 | // Returns the special flags to be added to ErrorCode values based on the |
| 304 | // parameters used in the current update attempt. |
| 305 | uint32_t GetErrorCodeFlags(); |
Darin Petkov | f42cc1c | 2010-09-01 09:03:02 -0700 | [diff] [blame] | 306 | |
Jae Hoon Kim | ed3fcc0 | 2019-07-11 14:35:38 -0700 | [diff] [blame] | 307 | // ActionProcessorDelegate methods |ProcessingDone()| internal helpers. |
| 308 | void ProcessingDoneInternal(const ActionProcessor* processor, ErrorCode code); |
| 309 | void ProcessingDoneUpdate(const ActionProcessor* processor, ErrorCode code); |
| 310 | void ProcessingDoneInstall(const ActionProcessor* processor, ErrorCode code); |
| 311 | |
Alex Deymo | c1c17b4 | 2015-11-23 03:53:15 -0300 | [diff] [blame] | 312 | // CertificateChecker::Observer method. |
| 313 | // Report metrics about the certificate being checked. |
| 314 | void CertificateChecked(ServerToCheck server_to_check, |
| 315 | CertificateCheckResult result) override; |
| 316 | |
David Zeuthen | 985b112 | 2013-10-09 12:13:15 -0700 | [diff] [blame] | 317 | // Checks if it's more than 24 hours since daily metrics were last |
| 318 | // reported and, if so, reports daily metrics. Returns |true| if |
| 319 | // metrics were reported, |false| otherwise. |
| 320 | bool CheckAndReportDailyMetrics(); |
| 321 | |
| 322 | // Calculates and reports the age of the currently running OS. This |
| 323 | // is defined as the age of the /etc/lsb-release file. |
| 324 | void ReportOSAge(); |
| 325 | |
Gilad Arnold | 1ebd813 | 2012-03-05 10:19:29 -0800 | [diff] [blame] | 326 | // Sets the status to the given status and notifies a status update over dbus. |
Nam T. Nguyen | 7d623eb | 2014-05-13 16:06:28 -0700 | [diff] [blame] | 327 | void SetStatusAndNotify(UpdateStatus status); |
Darin Petkov | a4a8a8c | 2010-07-15 22:21:12 -0700 | [diff] [blame] | 328 | |
Darin Petkov | 9b23057 | 2010-10-08 10:20:09 -0700 | [diff] [blame] | 329 | // Creates an error event object in |error_event_| to be included in an |
| 330 | // OmahaRequestAction once the current action processor is done. |
David Zeuthen | a99981f | 2013-04-29 13:42:47 -0700 | [diff] [blame] | 331 | void CreatePendingErrorEvent(AbstractAction* action, ErrorCode code); |
Darin Petkov | 09f96c3 | 2010-07-20 09:24:57 -0700 | [diff] [blame] | 332 | |
Darin Petkov | 9b23057 | 2010-10-08 10:20:09 -0700 | [diff] [blame] | 333 | // If there's a pending error event allocated in |error_event_|, schedules an |
| 334 | // OmahaRequestAction with that event in the current processor, clears the |
| 335 | // pending event, updates the status and returns true. Returns false |
| 336 | // otherwise. |
Darin Petkov | 09f96c3 | 2010-07-20 09:24:57 -0700 | [diff] [blame] | 337 | bool ScheduleErrorEventAction(); |
| 338 | |
Darin Petkov | 58dd134 | 2011-05-06 12:05:13 -0700 | [diff] [blame] | 339 | // Schedules an event loop callback to start the action processor. This is |
| 340 | // scheduled asynchronously to unblock the event loop. |
| 341 | void ScheduleProcessingStart(); |
| 342 | |
Darin Petkov | 3627577 | 2010-10-01 11:40:57 -0700 | [diff] [blame] | 343 | // Checks if a full update is needed and forces it by updating the Omaha |
| 344 | // request params. |
| 345 | void DisableDeltaUpdateIfNeeded(); |
| 346 | |
| 347 | // If this was a delta update attempt that failed, count it so that a full |
| 348 | // update can be tried when needed. |
| 349 | void MarkDeltaUpdateFailure(); |
Darin Petkov | 1b00310 | 2010-11-30 10:18:36 -0800 | [diff] [blame] | 350 | |
Andrew de los Reyes | 4516810 | 2010-11-22 11:13:50 -0800 | [diff] [blame] | 351 | ProxyResolver* GetProxyResolver() { |
Amin Hassani | e94ece5 | 2017-08-01 15:03:08 -0700 | [diff] [blame] | 352 | #if USE_CHROME_NETWORK_PROXY |
Sen Jiang | daeaa43 | 2018-10-09 18:18:45 -0700 | [diff] [blame] | 353 | if (obeying_proxies_) |
| 354 | return &chrome_proxy_resolver_; |
Amin Hassani | e94ece5 | 2017-08-01 15:03:08 -0700 | [diff] [blame] | 355 | #endif // USE_CHROME_NETWORK_PROXY |
Sen Jiang | daeaa43 | 2018-10-09 18:18:45 -0700 | [diff] [blame] | 356 | return &direct_proxy_resolver_; |
Andrew de los Reyes | 4516810 | 2010-11-22 11:13:50 -0800 | [diff] [blame] | 357 | } |
Darin Petkov | 3627577 | 2010-10-01 11:40:57 -0700 | [diff] [blame] | 358 | |
Thieu Le | 116fda3 | 2011-04-19 11:01:54 -0700 | [diff] [blame] | 359 | // Sends a ping to Omaha. |
| 360 | // This is used after an update has been applied and we're waiting for the |
| 361 | // user to reboot. This ping helps keep the number of actives count |
| 362 | // accurate in case a user takes a long time to reboot the device after an |
| 363 | // update has been applied. |
| 364 | void PingOmaha(); |
| 365 | |
Jay Srinivasan | 480ddfa | 2012-06-01 19:15:26 -0700 | [diff] [blame] | 366 | // Helper method of Update() to calculate the update-related parameters |
| 367 | // from various sources and set the appropriate state. Please refer to |
Sen Jiang | 771f648 | 2018-04-04 17:59:10 -0700 | [diff] [blame] | 368 | // Update() method for the meaning of the parameters. |
Jay Srinivasan | 480ddfa | 2012-06-01 19:15:26 -0700 | [diff] [blame] | 369 | bool CalculateUpdateParams(const std::string& app_version, |
| 370 | const std::string& omaha_url, |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 371 | const std::string& target_channel, |
| 372 | const std::string& target_version_prefix, |
Marton Hunyady | ba51c3f | 2018-04-25 15:18:10 +0200 | [diff] [blame] | 373 | bool rollback_allowed, |
Zentaro Kavanagh | 28def4f | 2019-01-15 17:15:01 -0800 | [diff] [blame] | 374 | bool rollback_data_save_requested, |
Zentaro Kavanagh | 0ef9a2f | 2018-07-02 12:05:07 -0700 | [diff] [blame] | 375 | int rollback_allowed_milestones, |
Jay Srinivasan | 480ddfa | 2012-06-01 19:15:26 -0700 | [diff] [blame] | 376 | bool obey_proxies, |
Nam T. Nguyen | 7d623eb | 2014-05-13 16:06:28 -0700 | [diff] [blame] | 377 | bool interactive); |
Jay Srinivasan | 480ddfa | 2012-06-01 19:15:26 -0700 | [diff] [blame] | 378 | |
Jay Srinivasan | 21be075 | 2012-07-25 15:44:56 -0700 | [diff] [blame] | 379 | // Calculates all the scattering related parameters (such as waiting period, |
| 380 | // which type of scattering is enabled, etc.) and also updates/deletes |
| 381 | // the corresponding prefs file used in scattering. Should be called |
| 382 | // only after the device policy has been loaded and set in the system_state_. |
Amin Hassani | ed37d68 | 2018-04-06 13:22:00 -0700 | [diff] [blame] | 383 | void CalculateScatteringParams(bool interactive); |
Jay Srinivasan | 21be075 | 2012-07-25 15:44:56 -0700 | [diff] [blame] | 384 | |
Jay Srinivasan | ae4697c | 2013-03-18 17:08:08 -0700 | [diff] [blame] | 385 | // Sets a random value for the waiting period to wait for before downloading |
| 386 | // an update, if one available. This value will be upperbounded by the |
| 387 | // scatter factor value specified from policy. |
Jay Srinivasan | 21be075 | 2012-07-25 15:44:56 -0700 | [diff] [blame] | 388 | void GenerateNewWaitingPeriod(); |
| 389 | |
Jay Srinivasan | 480ddfa | 2012-06-01 19:15:26 -0700 | [diff] [blame] | 390 | // Helper method of Update() to construct the sequence of actions to |
| 391 | // be performed for an update check. Please refer to |
Chris Sosa | d317e40 | 2013-06-12 13:47:09 -0700 | [diff] [blame] | 392 | // Update() method for the meaning of the parameters. |
Jay Srinivasan | 480ddfa | 2012-06-01 19:15:26 -0700 | [diff] [blame] | 393 | void BuildUpdateActions(bool interactive); |
| 394 | |
| 395 | // Decrements the count in the kUpdateCheckCountFilePath. |
| 396 | // Returns True if successfully decremented, false otherwise. |
| 397 | bool DecrementUpdateCheckCount(); |
| 398 | |
David Zeuthen | 8f191b2 | 2013-08-06 12:27:50 -0700 | [diff] [blame] | 399 | // Starts p2p and performs housekeeping. Returns true only if p2p is |
| 400 | // running and housekeeping was done. |
| 401 | bool StartP2PAndPerformHousekeeping(); |
| 402 | |
| 403 | // Calculates whether peer-to-peer should be used. Sets the |
| 404 | // |use_p2p_to_download_| and |use_p2p_to_share_| parameters |
| 405 | // on the |omaha_request_params_| object. |
| 406 | void CalculateP2PParams(bool interactive); |
| 407 | |
| 408 | // Starts P2P if it's enabled and there are files to actually share. |
| 409 | // Called only at program startup. Returns true only if p2p was |
| 410 | // started and housekeeping was performed. |
| 411 | bool StartP2PAtStartup(); |
| 412 | |
David Zeuthen | 3c55abd | 2013-10-14 12:48:03 -0700 | [diff] [blame] | 413 | // Writes to the processing completed marker. Does nothing if |
| 414 | // |update_completed_marker_| is empty. |
| 415 | void WriteUpdateCompletedMarker(); |
| 416 | |
Daniel Erat | 65f1da0 | 2014-06-27 22:05:38 -0700 | [diff] [blame] | 417 | // Reboots the system directly by calling /sbin/shutdown. Returns true on |
| 418 | // success. |
| 419 | bool RebootDirectly(); |
| 420 | |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 421 | // Callback for the async UpdateCheckAllowed policy request. If |status| is |
| 422 | // |EvalStatus::kSucceeded|, either runs or suppresses periodic update checks, |
| 423 | // based on the content of |params|. Otherwise, retries the policy request. |
| 424 | void OnUpdateScheduled( |
| 425 | chromeos_update_manager::EvalStatus status, |
| 426 | const chromeos_update_manager::UpdateCheckParams& params); |
| 427 | |
| 428 | // Updates the time an update was last attempted to the current time. |
| 429 | void UpdateLastCheckedTime(); |
| 430 | |
Marton Hunyady | e58bddb | 2018-04-10 20:27:26 +0200 | [diff] [blame] | 431 | // Checks whether we need to clear the rollback-happened preference after |
| 432 | // policy is available again. |
| 433 | void UpdateRollbackHappened(); |
| 434 | |
Jae Hoon Kim | ba2fdce | 2019-07-11 13:18:58 -0700 | [diff] [blame] | 435 | // Returns if an update is: running, applied and needs reboot, or scheduled. |
| 436 | bool IsBusyOrUpdateScheduled(); |
Gilad Arnold | 54fa66d | 2014-09-29 13:14:29 -0700 | [diff] [blame] | 437 | |
Adolfo Victoria | 497044c | 2018-07-18 07:51:42 -0700 | [diff] [blame] | 438 | void CalculateStagingParams(bool interactive); |
| 439 | |
May Lippert | 60aa3ca | 2018-08-15 16:55:29 -0700 | [diff] [blame] | 440 | // Reports a metric that tracks the time from when the update was first seen |
| 441 | // to the time when the update was finally downloaded and applied. This metric |
| 442 | // will only be reported for enterprise enrolled devices. |
| 443 | void ReportTimeToUpdateAppliedMetric(); |
| 444 | |
Amin Hassani | ecb60d3 | 2019-06-17 18:09:10 -0700 | [diff] [blame] | 445 | // Resets interactivity and forced update flags. |
| 446 | void ResetInteractivityFlags(); |
| 447 | |
Andrew | 065d78d | 2020-04-07 15:43:07 -0700 | [diff] [blame] | 448 | // Resets all the DLC prefs. |
| 449 | bool ResetDlcPrefs(const std::string& dlc_id); |
| 450 | |
| 451 | // Get the integer values from the DLC metadata for |kPrefsPingLastActive| |
| 452 | // or |kPrefsPingLastRollcall|. |
Andrew | e045aef | 2020-01-08 16:29:22 -0800 | [diff] [blame] | 453 | // The value is equal to -2 when the value cannot be read or is not numeric. |
| 454 | // The value is equal to -1 the first time it is being sent, which is |
| 455 | // when the metadata file doesn't exist. |
Andrew | 065d78d | 2020-04-07 15:43:07 -0700 | [diff] [blame] | 456 | int64_t GetPingMetadata(const std::string& metadata_key) const; |
Andrew | e045aef | 2020-01-08 16:29:22 -0800 | [diff] [blame] | 457 | |
Amin Hassani | 2b68e6b | 2020-04-17 10:49:12 -0700 | [diff] [blame] | 458 | // Calculates the update parameters for DLCs. Sets the |dlc_ids_| |
Andrew | e045aef | 2020-01-08 16:29:22 -0800 | [diff] [blame] | 459 | // parameter on the |omaha_request_params_| object. |
| 460 | void CalculateDlcParams(); |
| 461 | |
Jae Hoon Kim | 7fdfbf1 | 2020-04-10 18:15:50 -0700 | [diff] [blame] | 462 | // Returns the list of DLC IDs that were installed/updated, excluding the ones |
| 463 | // which had "noupdate" in the Omaha response. |
| 464 | std::vector<std::string> GetSuccessfulDlcIds(); |
| 465 | |
Darin Petkov | 9b23057 | 2010-10-08 10:20:09 -0700 | [diff] [blame] | 466 | // Last status notification timestamp used for throttling. Use monotonic |
| 467 | // TimeTicks to ensure that notifications are sent even if the system clock is |
| 468 | // set back in the middle of an update. |
Darin Petkov | af18305 | 2010-08-23 12:07:13 -0700 | [diff] [blame] | 469 | base::TimeTicks last_notify_time_; |
Andrew de los Reyes | 63b96d7 | 2010-05-10 13:08:54 -0700 | [diff] [blame] | 470 | |
Amin Hassani | 04d4162 | 2018-12-20 15:35:41 -0800 | [diff] [blame] | 471 | // Our two proxy resolvers |
| 472 | DirectProxyResolver direct_proxy_resolver_; |
| 473 | #if USE_CHROME_NETWORK_PROXY |
| 474 | ChromeBrowserProxyResolver chrome_proxy_resolver_; |
| 475 | #endif // USE_CHROME_NETWORK_PROXY |
| 476 | |
Ben Chan | 02f7c1d | 2014-10-18 15:18:02 -0700 | [diff] [blame] | 477 | std::unique_ptr<ActionProcessor> processor_; |
Darin Petkov | a4a8a8c | 2010-07-15 22:21:12 -0700 | [diff] [blame] | 478 | |
Jay Srinivasan | 6f6ea00 | 2012-12-14 11:26:28 -0800 | [diff] [blame] | 479 | // External state of the system outside the update_engine process |
| 480 | // carved out separately to mock out easily in unit tests. |
| 481 | SystemState* system_state_; |
| 482 | |
Alex Deymo | 33e91e7 | 2015-12-01 18:26:08 -0300 | [diff] [blame] | 483 | // Pointer to the certificate checker instance to use. |
| 484 | CertificateChecker* cert_checker_; |
| 485 | |
Alex Deymo | fa78f14 | 2016-01-26 21:36:16 -0800 | [diff] [blame] | 486 | // The list of services observing changes in the updater. |
| 487 | std::set<ServiceObserverInterface*> service_observers_; |
Casey Dahlin | 4089249 | 2016-01-25 16:55:28 -0800 | [diff] [blame] | 488 | |
Amin Hassani | d3f4bea | 2018-04-30 14:52:40 -0700 | [diff] [blame] | 489 | // The install plan. |
| 490 | std::unique_ptr<InstallPlan> install_plan_; |
Darin Petkov | 9b23057 | 2010-10-08 10:20:09 -0700 | [diff] [blame] | 491 | |
Jay Srinivasan | 6f6ea00 | 2012-12-14 11:26:28 -0800 | [diff] [blame] | 492 | // Pointer to the preferences store interface. This is just a cached |
| 493 | // copy of system_state->prefs() because it's used in many methods and |
| 494 | // is convenient this way. |
Gilad Arnold | 1f84723 | 2014-04-07 12:07:49 -0700 | [diff] [blame] | 495 | PrefsInterface* prefs_ = nullptr; |
Darin Petkov | 1cbd78f | 2010-07-29 12:38:34 -0700 | [diff] [blame] | 496 | |
Darin Petkov | 09f96c3 | 2010-07-20 09:24:57 -0700 | [diff] [blame] | 497 | // Pending error event, if any. |
Ben Chan | 02f7c1d | 2014-10-18 15:18:02 -0700 | [diff] [blame] | 498 | std::unique_ptr<OmahaEvent> error_event_; |
Darin Petkov | 09f96c3 | 2010-07-20 09:24:57 -0700 | [diff] [blame] | 499 | |
Andrew de los Reyes | c1d5c93 | 2011-04-20 17:15:47 -0700 | [diff] [blame] | 500 | // If we should request a reboot even tho we failed the update |
Gilad Arnold | 1f84723 | 2014-04-07 12:07:49 -0700 | [diff] [blame] | 501 | bool fake_update_success_ = false; |
Andrew de los Reyes | c1d5c93 | 2011-04-20 17:15:47 -0700 | [diff] [blame] | 502 | |
Darin Petkov | 85ced13 | 2010-09-01 10:20:56 -0700 | [diff] [blame] | 503 | // HTTP server response code from the last HTTP request action. |
Gilad Arnold | 1f84723 | 2014-04-07 12:07:49 -0700 | [diff] [blame] | 504 | int http_response_code_ = 0; |
Darin Petkov | 1023a60 | 2010-08-30 13:47:51 -0700 | [diff] [blame] | 505 | |
Sen Jiang | 3978ddd | 2018-03-22 18:05:44 -0700 | [diff] [blame] | 506 | // The attempt error code when the update attempt finished. |
| 507 | ErrorCode attempt_error_code_ = ErrorCode::kSuccess; |
| 508 | |
Alex Deymo | ab0d976 | 2016-02-02 10:52:56 -0800 | [diff] [blame] | 509 | // CPU limiter during the update. |
| 510 | CPULimiter cpu_limiter_; |
Darin Petkov | c6c135c | 2010-08-11 13:36:18 -0700 | [diff] [blame] | 511 | |
Andrew de los Reyes | 63b96d7 | 2010-05-10 13:08:54 -0700 | [diff] [blame] | 512 | // For status: |
Alex Deymo | 906191f | 2015-10-12 12:22:44 -0700 | [diff] [blame] | 513 | UpdateStatus status_{UpdateStatus::IDLE}; |
Gilad Arnold | 1f84723 | 2014-04-07 12:07:49 -0700 | [diff] [blame] | 514 | double download_progress_ = 0.0; |
| 515 | int64_t last_checked_time_ = 0; |
Alex Vakulenko | dea2eac | 2014-03-14 15:56:59 -0700 | [diff] [blame] | 516 | std::string prev_version_; |
Gilad Arnold | 1f84723 | 2014-04-07 12:07:49 -0700 | [diff] [blame] | 517 | std::string new_version_ = "0.0.0.0"; |
Aaron Wood | 7f92e2b | 2017-08-28 14:51:21 -0700 | [diff] [blame] | 518 | uint64_t new_payload_size_ = 0; |
Aaron Wood | bf5a252 | 2017-10-04 10:58:36 -0700 | [diff] [blame] | 519 | // Flags influencing all periodic update checks |
| 520 | UpdateAttemptFlags update_attempt_flags_ = UpdateAttemptFlags::kNone; |
| 521 | // Flags influencing the currently in-progress check (cached at the start of |
| 522 | // the update check). |
| 523 | UpdateAttemptFlags current_update_attempt_flags_ = UpdateAttemptFlags::kNone; |
Andrew de los Reyes | 63b96d7 | 2010-05-10 13:08:54 -0700 | [diff] [blame] | 524 | |
Jay Srinivasan | ae4697c | 2013-03-18 17:08:08 -0700 | [diff] [blame] | 525 | // Common parameters for all Omaha requests. |
Gilad Arnold | 1f84723 | 2014-04-07 12:07:49 -0700 | [diff] [blame] | 526 | OmahaRequestParams* omaha_request_params_ = nullptr; |
Darin Petkov | a4a8a8c | 2010-07-15 22:21:12 -0700 | [diff] [blame] | 527 | |
Andrew de los Reyes | 4516810 | 2010-11-22 11:13:50 -0800 | [diff] [blame] | 528 | // Number of consecutive manual update checks we've had where we obeyed |
| 529 | // Chrome's proxy settings. |
Gilad Arnold | 1f84723 | 2014-04-07 12:07:49 -0700 | [diff] [blame] | 530 | int proxy_manual_checks_ = 0; |
Andrew de los Reyes | 4516810 | 2010-11-22 11:13:50 -0800 | [diff] [blame] | 531 | |
| 532 | // If true, this update cycle we are obeying proxies |
Gilad Arnold | 1f84723 | 2014-04-07 12:07:49 -0700 | [diff] [blame] | 533 | bool obeying_proxies_ = true; |
Andrew de los Reyes | 4516810 | 2010-11-22 11:13:50 -0800 | [diff] [blame] | 534 | |
Patrick Dubroy | 7fbbe8a | 2011-08-01 17:28:22 +0200 | [diff] [blame] | 535 | // Used for fetching information about the device policy. |
Ben Chan | 02f7c1d | 2014-10-18 15:18:02 -0700 | [diff] [blame] | 536 | std::unique_ptr<policy::PolicyProvider> policy_provider_; |
Patrick Dubroy | 7fbbe8a | 2011-08-01 17:28:22 +0200 | [diff] [blame] | 537 | |
Jay Srinivasan | 480ddfa | 2012-06-01 19:15:26 -0700 | [diff] [blame] | 538 | // The current scatter factor as found in the policy setting. |
| 539 | base::TimeDelta scatter_factor_; |
| 540 | |
Gilad Arnold | a6dab94 | 2014-04-25 11:46:03 -0700 | [diff] [blame] | 541 | // The number of consecutive failed update checks. Needed for calculating the |
| 542 | // next update check interval. |
| 543 | unsigned int consecutive_failed_update_checks_ = 0; |
| 544 | |
Gilad Arnold | a0258a5 | 2014-07-10 16:21:19 -0700 | [diff] [blame] | 545 | // The poll interval (in seconds) that was dictated by Omaha, if any; zero |
| 546 | // otherwise. This is needed for calculating the update check interval. |
| 547 | unsigned int server_dictated_poll_interval_ = 0; |
| 548 | |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 549 | // Tracks whether we have scheduled update checks. |
| 550 | bool waiting_for_scheduled_check_ = false; |
| 551 | |
| 552 | // A callback to use when a forced update request is either received (true) or |
| 553 | // cleared by an update attempt (false). The second argument indicates whether |
| 554 | // this is an interactive update, and its value is significant iff the first |
| 555 | // argument is true. |
Ben Chan | 02f7c1d | 2014-10-18 15:18:02 -0700 | [diff] [blame] | 556 | std::unique_ptr<base::Callback<void(bool, bool)>> |
Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 557 | forced_update_pending_callback_; |
| 558 | |
| 559 | // The |app_version| and |omaha_url| parameters received during the latest |
| 560 | // forced update request. They are retrieved for use once the update is |
| 561 | // actually scheduled. |
| 562 | std::string forced_app_version_; |
| 563 | std::string forced_omaha_url_; |
Gilad Arnold | 44dc3bf | 2014-07-18 23:39:38 -0700 | [diff] [blame] | 564 | |
Xiaochu Liu | f53a5d3 | 2018-11-26 13:48:59 -0800 | [diff] [blame] | 565 | // A list of DLC module IDs. |
Amin Hassani | 2b68e6b | 2020-04-17 10:49:12 -0700 | [diff] [blame] | 566 | std::vector<std::string> dlc_ids_; |
Xiaochu Liu | 88d9038 | 2018-08-29 16:09:11 -0700 | [diff] [blame] | 567 | // Whether the operation is install (write to the current slot not the |
| 568 | // inactive slot). |
| 569 | bool is_install_; |
| 570 | |
Adolfo Victoria | 497044c | 2018-07-18 07:51:42 -0700 | [diff] [blame] | 571 | // If this is not TimeDelta(), then that means staging is turned on. |
| 572 | base::TimeDelta staging_wait_time_; |
| 573 | chromeos_update_manager::StagingSchedule staging_schedule_; |
| 574 | |
Jae Hoon Kim | edb6550 | 2019-06-14 11:52:17 -0700 | [diff] [blame] | 575 | // This is the session ID used to track update flow to Omaha. |
| 576 | std::string session_id_; |
| 577 | |
Jae Hoon Kim | 5e8e30b | 2020-05-06 14:59:06 -0700 | [diff] [blame] | 578 | // Interface for excluder. |
| 579 | std::unique_ptr<ExcluderInterface> excluder_; |
| 580 | |
Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 581 | DISALLOW_COPY_AND_ASSIGN(UpdateAttempter); |
| 582 | }; |
| 583 | |
Amin Hassani | 7cc8bb0 | 2019-01-14 16:29:47 -0800 | [diff] [blame] | 584 | // Turns a generic ErrorCode::kError to a generic error code specific |
| 585 | // to |action| (e.g., ErrorCode::kFilesystemVerifierError). If |code| is |
| 586 | // not ErrorCode::kError, or the action is not matched, returns |code| |
| 587 | // unchanged. |
| 588 | |
| 589 | ErrorCode GetErrorCodeForAction(AbstractAction* action, ErrorCode code); |
| 590 | |
Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 591 | } // namespace chromeos_update_engine |
| 592 | |
Gilad Arnold | cf175a0 | 2014-07-10 16:48:47 -0700 | [diff] [blame] | 593 | #endif // UPDATE_ENGINE_UPDATE_ATTEMPTER_H_ |