blob: d24f7347d722dcf253a23dd475b03b3c0f31feb6 [file] [log] [blame]
Ben Chanfad4a0b2012-04-18 15:49:59 -07001// Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
Darin Petkov5c97ac52011-07-19 16:30:49 -07002// 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/dbus_properties_proxy.h"
6
Christopher Wileyb691efd2012-08-09 13:51:51 -07007#include "shill/logging.h"
Darin Petkov5c97ac52011-07-19 16:30:49 -07008
Darin Petkov5c97ac52011-07-19 16:30:49 -07009namespace shill {
10
Darin Petkov5c97ac52011-07-19 16:30:49 -070011using std::string;
12using std::vector;
13
Jason Glasgow9c09e362012-04-18 15:16:29 -040014DBusPropertiesProxy::DBusPropertiesProxy(DBus::Connection *connection,
Darin Petkov5c97ac52011-07-19 16:30:49 -070015 const string &path,
16 const string &service)
Jason Glasgow9c09e362012-04-18 15:16:29 -040017 : proxy_(connection, path, service) {}
Darin Petkov5c97ac52011-07-19 16:30:49 -070018
19DBusPropertiesProxy::~DBusPropertiesProxy() {}
20
Darin Petkove0a312e2011-07-20 13:45:28 -070021DBusPropertiesMap DBusPropertiesProxy::GetAll(const string &interface_name) {
mukesh agrawal06175d72012-04-23 16:46:01 -070022 SLOG(DBus, 2) << __func__ << "(" << interface_name << ")";
Gary Morain610977f2012-05-04 16:03:52 -070023 try {
24 return proxy_.GetAll(interface_name);
25 } catch (const DBus::Error &e) {
Darin Petkovd2a78bc2012-08-15 12:34:49 +020026 LOG(ERROR) << "DBus exception: " << e.name() << ": " << e.what()
Gary Morain610977f2012-05-04 16:03:52 -070027 << " interface name: " << interface_name;
Gary Morain610977f2012-05-04 16:03:52 -070028 }
Darin Petkovd2a78bc2012-08-15 12:34:49 +020029 return DBusPropertiesMap();
Darin Petkov5c97ac52011-07-19 16:30:49 -070030}
31
Jason Glasgow9c09e362012-04-18 15:16:29 -040032void DBusPropertiesProxy::set_properties_changed_callback(
33 const PropertiesChangedCallback &callback) {
34 proxy_.set_properties_changed_callback(callback);
35}
36
37void DBusPropertiesProxy::set_modem_manager_properties_changed_callback(
38 const ModemManagerPropertiesChangedCallback &callback) {
39 proxy_.set_modem_manager_properties_changed_callback(callback);
40}
41
42DBusPropertiesProxy::Proxy::Proxy(DBus::Connection *connection,
Darin Petkov5c97ac52011-07-19 16:30:49 -070043 const string &path,
44 const string &service)
Jason Glasgow9c09e362012-04-18 15:16:29 -040045 : DBus::ObjectProxy(*connection, path, service.c_str()) {}
Darin Petkov5c97ac52011-07-19 16:30:49 -070046
47DBusPropertiesProxy::Proxy::~Proxy() {}
48
49void DBusPropertiesProxy::Proxy::MmPropertiesChanged(
50 const string &interface,
Darin Petkove0a312e2011-07-20 13:45:28 -070051 const DBusPropertiesMap &properties) {
Ben Chanfad4a0b2012-04-18 15:49:59 -070052 SLOG(DBus, 2) << __func__ << "(" << interface << ")";
Jason Glasgow9c09e362012-04-18 15:16:29 -040053 mm_properties_changed_callback_.Run(interface, properties);
Darin Petkov5c97ac52011-07-19 16:30:49 -070054}
55
56void DBusPropertiesProxy::Proxy::PropertiesChanged(
57 const string &interface,
Darin Petkove0a312e2011-07-20 13:45:28 -070058 const DBusPropertiesMap &changed_properties,
Darin Petkov5c97ac52011-07-19 16:30:49 -070059 const vector<string> &invalidated_properties) {
Ben Chanfad4a0b2012-04-18 15:49:59 -070060 SLOG(DBus, 2) << __func__ << "(" << interface << ")";
Jason Glasgow9c09e362012-04-18 15:16:29 -040061 properties_changed_callback_.Run(
Darin Petkovc5f56562011-08-06 16:40:05 -070062 interface, changed_properties, invalidated_properties);
Darin Petkov5c97ac52011-07-19 16:30:49 -070063}
64
Jason Glasgow9c09e362012-04-18 15:16:29 -040065void DBusPropertiesProxy::Proxy::set_properties_changed_callback(
66 const PropertiesChangedCallback &callback) {
67 properties_changed_callback_ = callback;
68}
69
70void DBusPropertiesProxy::Proxy::set_modem_manager_properties_changed_callback(
71 const ModemManagerPropertiesChangedCallback &callback) {
72 mm_properties_changed_callback_ = callback;
73}
74
Darin Petkov5c97ac52011-07-19 16:30:49 -070075} // namespace shill