// Copyright 2014 The Chromium OS Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include <brillo/daemons/dbus_daemon.h> #include <sysexits.h> #include <base/bind.h> #include <brillo/dbus/async_event_sequencer.h> #include <brillo/dbus/exported_object_manager.h> using brillo::dbus_utils::AsyncEventSequencer; using brillo::dbus_utils::ExportedObjectManager; namespace brillo { DBusDaemon::DBusDaemon() { } int DBusDaemon::OnInit() { int exit_code = Daemon::OnInit(); if (exit_code != EX_OK) return exit_code; bus_ = dbus_connection_.Connect(); CHECK(bus_); return exit_code; } DBusServiceDaemon::DBusServiceDaemon(const std::string& service_name) : service_name_(service_name) { } DBusServiceDaemon::DBusServiceDaemon( const std::string& service_name, const dbus::ObjectPath& object_manager_path) : service_name_(service_name), object_manager_path_(object_manager_path) { } DBusServiceDaemon::DBusServiceDaemon(const std::string& service_name, base::StringPiece object_manager_path) : DBusServiceDaemon(service_name, dbus::ObjectPath(object_manager_path.as_string())) { } int DBusServiceDaemon::OnInit() { int exit_code = DBusDaemon::OnInit(); if (exit_code != EX_OK) return exit_code; scoped_refptr<AsyncEventSequencer> sequencer(new AsyncEventSequencer()); if (object_manager_path_.IsValid()) { object_manager_.reset( new ExportedObjectManager(bus_, object_manager_path_)); object_manager_->RegisterAsync( sequencer->GetHandler("ObjectManager.RegisterAsync() failed.", true)); } RegisterDBusObjectsAsync(sequencer.get()); sequencer->OnAllTasksCompletedCall({ base::Bind(&DBusServiceDaemon::TakeServiceOwnership, base::Unretained(this)) }); return EX_OK; } void DBusServiceDaemon::RegisterDBusObjectsAsync( dbus_utils::AsyncEventSequencer* /* sequencer */) { // Do nothing here. // Overload this method to export custom D-Bus objects at daemon startup. } void DBusServiceDaemon::TakeServiceOwnership(bool success) { // Success should always be true since we've said that failures are fatal. CHECK(success) << "Init of one or more objects has failed."; CHECK(bus_->RequestOwnershipAndBlock(service_name_, dbus::Bus::REQUIRE_PRIMARY)) << "Unable to take ownership of " << service_name_; } } // namespace brillo