blob: b37960306543b0edd4fac1ffe037b7d0f1ead650 [file] [log] [blame]
Alex Deymoaea4c1c2015-08-19 20:24:43 -07001//
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 Reyes4e9b9f42010-04-26 15:06:43 -070016
17#include "update_engine/dbus_service.h"
Alex Deymofa78f142016-01-26 21:36:16 -080018
Xiaochu Liu88d90382018-08-29 16:09:11 -070019#include <string>
20#include <vector>
21
Amin Hassani9b66aa62019-03-14 14:13:30 -070022#include <dlcservice/proto_bindings/dlcservice.pb.h>
Xiaochu Liu88d90382018-08-29 16:09:11 -070023#include <update_engine/dbus-constants.h>
Xiaochu Liu88d90382018-08-29 16:09:11 -070024
Sen Jiang299128e2016-06-03 17:48:18 -070025#include "update_engine/dbus_connection.h"
Amin Hassanieb463ee2019-06-20 19:23:03 -070026#include "update_engine/proto_bindings/update_engine.pb.h"
Alex Deymofa78f142016-01-26 21:36:16 -080027#include "update_engine/update_status_utils.h"
Don Garrettbb26fc82013-11-15 10:40:17 -080028
Alex Deymob7ca0962014-10-01 17:58:07 -070029namespace chromeos_update_engine {
Don Garrettbb26fc82013-11-15 10:40:17 -080030
Casey Dahlina93cd532016-01-14 16:55:11 -080031using brillo::ErrorPtr;
Casey Dahlina93cd532016-01-14 16:55:11 -080032using chromeos_update_engine::UpdateEngineService;
Amin Hassani3bab1772019-06-21 14:58:25 -070033using dlcservice::DlcModuleList;
Alex Deymofa78f142016-01-26 21:36:16 -080034using std::string;
Xiaochu Liu88d90382018-08-29 16:09:11 -070035using std::vector;
Amin Hassania4417432019-07-08 12:52:40 -070036using update_engine::Operation;
Amin Hassanieb463ee2019-06-20 19:23:03 -070037using update_engine::StatusResult;
Aaron Wood7f92e2b2017-08-28 14:51:21 -070038using update_engine::UpdateEngineStatus;
Amin Hassania4417432019-07-08 12:52:40 -070039using update_engine::UpdateStatus;
Casey Dahlina93cd532016-01-14 16:55:11 -080040
Amin Hassanieb463ee2019-06-20 19:23:03 -070041namespace {
42// Converts the internal |UpdateEngineStatus| to the protobuf |StatusResult|.
43void ConvertToStatusResult(const UpdateEngineStatus& ue_status,
44 StatusResult* out_status) {
45 out_status->set_last_checked_time(ue_status.last_checked_time);
46 out_status->set_progress(ue_status.progress);
Amin Hassania4417432019-07-08 12:52:40 -070047 out_status->set_current_operation(static_cast<Operation>(ue_status.status));
Amin Hassanieb463ee2019-06-20 19:23:03 -070048 out_status->set_new_version(ue_status.new_version);
49 out_status->set_new_size(ue_status.new_size_bytes);
Jae Hoon Kim2f78c1c2019-07-25 13:20:43 -070050 out_status->set_is_install(ue_status.is_install);
Amin Hassanieb463ee2019-06-20 19:23:03 -070051}
52} // namespace
53
Casey Dahlina93cd532016-01-14 16:55:11 -080054DBusUpdateEngineService::DBusUpdateEngineService(SystemState* system_state)
Amin Hassani7cc8bb02019-01-14 16:29:47 -080055 : common_(new UpdateEngineService{system_state}) {}
Don Garrettbb26fc82013-11-15 10:40:17 -080056
Alex Deymob7ca0962014-10-01 17:58:07 -070057// org::chromium::UpdateEngineInterfaceInterface methods implementation.
Don Garrettbb26fc82013-11-15 10:40:17 -080058
Casey Dahlina93cd532016-01-14 16:55:11 -080059bool DBusUpdateEngineService::AttemptUpdate(ErrorPtr* error,
60 const string& in_app_version,
61 const string& in_omaha_url) {
Alex Deymob7ca0962014-10-01 17:58:07 -070062 return AttemptUpdateWithFlags(
63 error, in_app_version, in_omaha_url, 0 /* no flags */);
Don Garrettbb26fc82013-11-15 10:40:17 -080064}
65
Casey Dahlina93cd532016-01-14 16:55:11 -080066bool DBusUpdateEngineService::AttemptUpdateWithFlags(
67 ErrorPtr* error,
68 const string& in_app_version,
69 const string& in_omaha_url,
70 int32_t in_flags_as_int) {
71 update_engine::AttemptUpdateFlags flags =
72 static_cast<update_engine::AttemptUpdateFlags>(in_flags_as_int);
Amin Hassani6bb001f2018-02-26 14:33:02 -080073 bool interactive = !(flags & update_engine::kAttemptUpdateFlagNonInteractive);
74 bool result;
Casey Dahlina93cd532016-01-14 16:55:11 -080075 return common_->AttemptUpdate(
Amin Hassani0eae4272018-06-01 11:31:34 -070076 error,
77 in_app_version,
78 in_omaha_url,
79 interactive ? 0 : update_engine::UpdateAttemptFlags::kFlagNonInteractive,
80 &result);
Darin Petkov296889c2010-07-23 16:20:54 -070081}
82
Xiaochu Liu88d90382018-08-29 16:09:11 -070083bool DBusUpdateEngineService::AttemptInstall(ErrorPtr* error,
Amin Hassani3bab1772019-06-21 14:58:25 -070084 const DlcModuleList& request) {
Amin Hassani9b66aa62019-03-14 14:13:30 -070085 vector<string> dlc_ids;
Amin Hassani3bab1772019-06-21 14:58:25 -070086 for (const auto& dlc_module_info : request.dlc_module_infos()) {
Amin Hassani9b66aa62019-03-14 14:13:30 -070087 if (dlc_module_info.dlc_id().empty()) {
Xiaochu Liu88d90382018-08-29 16:09:11 -070088 *error = brillo::Error::Create(
Amin Hassani3bab1772019-06-21 14:58:25 -070089 FROM_HERE, "update_engine", "INTERNAL", "Empty DLC ID passed.");
Xiaochu Liu88d90382018-08-29 16:09:11 -070090 return false;
91 }
Amin Hassani9b66aa62019-03-14 14:13:30 -070092 dlc_ids.push_back(dlc_module_info.dlc_id());
Xiaochu Liu88d90382018-08-29 16:09:11 -070093 }
Amin Hassani3bab1772019-06-21 14:58:25 -070094 return common_->AttemptInstall(error, request.omaha_url(), dlc_ids);
Xiaochu Liu88d90382018-08-29 16:09:11 -070095}
96
Casey Dahlina93cd532016-01-14 16:55:11 -080097bool DBusUpdateEngineService::AttemptRollback(ErrorPtr* error,
98 bool in_powerwash) {
99 return common_->AttemptRollback(error, in_powerwash);
Chris Sosad317e402013-06-12 13:47:09 -0700100}
101
Casey Dahlina93cd532016-01-14 16:55:11 -0800102bool DBusUpdateEngineService::CanRollback(ErrorPtr* error,
103 bool* out_can_rollback) {
104 return common_->CanRollback(error, out_can_rollback);
Alex Vakulenko2bddadd2014-03-27 13:23:46 -0700105}
106
Casey Dahlina93cd532016-01-14 16:55:11 -0800107bool DBusUpdateEngineService::ResetStatus(ErrorPtr* error) {
108 return common_->ResetStatus(error);
Don Garrettbb26fc82013-11-15 10:40:17 -0800109}
Jay Srinivasanc1ba09a2012-08-14 14:15:57 -0700110
Casey Dahlina93cd532016-01-14 16:55:11 -0800111bool DBusUpdateEngineService::GetStatus(ErrorPtr* error,
112 int64_t* out_last_checked_time,
113 double* out_progress,
114 string* out_current_operation,
115 string* out_new_version,
116 int64_t* out_new_size) {
Amin Hassani6bb001f2018-02-26 14:33:02 -0800117 UpdateEngineStatus status;
118 if (!common_->GetStatus(error, &status)) {
119 return false;
120 }
121 *out_last_checked_time = status.last_checked_time;
122 *out_progress = status.progress;
123 *out_current_operation = UpdateStatusToString(status.status);
124 *out_new_version = status.new_version;
125 *out_new_size = status.new_size_bytes;
126 return true;
Andrew de los Reyes4e9b9f42010-04-26 15:06:43 -0700127}
128
Amin Hassanieb463ee2019-06-20 19:23:03 -0700129bool DBusUpdateEngineService::GetStatusAdvanced(ErrorPtr* error,
130 StatusResult* out_status) {
131 UpdateEngineStatus status;
132 if (!common_->GetStatus(error, &status)) {
133 return false;
134 }
135
136 ConvertToStatusResult(status, out_status);
137 return true;
138}
139
Casey Dahlina93cd532016-01-14 16:55:11 -0800140bool DBusUpdateEngineService::RebootIfNeeded(ErrorPtr* error) {
141 return common_->RebootIfNeeded(error);
Andrew de los Reyes63b96d72010-05-10 13:08:54 -0700142}
143
Casey Dahlina93cd532016-01-14 16:55:11 -0800144bool DBusUpdateEngineService::SetChannel(ErrorPtr* error,
145 const string& in_target_channel,
146 bool in_is_powerwash_allowed) {
147 return common_->SetChannel(error, in_target_channel, in_is_powerwash_allowed);
Jay Srinivasanae4697c2013-03-18 17:08:08 -0700148}
149
Casey Dahlina93cd532016-01-14 16:55:11 -0800150bool DBusUpdateEngineService::GetChannel(ErrorPtr* error,
151 bool in_get_current_channel,
152 string* out_channel) {
153 return common_->GetChannel(error, in_get_current_channel, out_channel);
Darin Petkov8daa3242010-10-25 13:28:47 -0700154}
155
Alex Deymo5b5fa8b2016-10-06 15:40:49 -0700156bool DBusUpdateEngineService::GetCohortHint(ErrorPtr* error,
157 string* out_cohort_hint) {
158 return common_->GetCohortHint(error, out_cohort_hint);
159}
160
161bool DBusUpdateEngineService::SetCohortHint(ErrorPtr* error,
162 const string& in_cohort_hint) {
163 return common_->SetCohortHint(error, in_cohort_hint);
164}
165
Casey Dahlina93cd532016-01-14 16:55:11 -0800166bool DBusUpdateEngineService::SetP2PUpdatePermission(ErrorPtr* error,
167 bool in_enabled) {
168 return common_->SetP2PUpdatePermission(error, in_enabled);
Alex Deymo5fdf7762013-07-17 20:01:40 -0700169}
170
Casey Dahlina93cd532016-01-14 16:55:11 -0800171bool DBusUpdateEngineService::GetP2PUpdatePermission(ErrorPtr* error,
172 bool* out_enabled) {
173 return common_->GetP2PUpdatePermission(error, out_enabled);
Alex Deymo5fdf7762013-07-17 20:01:40 -0700174}
175
Casey Dahlina93cd532016-01-14 16:55:11 -0800176bool DBusUpdateEngineService::SetUpdateOverCellularPermission(ErrorPtr* error,
177 bool in_allowed) {
178 return common_->SetUpdateOverCellularPermission(error, in_allowed);
Alex Deymof4867c42013-06-28 14:41:39 -0700179}
180
Weidong Guo421ff332017-04-17 10:08:38 -0700181bool DBusUpdateEngineService::SetUpdateOverCellularTarget(
182 brillo::ErrorPtr* error,
183 const std::string& target_version,
184 int64_t target_size) {
185 return common_->SetUpdateOverCellularTarget(
186 error, target_version, target_size);
187}
188
Casey Dahlina93cd532016-01-14 16:55:11 -0800189bool DBusUpdateEngineService::GetUpdateOverCellularPermission(
190 ErrorPtr* error, bool* out_allowed) {
191 return common_->GetUpdateOverCellularPermission(error, out_allowed);
Alex Deymof4867c42013-06-28 14:41:39 -0700192}
193
Casey Dahlina93cd532016-01-14 16:55:11 -0800194bool DBusUpdateEngineService::GetDurationSinceUpdate(
195 ErrorPtr* error, int64_t* out_usec_wallclock) {
196 return common_->GetDurationSinceUpdate(error, out_usec_wallclock);
David Zeuthen3c55abd2013-10-14 12:48:03 -0700197}
198
Casey Dahlina93cd532016-01-14 16:55:11 -0800199bool DBusUpdateEngineService::GetPrevVersion(ErrorPtr* error,
200 string* out_prev_version) {
201 return common_->GetPrevVersion(error, out_prev_version);
Andrew de los Reyes63b96d72010-05-10 13:08:54 -0700202}
Alex Vakulenkodea2eac2014-03-14 15:56:59 -0700203
Casey Dahlina93cd532016-01-14 16:55:11 -0800204bool DBusUpdateEngineService::GetRollbackPartition(
205 ErrorPtr* error, string* out_rollback_partition_name) {
206 return common_->GetRollbackPartition(error, out_rollback_partition_name);
Alex Deymob7ca0962014-10-01 17:58:07 -0700207}
208
Shuqian Zhao29971732016-02-05 11:29:32 -0800209bool DBusUpdateEngineService::GetLastAttemptError(
Alex Deymob3fa53b2016-04-18 19:57:58 -0700210 ErrorPtr* error, int32_t* out_last_attempt_error) {
211 return common_->GetLastAttemptError(error, out_last_attempt_error);
212}
213
214bool DBusUpdateEngineService::GetEolStatus(ErrorPtr* error,
215 int32_t* out_eol_status) {
216 return common_->GetEolStatus(error, out_eol_status);
Shuqian Zhao29971732016-02-05 11:29:32 -0800217}
218
Sen Jiang299128e2016-06-03 17:48:18 -0700219UpdateEngineAdaptor::UpdateEngineAdaptor(SystemState* system_state)
Alex Deymob7ca0962014-10-01 17:58:07 -0700220 : org::chromium::UpdateEngineInterfaceAdaptor(&dbus_service_),
Sen Jiang299128e2016-06-03 17:48:18 -0700221 bus_(DBusConnection::Get()->GetDBus()),
222 dbus_service_(system_state),
223 dbus_object_(nullptr,
224 bus_,
225 dbus::ObjectPath(update_engine::kUpdateEngineServicePath)) {}
Alex Deymob7ca0962014-10-01 17:58:07 -0700226
227void UpdateEngineAdaptor::RegisterAsync(
228 const base::Callback<void(bool)>& completion_callback) {
229 RegisterWithDBusObject(&dbus_object_);
230 dbus_object_.RegisterAsync(completion_callback);
231}
232
233bool UpdateEngineAdaptor::RequestOwnership() {
Alex Deymod6deb1d2015-08-28 15:54:37 -0700234 return bus_->RequestOwnershipAndBlock(update_engine::kUpdateEngineServiceName,
Alex Deymob7ca0962014-10-01 17:58:07 -0700235 dbus::Bus::REQUIRE_PRIMARY);
236}
237
Aaron Wood7f92e2b2017-08-28 14:51:21 -0700238void UpdateEngineAdaptor::SendStatusUpdate(
239 const UpdateEngineStatus& update_engine_status) {
Amin Hassanieb463ee2019-06-20 19:23:03 -0700240 StatusResult status;
241 ConvertToStatusResult(update_engine_status, &status);
242
243 // TODO(crbug.com/977320): Deprecate |StatusUpdate| signal.
244 SendStatusUpdateSignal(status.last_checked_time(),
245 status.progress(),
Amin Hassania4417432019-07-08 12:52:40 -0700246 UpdateStatusToString(static_cast<UpdateStatus>(
247 status.current_operation())),
Amin Hassanieb463ee2019-06-20 19:23:03 -0700248 status.new_version(),
249 status.new_size());
250
251 // Send |StatusUpdateAdvanced| signal.
252 SendStatusUpdateAdvancedSignal(status);
Alex Deymofa78f142016-01-26 21:36:16 -0800253}
254
Alex Deymob7ca0962014-10-01 17:58:07 -0700255} // namespace chromeos_update_engine