| // Copyright (c) 2013 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 "lorgnette/daemon.h" |
| |
| #include <sysexits.h> |
| |
| #include <string> |
| |
| #include <base/bind.h> |
| #include <base/logging.h> |
| #include <base/run_loop.h> |
| #include <base/threading/thread_task_runner_handle.h> |
| #include <chromeos/dbus/service_constants.h> |
| |
| #include "lorgnette/sane_client_impl.h" |
| |
| using std::string; |
| |
| namespace lorgnette { |
| |
| // static |
| const char Daemon::kScanGroupName[] = "scanner"; |
| const char Daemon::kScanUserName[] = "saned"; |
| const int Daemon::kShutdownTimeoutMilliseconds = 20000; |
| |
| Daemon::Daemon(const base::Closure& startup_callback) |
| : DBusServiceDaemon(kManagerServiceName, "/ObjectManager"), |
| startup_callback_(startup_callback) {} |
| |
| int Daemon::OnInit() { |
| LOG(INFO) << "Starting daemon"; |
| int return_code = brillo::DBusServiceDaemon::OnInit(); |
| if (return_code != EX_OK) { |
| return return_code; |
| } |
| |
| PostponeShutdown(); |
| |
| // Signal that we've acquired all resources. |
| startup_callback_.Run(); |
| return EX_OK; |
| } |
| |
| void Daemon::RegisterDBusObjectsAsync( |
| brillo::dbus_utils::AsyncEventSequencer* sequencer) { |
| manager_.reset(new Manager( |
| base::Bind(&Daemon::PostponeShutdown, weak_factory_.GetWeakPtr()), |
| SaneClientImpl::Create())); |
| manager_->RegisterAsync(object_manager_.get(), sequencer); |
| } |
| |
| void Daemon::OnShutdown(int* return_code) { |
| LOG(INFO) << "Shutting down daemon"; |
| manager_.reset(); |
| brillo::DBusServiceDaemon::OnShutdown(return_code); |
| } |
| |
| void Daemon::PostponeShutdown() { |
| shutdown_callback_.Reset( |
| base::Bind(&brillo::Daemon::Quit, weak_factory_.GetWeakPtr())); |
| base::ThreadTaskRunnerHandle::Get()->PostDelayedTask( |
| FROM_HERE, shutdown_callback_.callback(), |
| base::TimeDelta::FromMilliseconds(kShutdownTimeoutMilliseconds)); |
| } |
| |
| } // namespace lorgnette |