blob: c256d332788e29688d6498dde6376bedea56952b [file] [log] [blame]
mukesh agrawal7c1fece2012-01-13 11:31:27 -08001// Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
Darin Petkov394b7d42011-11-03 15:48:02 +01002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#include "shill/power_manager_proxy.h"
6
7#include <base/logging.h>
8#include <chromeos/dbus/service_constants.h>
9
Ben Chanfad4a0b2012-04-18 15:49:59 -070010#include "shill/scope_logger.h"
11
mukesh agrawal7c1fece2012-01-13 11:31:27 -080012using std::string;
13
Darin Petkov394b7d42011-11-03 15:48:02 +010014namespace shill {
15
16PowerManagerProxy::PowerManagerProxy(PowerManagerProxyDelegate *delegate,
17 DBus::Connection *connection)
18 : proxy_(delegate, connection) {}
19
20PowerManagerProxy::~PowerManagerProxy() {}
21
22void PowerManagerProxy::RegisterSuspendDelay(uint32 delay_ms) {
23 proxy_.RegisterSuspendDelay(delay_ms);
24}
25
26PowerManagerProxy::Proxy::Proxy(PowerManagerProxyDelegate *delegate,
27 DBus::Connection *connection)
28 : DBus::ObjectProxy(*connection,
mukesh agrawal5c05b292012-03-07 10:12:52 -080029 power_manager::kPowerManagerServicePath,
Darin Petkov394b7d42011-11-03 15:48:02 +010030 power_manager::kPowerManagerServiceName),
31 delegate_(delegate) {}
32
33PowerManagerProxy::Proxy::~Proxy() {}
34
mukesh agrawal5c05b292012-03-07 10:12:52 -080035// TODO(quiche): make this signal work again. crosbug.com/27475
Darin Petkov394b7d42011-11-03 15:48:02 +010036void PowerManagerProxy::Proxy::SuspendDelay(const uint32_t &sequence_number) {
Ben Chanfad4a0b2012-04-18 15:49:59 -070037 SLOG(Power, 2) << __func__ << "(" << sequence_number << ")";
Darin Petkov394b7d42011-11-03 15:48:02 +010038 delegate_->OnSuspendDelay(sequence_number);
39}
40
mukesh agrawal7c1fece2012-01-13 11:31:27 -080041void PowerManagerProxy::Proxy::PowerStateChanged(
42 const string &new_power_state) {
Ben Chanfad4a0b2012-04-18 15:49:59 -070043 SLOG(Power, 2) << __func__ << "(" << new_power_state << ")";
mukesh agrawal7c1fece2012-01-13 11:31:27 -080044
45 PowerManagerProxyDelegate::SuspendState suspend_state;
46 if (new_power_state == "on") {
47 suspend_state = PowerManagerProxyDelegate::kOn;
48 } else if (new_power_state == "standby") {
49 suspend_state = PowerManagerProxyDelegate::kStandby;
50 } else if (new_power_state == "mem") {
51 suspend_state = PowerManagerProxyDelegate::kMem;
52 } else if (new_power_state == "disk") {
53 suspend_state = PowerManagerProxyDelegate::kDisk;
54 } else {
55 suspend_state = PowerManagerProxyDelegate::kUnknown;
56 }
57 delegate_->OnPowerStateChanged(suspend_state);
58}
59
Darin Petkov394b7d42011-11-03 15:48:02 +010060} // namespace shill