blob: fdbd80a6fcb2fdacb7a54af842f58b94d835c288 [file] [log] [blame]
Darin Petkov73058b42010-10-06 16:32:19 -07001// Copyright (c) 2010 The Chromium OS Authors. All rights reserved.
adlr@google.com3defe6a2009-12-04 20:57:17 +00002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#include "update_engine/omaha_response_handler_action.h"
Darin Petkov73058b42010-10-06 16:32:19 -07006
adlr@google.com3defe6a2009-12-04 20:57:17 +00007#include <string>
Darin Petkov73058b42010-10-06 16:32:19 -07008
9#include <base/logging.h>
10
Darin Petkov0406e402010-10-06 21:33:11 -070011#include "update_engine/delta_performer.h"
Darin Petkov73058b42010-10-06 16:32:19 -070012#include "update_engine/prefs_interface.h"
adlr@google.com3defe6a2009-12-04 20:57:17 +000013#include "update_engine/utils.h"
14
15using std::string;
16
17namespace chromeos_update_engine {
18
Darin Petkov6c118642010-10-21 12:06:30 -070019const char OmahaResponseHandlerAction::kDeadlineFile[] =
20 "/tmp/update-check-response-deadline";
21
adlr@google.com3defe6a2009-12-04 20:57:17 +000022void OmahaResponseHandlerAction::PerformAction() {
23 CHECK(HasInputObject());
24 ScopedActionCompleter completer(processor_, this);
Darin Petkov6a5b3222010-07-13 14:55:28 -070025 const OmahaResponse& response = GetInputObject();
adlr@google.com3defe6a2009-12-04 20:57:17 +000026 if (!response.update_exists) {
Andrew de los Reyes4fe15d02009-12-10 19:01:36 -080027 got_no_update_response_ = true;
adlr@google.com3defe6a2009-12-04 20:57:17 +000028 LOG(INFO) << "There are no updates. Aborting.";
29 return;
30 }
Andrew de los Reyes63b96d72010-05-10 13:08:54 -070031 install_plan_.download_url = response.codebase;
32 install_plan_.size = response.size;
33 install_plan_.download_hash = response.hash;
Darin Petkov0406e402010-10-06 21:33:11 -070034
35 install_plan_.is_resume =
36 DeltaPerformer::CanResumeUpdate(prefs_, response.hash);
37 if (!install_plan_.is_resume) {
Darin Petkov9b230572010-10-08 10:20:09 -070038 LOG_IF(WARNING, !DeltaPerformer::ResetUpdateProgress(prefs_, false))
Darin Petkov0406e402010-10-06 21:33:11 -070039 << "Unable to reset the update progress.";
40 LOG_IF(WARNING, !prefs_->SetString(kPrefsUpdateCheckResponseHash,
41 response.hash))
42 << "Unable to save the update check response hash.";
43 }
44
adlr@google.com3defe6a2009-12-04 20:57:17 +000045 TEST_AND_RETURN(GetInstallDev(
46 (!boot_device_.empty() ? boot_device_ : utils::BootDevice()),
Andrew de los Reyes63b96d72010-05-10 13:08:54 -070047 &install_plan_.install_path));
48 install_plan_.kernel_install_path =
49 utils::BootKernelDevice(install_plan_.install_path);
adlr@google.com3defe6a2009-12-04 20:57:17 +000050
Andrew de los Reyes3270f742010-07-15 22:28:14 -070051 install_plan_.is_full_update = !response.is_delta;
adlr@google.com3defe6a2009-12-04 20:57:17 +000052
Andrew de los Reyesf98bff82010-05-06 13:33:25 -070053 TEST_AND_RETURN(HasOutputPipe());
adlr@google.com3defe6a2009-12-04 20:57:17 +000054 if (HasOutputPipe())
Andrew de los Reyes63b96d72010-05-10 13:08:54 -070055 SetOutputObject(install_plan_);
adlr@google.com3defe6a2009-12-04 20:57:17 +000056 LOG(INFO) << "Using this install plan:";
Andrew de los Reyes63b96d72010-05-10 13:08:54 -070057 install_plan_.Dump();
Darin Petkov6a5b3222010-07-13 14:55:28 -070058
Darin Petkov6c118642010-10-21 12:06:30 -070059 // Send the deadline data (if any) to Chrome through a file. This is a pretty
60 // hacky solution but should be OK for now.
61 //
62 // TODO(petkov): Rearchitect this to avoid communication through a
63 // file. Ideallly, we would include this information in D-Bus's GetStatus
64 // method and UpdateStatus signal. A potential issue is that update_engine may
65 // be unresponsive during an update download.
66 utils::WriteFile(kDeadlineFile,
67 response.deadline.data(),
68 response.deadline.size());
69 chmod(kDeadlineFile, S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH);
70
Darin Petkovc1a8b422010-07-19 11:34:49 -070071 completer.set_code(kActionCodeSuccess);
adlr@google.com3defe6a2009-12-04 20:57:17 +000072}
73
74bool OmahaResponseHandlerAction::GetInstallDev(const std::string& boot_dev,
75 std::string* install_dev) {
Andrew de los Reyesf98bff82010-05-06 13:33:25 -070076 TEST_AND_RETURN_FALSE(utils::StringHasPrefix(boot_dev, "/dev/"));
adlr@google.com3defe6a2009-12-04 20:57:17 +000077 string ret(boot_dev);
Andrew de los Reyesf98bff82010-05-06 13:33:25 -070078 string::reverse_iterator it = ret.rbegin(); // last character in string
79 // Right now, we just switch '3' and '5' partition numbers.
80 TEST_AND_RETURN_FALSE((*it == '3') || (*it == '5'));
81 *it = (*it == '3') ? '5' : '3';
adlr@google.com3defe6a2009-12-04 20:57:17 +000082 *install_dev = ret;
83 return true;
84}
85
86} // namespace chromeos_update_engine