| Mike Frysinger | 8155d08 | 2012-04-06 15:23:18 -0400 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium OS Authors. All rights reserved. | 
| rspangler@google.com | 49fdf18 | 2009-10-10 00:57:34 +0000 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be | 
|  | 3 | // found in the LICENSE file. | 
|  | 4 |  | 
| Alex Deymo | 67363ee | 2014-09-23 23:07:44 -0700 | [diff] [blame] | 5 | #include <unistd.h> | 
|  | 6 |  | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 7 | #include <string> | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 8 | #include <vector> | 
| Darin Petkov | 9d65b7b | 2010-07-20 09:13:01 -0700 | [diff] [blame] | 9 |  | 
| Darin Petkov | 1023a60 | 2010-08-30 13:47:51 -0700 | [diff] [blame] | 10 | #include <base/at_exit.h> | 
|  | 11 | #include <base/command_line.h> | 
| Ben Chan | 06c76a4 | 2014-09-05 08:21:06 -0700 | [diff] [blame] | 12 | #include <base/files/file_util.h> | 
| Darin Petkov | 1023a60 | 2010-08-30 13:47:51 -0700 | [diff] [blame] | 13 | #include <base/logging.h> | 
| Alex Vakulenko | 75039d7 | 2014-03-25 12:36:28 -0700 | [diff] [blame] | 14 | #include <base/strings/string_util.h> | 
|  | 15 | #include <base/strings/stringprintf.h> | 
| Alex Deymo | 67363ee | 2014-09-23 23:07:44 -0700 | [diff] [blame] | 16 | #include <base/time/time.h> | 
| Steve Fung | d570820 | 2014-09-28 23:24:06 -0700 | [diff] [blame] | 17 | #include <chromeos/flag_helper.h> | 
| rspangler@google.com | 49fdf18 | 2009-10-10 00:57:34 +0000 | [diff] [blame] | 18 | #include <glib.h> | 
| Darin Petkov | 1023a60 | 2010-08-30 13:47:51 -0700 | [diff] [blame] | 19 | #include <metrics/metrics_library.h> | 
| Chris Masone | 4dc2ada | 2010-09-23 12:43:03 -0700 | [diff] [blame] | 20 | #include <sys/stat.h> | 
| Alex Deymo | 44666f9 | 2014-07-22 20:29:24 -0700 | [diff] [blame] | 21 | #include <sys/types.h> | 
| Darin Petkov | 9d65b7b | 2010-07-20 09:13:01 -0700 | [diff] [blame] | 22 |  | 
| Bruno Rocha | 7f9aea2 | 2011-09-12 14:31:24 -0700 | [diff] [blame] | 23 | #include "update_engine/certificate_checker.h" | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 24 | #include "update_engine/dbus_constants.h" | 
|  | 25 | #include "update_engine/dbus_service.h" | 
| Gilad Arnold | 1b9d6ae | 2014-03-03 13:46:07 -0800 | [diff] [blame] | 26 | #include "update_engine/dbus_wrapper_interface.h" | 
| Alex Deymo | 44666f9 | 2014-07-22 20:29:24 -0700 | [diff] [blame] | 27 | #include "update_engine/glib_utils.h" | 
| Jay Srinivasan | 55f50c2 | 2013-01-10 19:24:35 -0800 | [diff] [blame] | 28 | #include "update_engine/real_system_state.h" | 
| Andrew de los Reyes | 3d6a209 | 2010-08-23 18:23:26 -0700 | [diff] [blame] | 29 | #include "update_engine/subprocess.h" | 
| Darin Petkov | 9c0baf8 | 2010-10-07 13:44:48 -0700 | [diff] [blame] | 30 | #include "update_engine/terminator.h" | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 31 | #include "update_engine/update_attempter.h" | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 32 | extern "C" { | 
| Timothy Jennison | 08d4931 | 2015-03-04 13:46:40 -0500 | [diff] [blame] | 33 | #include "update_engine/org.chromium.UpdateEngineInterface.dbusserver.h" | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 34 | } | 
| Alex Vakulenko | 44cab30 | 2014-07-23 13:12:15 -0700 | [diff] [blame] | 35 | #include "update_engine/utils.h" | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 36 |  | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 37 | using std::string; | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 38 | using std::vector; | 
|  | 39 |  | 
| Alex Deymo | 67363ee | 2014-09-23 23:07:44 -0700 | [diff] [blame] | 40 | namespace { | 
|  | 41 | const int kDBusSystemMaxWaitSeconds = 2 * 60; | 
|  | 42 | }  // namespace | 
|  | 43 |  | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 44 | namespace chromeos_update_engine { | 
|  | 45 |  | 
| Andrew de los Reyes | 3d6a209 | 2010-08-23 18:23:26 -0700 | [diff] [blame] | 46 | gboolean UpdateBootFlags(void* arg) { | 
| Darin Petkov | 61635a9 | 2011-05-18 16:20:36 -0700 | [diff] [blame] | 47 | reinterpret_cast<UpdateAttempter*>(arg)->UpdateBootFlags(); | 
|  | 48 | return FALSE;  // Don't call this callback again | 
|  | 49 | } | 
|  | 50 |  | 
|  | 51 | gboolean BroadcastStatus(void* arg) { | 
|  | 52 | reinterpret_cast<UpdateAttempter*>(arg)->BroadcastStatus(); | 
| Andrew de los Reyes | 3d6a209 | 2010-08-23 18:23:26 -0700 | [diff] [blame] | 53 | return FALSE;  // Don't call this callback again | 
|  | 54 | } | 
|  | 55 |  | 
| David Zeuthen | e4c58bf | 2013-06-18 17:26:50 -0700 | [diff] [blame] | 56 | gboolean UpdateEngineStarted(gpointer user_data) { | 
|  | 57 | reinterpret_cast<UpdateAttempter*>(user_data)->UpdateEngineStarted(); | 
| Alex Vakulenko | d2779df | 2014-06-16 13:19:00 -0700 | [diff] [blame] | 58 | return FALSE;  // Remove idle source (e.g. don't do the callback again) | 
| David Zeuthen | e4c58bf | 2013-06-18 17:26:50 -0700 | [diff] [blame] | 59 | } | 
|  | 60 |  | 
| Andrew de los Reyes | 7352067 | 2010-05-10 13:44:58 -0700 | [diff] [blame] | 61 | namespace { | 
|  | 62 |  | 
| Alex Deymo | 67363ee | 2014-09-23 23:07:44 -0700 | [diff] [blame] | 63 | // Wait for DBus to be ready by attempting to get the system bus up to | 
|  | 64 | // |timeout| time. Returns whether it succeeded to get the bus. | 
|  | 65 | bool WaitForDBusSystem(base::TimeDelta timeout) { | 
|  | 66 | GError *error = nullptr; | 
|  | 67 | DBusGConnection *bus = nullptr; | 
|  | 68 | Clock clock; | 
|  | 69 | base::Time deadline = clock.GetMonotonicTime() + timeout; | 
|  | 70 |  | 
|  | 71 | while (clock.GetMonotonicTime() < deadline) { | 
|  | 72 | bus = dbus_g_bus_get(DBUS_BUS_SYSTEM, &error); | 
|  | 73 | if (bus) | 
|  | 74 | return true; | 
|  | 75 | LOG(WARNING) << "Failed to get system bus, waiting: " | 
|  | 76 | << utils::GetAndFreeGError(&error); | 
|  | 77 | // Wait 1 second. | 
|  | 78 | sleep(1); | 
|  | 79 | } | 
|  | 80 | LOG(ERROR) << "Failed to get system bus after " << timeout.InSeconds() | 
|  | 81 | << " seconds."; | 
|  | 82 | return false; | 
|  | 83 | } | 
|  | 84 |  | 
|  | 85 | void SetupDBusService(UpdateEngineService* service) { | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 86 | DBusGConnection *bus; | 
|  | 87 | DBusGProxy *proxy; | 
| Alex Vakulenko | 75039d7 | 2014-03-25 12:36:28 -0700 | [diff] [blame] | 88 | GError *error = nullptr; | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 89 |  | 
|  | 90 | bus = dbus_g_bus_get(DBUS_BUS_SYSTEM, &error); | 
| Darin Petkov | a0b9e77 | 2011-10-06 05:05:56 -0700 | [diff] [blame] | 91 | LOG_IF(FATAL, !bus) << "Failed to get bus: " | 
|  | 92 | << utils::GetAndFreeGError(&error); | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 93 | proxy = dbus_g_proxy_new_for_name(bus, | 
|  | 94 | DBUS_SERVICE_DBUS, | 
|  | 95 | DBUS_PATH_DBUS, | 
|  | 96 | DBUS_INTERFACE_DBUS); | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 97 | guint32 request_name_ret; | 
|  | 98 | if (!org_freedesktop_DBus_request_name(proxy, | 
|  | 99 | kUpdateEngineServiceName, | 
|  | 100 | 0, | 
|  | 101 | &request_name_ret, | 
|  | 102 | &error)) { | 
| Darin Petkov | a0b9e77 | 2011-10-06 05:05:56 -0700 | [diff] [blame] | 103 | LOG(FATAL) << "Failed to get name: " << utils::GetAndFreeGError(&error); | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 104 | } | 
|  | 105 | if (request_name_ret != DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER) { | 
|  | 106 | g_warning("Got result code %u from requesting name", request_name_ret); | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 107 | LOG(FATAL) << "Got result code " << request_name_ret | 
|  | 108 | << " from requesting name, but expected " | 
|  | 109 | << DBUS_REQUEST_NAME_REPLY_PRIMARY_OWNER; | 
|  | 110 | } | 
|  | 111 | dbus_g_connection_register_g_object(bus, | 
|  | 112 | "/org/chromium/UpdateEngine", | 
|  | 113 | G_OBJECT(service)); | 
|  | 114 | } | 
|  | 115 |  | 
| Darin Petkov | 30291ed | 2010-11-12 10:23:06 -0800 | [diff] [blame] | 116 | void SetupLogSymlink(const string& symlink_path, const string& log_path) { | 
|  | 117 | // TODO(petkov): To ensure a smooth transition between non-timestamped and | 
|  | 118 | // timestamped logs, move an existing log to start the first timestamped | 
|  | 119 | // one. This code can go away once all clients are switched to this version or | 
|  | 120 | // we stop caring about the old-style logs. | 
|  | 121 | if (utils::FileExists(symlink_path.c_str()) && | 
|  | 122 | !utils::IsSymlink(symlink_path.c_str())) { | 
| Alex Vakulenko | 75039d7 | 2014-03-25 12:36:28 -0700 | [diff] [blame] | 123 | base::ReplaceFile(base::FilePath(symlink_path), | 
|  | 124 | base::FilePath(log_path), | 
|  | 125 | nullptr); | 
| Darin Petkov | 30291ed | 2010-11-12 10:23:06 -0800 | [diff] [blame] | 126 | } | 
| Alex Vakulenko | 75039d7 | 2014-03-25 12:36:28 -0700 | [diff] [blame] | 127 | base::DeleteFile(base::FilePath(symlink_path), true); | 
| Darin Petkov | 30291ed | 2010-11-12 10:23:06 -0800 | [diff] [blame] | 128 | if (symlink(log_path.c_str(), symlink_path.c_str()) == -1) { | 
|  | 129 | PLOG(ERROR) << "Unable to create symlink " << symlink_path | 
|  | 130 | << " pointing at " << log_path; | 
|  | 131 | } | 
|  | 132 | } | 
|  | 133 |  | 
|  | 134 | string GetTimeAsString(time_t utime) { | 
|  | 135 | struct tm tm; | 
| Alex Vakulenko | d2779df | 2014-06-16 13:19:00 -0700 | [diff] [blame] | 136 | CHECK_EQ(localtime_r(&utime, &tm), &tm); | 
| Darin Petkov | 30291ed | 2010-11-12 10:23:06 -0800 | [diff] [blame] | 137 | char str[16]; | 
| Alex Vakulenko | d2779df | 2014-06-16 13:19:00 -0700 | [diff] [blame] | 138 | CHECK_EQ(strftime(str, sizeof(str), "%Y%m%d-%H%M%S", &tm), 15u); | 
| Darin Petkov | 30291ed | 2010-11-12 10:23:06 -0800 | [diff] [blame] | 139 | return str; | 
|  | 140 | } | 
|  | 141 |  | 
|  | 142 | string SetupLogFile(const string& kLogsRoot) { | 
|  | 143 | const string kLogSymlink = kLogsRoot + "/update_engine.log"; | 
|  | 144 | const string kLogsDir = kLogsRoot + "/update_engine"; | 
|  | 145 | const string kLogPath = | 
| Alex Vakulenko | 75039d7 | 2014-03-25 12:36:28 -0700 | [diff] [blame] | 146 | base::StringPrintf("%s/update_engine.%s", | 
|  | 147 | kLogsDir.c_str(), | 
|  | 148 | GetTimeAsString(::time(nullptr)).c_str()); | 
| Darin Petkov | 30291ed | 2010-11-12 10:23:06 -0800 | [diff] [blame] | 149 | mkdir(kLogsDir.c_str(), 0755); | 
|  | 150 | SetupLogSymlink(kLogSymlink, kLogPath); | 
|  | 151 | return kLogSymlink; | 
|  | 152 | } | 
|  | 153 |  | 
| Steve Fung | d570820 | 2014-09-28 23:24:06 -0700 | [diff] [blame] | 154 | void SetupLogging(bool log_to_std_err) { | 
| Alex Deymo | d603ba9 | 2014-10-03 14:51:33 -0700 | [diff] [blame] | 155 | string log_file; | 
| Alex Vakulenko | 75039d7 | 2014-03-25 12:36:28 -0700 | [diff] [blame] | 156 | logging::LoggingSettings log_settings; | 
|  | 157 | log_settings.lock_log = logging::DONT_LOCK_LOG_FILE; | 
|  | 158 | log_settings.delete_old = logging::APPEND_TO_OLD_LOG_FILE; | 
| Alex Vakulenko | 75039d7 | 2014-03-25 12:36:28 -0700 | [diff] [blame] | 159 |  | 
| Steve Fung | d570820 | 2014-09-28 23:24:06 -0700 | [diff] [blame] | 160 | if (log_to_std_err) { | 
| Alex Vakulenko | 75039d7 | 2014-03-25 12:36:28 -0700 | [diff] [blame] | 161 | // Log to stderr initially. | 
|  | 162 | log_settings.log_file = nullptr; | 
|  | 163 | log_settings.logging_dest = logging::LOG_TO_SYSTEM_DEBUG_LOG; | 
|  | 164 | } else { | 
| Alex Deymo | d603ba9 | 2014-10-03 14:51:33 -0700 | [diff] [blame] | 165 | log_file = SetupLogFile("/var/log"); | 
| Alex Vakulenko | 75039d7 | 2014-03-25 12:36:28 -0700 | [diff] [blame] | 166 | log_settings.log_file = log_file.c_str(); | 
|  | 167 | log_settings.logging_dest = logging::LOG_TO_FILE; | 
| Darin Petkov | 30291ed | 2010-11-12 10:23:06 -0800 | [diff] [blame] | 168 | } | 
| Alex Vakulenko | 75039d7 | 2014-03-25 12:36:28 -0700 | [diff] [blame] | 169 |  | 
|  | 170 | logging::InitLogging(log_settings); | 
| Darin Petkov | 30291ed | 2010-11-12 10:23:06 -0800 | [diff] [blame] | 171 | } | 
| Andrew de los Reyes | 000d895 | 2011-03-02 15:21:14 -0800 | [diff] [blame] | 172 |  | 
| Alex Vakulenko | d2779df | 2014-06-16 13:19:00 -0700 | [diff] [blame] | 173 | }  // namespace | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 174 | }  // namespace chromeos_update_engine | 
| rspangler@google.com | 49fdf18 | 2009-10-10 00:57:34 +0000 | [diff] [blame] | 175 |  | 
| rspangler@google.com | 49fdf18 | 2009-10-10 00:57:34 +0000 | [diff] [blame] | 176 | int main(int argc, char** argv) { | 
| Steve Fung | d570820 | 2014-09-28 23:24:06 -0700 | [diff] [blame] | 177 | DEFINE_bool(logtostderr, false, | 
|  | 178 | "Write logs to stderr instead of to a file in log_dir."); | 
|  | 179 | DEFINE_bool(foreground, false, | 
|  | 180 | "Don't daemon()ize; run in foreground."); | 
|  | 181 |  | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 182 | ::g_type_init(); | 
| Ben Chan | 46bf5c8 | 2013-06-24 11:17:41 -0700 | [diff] [blame] | 183 | dbus_threads_init_default(); | 
| Darin Petkov | 5c0a8af | 2010-08-24 13:39:13 -0700 | [diff] [blame] | 184 | base::AtExitManager exit_manager;  // Required for base/rand_util.h. | 
| Darin Petkov | 9c0baf8 | 2010-10-07 13:44:48 -0700 | [diff] [blame] | 185 | chromeos_update_engine::Terminator::Init(); | 
| adlr@google.com | c98a7ed | 2009-12-04 18:54:03 +0000 | [diff] [blame] | 186 | chromeos_update_engine::Subprocess::Init(); | 
| Steve Fung | d570820 | 2014-09-28 23:24:06 -0700 | [diff] [blame] | 187 | chromeos::FlagHelper::Init(argc, argv, "Chromium OS Update Engine"); | 
|  | 188 | chromeos_update_engine::SetupLogging(FLAGS_logtostderr); | 
| Andrew de los Reyes | 6b78e29 | 2010-05-10 15:54:39 -0700 | [diff] [blame] | 189 | if (!FLAGS_foreground) | 
|  | 190 | PLOG_IF(FATAL, daemon(0, 0) == 1) << "daemon() failed"; | 
|  | 191 |  | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 192 | LOG(INFO) << "Chrome OS Update Engine starting"; | 
| Darin Petkov | a4a8a8c | 2010-07-15 22:21:12 -0700 | [diff] [blame] | 193 |  | 
| Chris Masone | 4dc2ada | 2010-09-23 12:43:03 -0700 | [diff] [blame] | 194 | // Ensure that all written files have safe permissions. | 
|  | 195 | // This is a mask, so we _block_ execute for the owner, and ALL | 
|  | 196 | // permissions for other users. | 
|  | 197 | // Done _after_ log file creation. | 
|  | 198 | umask(S_IXUSR | S_IRWXG | S_IRWXO); | 
|  | 199 |  | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 200 | // Create the single GMainLoop | 
| Andrew de los Reyes | 63b96d7 | 2010-05-10 13:08:54 -0700 | [diff] [blame] | 201 | GMainLoop* loop = g_main_loop_new(g_main_context_default(), FALSE); | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 202 |  | 
| Alex Deymo | 67363ee | 2014-09-23 23:07:44 -0700 | [diff] [blame] | 203 | // Wait up to 2 minutes for DBus to be ready. | 
|  | 204 | LOG_IF(FATAL, !chromeos_update_engine::WaitForDBusSystem( | 
|  | 205 | base::TimeDelta::FromSeconds(kDBusSystemMaxWaitSeconds))) | 
|  | 206 | << "Failed to initialize DBus, aborting."; | 
|  | 207 |  | 
| Jay Srinivasan | f057205 | 2012-10-23 18:12:56 -0700 | [diff] [blame] | 208 | chromeos_update_engine::RealSystemState real_system_state; | 
| Nam T. Nguyen | 7d623eb | 2014-05-13 16:06:28 -0700 | [diff] [blame] | 209 | LOG_IF(ERROR, !real_system_state.Initialize()) | 
| Jay Srinivasan | 6f6ea00 | 2012-12-14 11:26:28 -0800 | [diff] [blame] | 210 | << "Failed to initialize system state."; | 
| Jay Srinivasan | 55f50c2 | 2013-01-10 19:24:35 -0800 | [diff] [blame] | 211 | chromeos_update_engine::UpdateAttempter *update_attempter = | 
|  | 212 | real_system_state.update_attempter(); | 
|  | 213 | CHECK(update_attempter); | 
| Darin Petkov | 9d65b7b | 2010-07-20 09:13:01 -0700 | [diff] [blame] | 214 |  | 
| Bruno Rocha | 7f9aea2 | 2011-09-12 14:31:24 -0700 | [diff] [blame] | 215 | // Sets static members for the certificate checker. | 
| Jay Srinivasan | 6f6ea00 | 2012-12-14 11:26:28 -0800 | [diff] [blame] | 216 | chromeos_update_engine::CertificateChecker::set_system_state( | 
|  | 217 | &real_system_state); | 
| Bruno Rocha | 7f9aea2 | 2011-09-12 14:31:24 -0700 | [diff] [blame] | 218 | chromeos_update_engine::OpenSSLWrapper openssl_wrapper; | 
|  | 219 | chromeos_update_engine::CertificateChecker::set_openssl_wrapper( | 
|  | 220 | &openssl_wrapper); | 
|  | 221 |  | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 222 | // Create the dbus service object: | 
|  | 223 | dbus_g_object_type_install_info(UPDATE_ENGINE_TYPE_SERVICE, | 
|  | 224 | &dbus_glib_update_engine_service_object_info); | 
| Alex Deymo | 7e8ac06 | 2014-05-01 12:56:58 -0700 | [diff] [blame] | 225 | UpdateEngineService* service = update_engine_service_new(); | 
| Jay Srinivasan | ae4697c | 2013-03-18 17:08:08 -0700 | [diff] [blame] | 226 | service->system_state_ = &real_system_state; | 
| Jay Srinivasan | 55f50c2 | 2013-01-10 19:24:35 -0800 | [diff] [blame] | 227 | update_attempter->set_dbus_service(service); | 
| Alex Deymo | 67363ee | 2014-09-23 23:07:44 -0700 | [diff] [blame] | 228 | chromeos_update_engine::SetupDBusService(service); | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 229 |  | 
| Gilad Arnold | ec7f916 | 2014-07-15 13:24:46 -0700 | [diff] [blame] | 230 | // Initiate update checks. | 
|  | 231 | update_attempter->ScheduleUpdates(); | 
| Andrew de los Reyes | 7352067 | 2010-05-10 13:44:58 -0700 | [diff] [blame] | 232 |  | 
| Darin Petkov | eee26ee | 2010-10-22 11:05:46 -0700 | [diff] [blame] | 233 | // Update boot flags after 45 seconds. | 
|  | 234 | g_timeout_add_seconds(45, | 
|  | 235 | &chromeos_update_engine::UpdateBootFlags, | 
| Jay Srinivasan | 55f50c2 | 2013-01-10 19:24:35 -0800 | [diff] [blame] | 236 | update_attempter); | 
| Andrew de los Reyes | 3d6a209 | 2010-08-23 18:23:26 -0700 | [diff] [blame] | 237 |  | 
| Darin Petkov | 61635a9 | 2011-05-18 16:20:36 -0700 | [diff] [blame] | 238 | // Broadcast the update engine status on startup to ensure consistent system | 
|  | 239 | // state on crashes. | 
| Jay Srinivasan | 55f50c2 | 2013-01-10 19:24:35 -0800 | [diff] [blame] | 240 | g_idle_add(&chromeos_update_engine::BroadcastStatus, update_attempter); | 
| Darin Petkov | 61635a9 | 2011-05-18 16:20:36 -0700 | [diff] [blame] | 241 |  | 
| David Zeuthen | e4c58bf | 2013-06-18 17:26:50 -0700 | [diff] [blame] | 242 | // Run the UpdateEngineStarted() method on |update_attempter|. | 
|  | 243 | g_idle_add(&chromeos_update_engine::UpdateEngineStarted, update_attempter); | 
|  | 244 |  | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 245 | // Run the main loop until exit time: | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 246 | g_main_loop_run(loop); | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 247 |  | 
|  | 248 | // Cleanup: | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 249 | g_main_loop_unref(loop); | 
| Alex Vakulenko | 75039d7 | 2014-03-25 12:36:28 -0700 | [diff] [blame] | 250 | update_attempter->set_dbus_service(nullptr); | 
| Andrew de los Reyes | 4e9b9f4 | 2010-04-26 15:06:43 -0700 | [diff] [blame] | 251 | g_object_unref(G_OBJECT(service)); | 
| Andrew de los Reyes | 4fe15d0 | 2009-12-10 19:01:36 -0800 | [diff] [blame] | 252 |  | 
|  | 253 | LOG(INFO) << "Chrome OS Update Engine terminating"; | 
| rspangler@google.com | 49fdf18 | 2009-10-10 00:57:34 +0000 | [diff] [blame] | 254 | return 0; | 
|  | 255 | } |