| 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_ |