mukesh agrawal | 4d0401c | 2012-01-06 16:05:31 -0800 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium OS Authors. All rights reserved. |
Chris Masone | d7732e4 | 2011-05-20 11:08:56 -0700 | [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 | |
| 5 | #include "shill/device_dbus_adaptor.h" |
| 6 | |
| 7 | #include <map> |
| 8 | #include <string> |
| 9 | |
Chris Masone | a82b711 | 2011-05-25 15:16:29 -0700 | [diff] [blame] | 10 | #include "shill/device.h" |
Chris Masone | 8fe2c7e | 2011-06-09 15:51:19 -0700 | [diff] [blame] | 11 | #include "shill/error.h" |
Christopher Wiley | b691efd | 2012-08-09 13:51:51 -0700 | [diff] [blame] | 12 | #include "shill/logging.h" |
Chris Masone | a82b711 | 2011-05-25 15:16:29 -0700 | [diff] [blame] | 13 | |
Chris Masone | d7732e4 | 2011-05-20 11:08:56 -0700 | [diff] [blame] | 14 | using std::map; |
| 15 | using std::string; |
Paul Stewart | d4f2648 | 2014-04-25 19:12:03 -0700 | [diff] [blame] | 16 | using std::vector; |
Chris Masone | d7732e4 | 2011-05-20 11:08:56 -0700 | [diff] [blame] | 17 | |
| 18 | namespace shill { |
| 19 | |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 20 | namespace Logging { |
| 21 | static auto kModuleLogScope = ScopeLogger::kDBus; |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 22 | static string ObjectID(DeviceDBusAdaptor* d) { return d->GetRpcIdentifier(); } |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 23 | } |
| 24 | |
Chris Masone | d7732e4 | 2011-05-20 11:08:56 -0700 | [diff] [blame] | 25 | // static |
Chris Masone | a82b711 | 2011-05-25 15:16:29 -0700 | [diff] [blame] | 26 | const char DeviceDBusAdaptor::kPath[] = "/device/"; |
Chris Masone | d7732e4 | 2011-05-20 11:08:56 -0700 | [diff] [blame] | 27 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 28 | DeviceDBusAdaptor::DeviceDBusAdaptor(DBus::Connection* conn, Device* device) |
Paul Stewart | f3b3840 | 2015-01-16 12:59:03 -0800 | [diff] [blame] | 29 | : DBusAdaptor(conn, kPath + SanitizePathElement(device->UniqueName())), |
Chris Masone | 4e85161 | 2011-07-01 10:46:53 -0700 | [diff] [blame] | 30 | device_(device), |
| 31 | connection_name_(conn->unique_name()) { |
Chris Masone | d7732e4 | 2011-05-20 11:08:56 -0700 | [diff] [blame] | 32 | } |
Chris Masone | d0ceb8c | 2011-06-02 10:05:39 -0700 | [diff] [blame] | 33 | |
Chris Masone | ec6b18b | 2011-06-08 14:09:10 -0700 | [diff] [blame] | 34 | DeviceDBusAdaptor::~DeviceDBusAdaptor() { |
Ben Chan | cc225ef | 2014-09-30 13:26:51 -0700 | [diff] [blame] | 35 | device_ = nullptr; |
Chris Masone | ec6b18b | 2011-06-08 14:09:10 -0700 | [diff] [blame] | 36 | } |
Ben Chan | 3f4d4ee | 2014-09-09 07:41:33 -0700 | [diff] [blame] | 37 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 38 | const string& DeviceDBusAdaptor::GetRpcIdentifier() { |
Chris Masone | 4e85161 | 2011-07-01 10:46:53 -0700 | [diff] [blame] | 39 | return path(); |
| 40 | } |
| 41 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 42 | const string& DeviceDBusAdaptor::GetRpcConnectionIdentifier() { |
Chris Masone | 4e85161 | 2011-07-01 10:46:53 -0700 | [diff] [blame] | 43 | return connection_name_; |
| 44 | } |
Chris Masone | d7732e4 | 2011-05-20 11:08:56 -0700 | [diff] [blame] | 45 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 46 | void DeviceDBusAdaptor::EmitBoolChanged(const string& name, bool value) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 47 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 48 | << " " << name; |
Chris Masone | d0ceb8c | 2011-06-02 10:05:39 -0700 | [diff] [blame] | 49 | PropertyChanged(name, DBusAdaptor::BoolToVariant(value)); |
| 50 | } |
| 51 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 52 | void DeviceDBusAdaptor::EmitUintChanged(const string& name, |
Ben Chan | 7fab897 | 2014-08-10 17:14:46 -0700 | [diff] [blame] | 53 | uint32_t value) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 54 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 55 | << " " << name; |
Chris Masone | 8fe2c7e | 2011-06-09 15:51:19 -0700 | [diff] [blame] | 56 | PropertyChanged(name, DBusAdaptor::Uint32ToVariant(value)); |
Chris Masone | d0ceb8c | 2011-06-02 10:05:39 -0700 | [diff] [blame] | 57 | } |
| 58 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 59 | void DeviceDBusAdaptor::EmitUint16Changed(const string& name, uint16_t value) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 60 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 61 | << " " << name; |
Prathmesh Prabhu | 700ff4d | 2014-01-16 15:59:33 -0800 | [diff] [blame] | 62 | PropertyChanged(name, DBusAdaptor::Uint16ToVariant(value)); |
| 63 | } |
| 64 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 65 | void DeviceDBusAdaptor::EmitIntChanged(const string& name, int value) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 66 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 67 | << " " << name; |
Chris Masone | 8fe2c7e | 2011-06-09 15:51:19 -0700 | [diff] [blame] | 68 | PropertyChanged(name, DBusAdaptor::Int32ToVariant(value)); |
Chris Masone | d0ceb8c | 2011-06-02 10:05:39 -0700 | [diff] [blame] | 69 | } |
| 70 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 71 | void DeviceDBusAdaptor::EmitStringChanged(const string& name, |
| 72 | const string& value) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 73 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 74 | << " " << name; |
Chris Masone | d0ceb8c | 2011-06-02 10:05:39 -0700 | [diff] [blame] | 75 | PropertyChanged(name, DBusAdaptor::StringToVariant(value)); |
| 76 | } |
| 77 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 78 | void DeviceDBusAdaptor::EmitStringmapChanged(const string& name, |
| 79 | const Stringmap& value) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 80 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 81 | << " " << name; |
Prathmesh Prabhu | 9f06c87 | 2013-11-21 14:08:23 -0800 | [diff] [blame] | 82 | PropertyChanged(name, DBusAdaptor::StringmapToVariant(value)); |
| 83 | } |
| 84 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 85 | void DeviceDBusAdaptor::EmitStringmapsChanged(const string& name, |
| 86 | const Stringmaps& value) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 87 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 88 | << " " << name; |
Darin Petkov | 3cfbf21 | 2011-11-21 16:02:09 +0100 | [diff] [blame] | 89 | PropertyChanged(name, DBusAdaptor::StringmapsToVariant(value)); |
| 90 | } |
| 91 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 92 | void DeviceDBusAdaptor::EmitStringsChanged(const string& name, |
| 93 | const Strings& value) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 94 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 95 | << " " << name; |
Prathmesh Prabhu | 700ff4d | 2014-01-16 15:59:33 -0800 | [diff] [blame] | 96 | PropertyChanged(name, DBusAdaptor::StringsToVariant(value)); |
| 97 | } |
| 98 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 99 | void DeviceDBusAdaptor::EmitKeyValueStoreChanged(const string& name, |
| 100 | const KeyValueStore& value) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 101 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 102 | << " " << name; |
Darin Petkov | 63138a9 | 2012-02-06 14:09:15 +0100 | [diff] [blame] | 103 | PropertyChanged(name, DBusAdaptor::KeyValueStoreToVariant(value)); |
| 104 | } |
| 105 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 106 | void DeviceDBusAdaptor::EmitRpcIdentifierChanged(const std::string& name, |
| 107 | const std::string& value) { |
Christopher Wiley | 674598d | 2014-12-12 10:21:39 -0800 | [diff] [blame] | 108 | SLOG(this, 2) << __func__ << ": " << name; |
| 109 | PropertyChanged(name, DBusAdaptor::PathToVariant(value)); |
| 110 | } |
| 111 | |
Paul Stewart | d4f2648 | 2014-04-25 19:12:03 -0700 | [diff] [blame] | 112 | void DeviceDBusAdaptor::EmitRpcIdentifierArrayChanged( |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 113 | const string& name, |
| 114 | const vector<string>& value) { |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 115 | SLOG(this, 2) << __func__ << ": " << name; |
Ben Chan | 3f4d4ee | 2014-09-09 07:41:33 -0700 | [diff] [blame] | 116 | vector<DBus::Path> paths; |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 117 | for (const auto& element : value) { |
Paul Stewart | 6db7b24 | 2014-05-02 15:34:21 -0700 | [diff] [blame] | 118 | paths.push_back(element); |
Paul Stewart | d4f2648 | 2014-04-25 19:12:03 -0700 | [diff] [blame] | 119 | } |
| 120 | |
| 121 | PropertyChanged(name, DBusAdaptor::PathsToVariant(paths)); |
| 122 | } |
| 123 | |
Ben Chan | 3f4d4ee | 2014-09-09 07:41:33 -0700 | [diff] [blame] | 124 | map<string, DBus::Variant> DeviceDBusAdaptor::GetProperties( |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 125 | DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 126 | SLOG(this, 2) << __func__ << " " << device_->UniqueName(); |
Ben Chan | 3f4d4ee | 2014-09-09 07:41:33 -0700 | [diff] [blame] | 127 | map<string, DBus::Variant> properties; |
Chris Masone | 27c4aa5 | 2011-07-02 13:10:14 -0700 | [diff] [blame] | 128 | DBusAdaptor::GetProperties(device_->store(), &properties, &error); |
Chris Masone | a8a2c25 | 2011-06-27 22:16:30 -0700 | [diff] [blame] | 129 | return properties; |
Chris Masone | d7732e4 | 2011-05-20 11:08:56 -0700 | [diff] [blame] | 130 | } |
| 131 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 132 | void DeviceDBusAdaptor::SetProperty(const string& name, |
| 133 | const DBus::Variant& value, |
| 134 | DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 135 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 136 | << " " << name; |
mukesh agrawal | 6bb9e7c | 2012-01-30 14:57:54 -0800 | [diff] [blame] | 137 | DBusAdaptor::SetProperty(device_->mutable_store(), name, value, &error); |
Chris Masone | d7732e4 | 2011-05-20 11:08:56 -0700 | [diff] [blame] | 138 | } |
| 139 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 140 | void DeviceDBusAdaptor::ClearProperty(const string& name, |
| 141 | DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 142 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 143 | << " " << name; |
mukesh agrawal | 8abd2f6 | 2012-01-30 14:56:14 -0800 | [diff] [blame] | 144 | DBusAdaptor::ClearProperty(device_->mutable_store(), name, &error); |
Chris Masone | ccc8881 | 2011-06-08 18:00:10 -0700 | [diff] [blame] | 145 | } |
| 146 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 147 | void DeviceDBusAdaptor::Enable(DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 148 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName(); |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 149 | Error e(Error::kOperationInitiated); |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 150 | DBus::Tag* tag = new DBus::Tag(); |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 151 | device_->SetEnabledPersistent(true, &e, GetMethodReplyCallback(tag)); |
| 152 | ReturnResultOrDefer(tag, e, &error); |
| 153 | } |
| 154 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 155 | void DeviceDBusAdaptor::Disable(DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 156 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName(); |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 157 | Error e(Error::kOperationInitiated); |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 158 | DBus::Tag* tag = new DBus::Tag(); |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 159 | device_->SetEnabledPersistent(false, &e, GetMethodReplyCallback(tag)); |
| 160 | ReturnResultOrDefer(tag, e, &error); |
| 161 | } |
| 162 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 163 | void DeviceDBusAdaptor::ProposeScan(DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 164 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName(); |
Darin Petkov | c086531 | 2011-09-16 15:31:20 -0700 | [diff] [blame] | 165 | Error e; |
Wade Guthrie | 68d4109 | 2013-04-02 12:56:02 -0700 | [diff] [blame] | 166 | // User scan requests, which are the likely source of DBus requests, probably |
| 167 | // aren't time-critical so we might as well perform a complete scan. It |
| 168 | // also provides a failsafe for progressive scan. |
Wade Guthrie | 4823f4f | 2013-07-25 10:03:03 -0700 | [diff] [blame] | 169 | device_->Scan(Device::kFullScan, &e, __func__); |
Darin Petkov | c086531 | 2011-09-16 15:31:20 -0700 | [diff] [blame] | 170 | e.ToDBusError(&error); |
Chris Masone | d7732e4 | 2011-05-20 11:08:56 -0700 | [diff] [blame] | 171 | } |
| 172 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 173 | DBus::Path DeviceDBusAdaptor::AddIPConfig(const string& /*method*/, |
| 174 | DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 175 | SLOG(this, 2) << __func__; |
Paul Stewart | 624b9a2 | 2012-05-21 14:17:35 -0700 | [diff] [blame] | 176 | Error e(Error::kNotSupported, "This function is deprecated in shill"); |
| 177 | e.ToDBusError(&error); |
Darin Petkov | fd164b8 | 2012-02-10 14:11:52 +0100 | [diff] [blame] | 178 | return "/"; |
Chris Masone | d7732e4 | 2011-05-20 11:08:56 -0700 | [diff] [blame] | 179 | } |
| 180 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 181 | void DeviceDBusAdaptor::Register(const string& network_id, |
| 182 | DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 183 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 184 | << " (" << network_id << ")"; |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 185 | Error e(Error::kOperationInitiated); |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 186 | DBus::Tag* tag = new DBus::Tag(); |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 187 | device_->RegisterOnNetwork(network_id, &e, GetMethodReplyCallback(tag)); |
| 188 | ReturnResultOrDefer(tag, e, &error); |
Chris Masone | ccc8881 | 2011-06-08 18:00:10 -0700 | [diff] [blame] | 189 | } |
| 190 | |
Darin Petkov | c64fe5e | 2012-01-11 12:46:13 +0100 | [diff] [blame] | 191 | void DeviceDBusAdaptor::RequirePin( |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 192 | const string& pin, const bool& require, DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 193 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName(); |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 194 | Error e(Error::kOperationInitiated); |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 195 | DBus::Tag* tag = new DBus::Tag(); |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 196 | device_->RequirePIN(pin, require, &e, GetMethodReplyCallback(tag)); |
| 197 | ReturnResultOrDefer(tag, e, &error); |
Chris Masone | ccc8881 | 2011-06-08 18:00:10 -0700 | [diff] [blame] | 198 | } |
| 199 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 200 | void DeviceDBusAdaptor::EnterPin(const string& pin, |
| 201 | DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 202 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName(); |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 203 | Error e(Error::kOperationInitiated); |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 204 | DBus::Tag* tag = new DBus::Tag(); |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 205 | device_->EnterPIN(pin, &e, GetMethodReplyCallback(tag)); |
| 206 | ReturnResultOrDefer(tag, e, &error); |
Chris Masone | ccc8881 | 2011-06-08 18:00:10 -0700 | [diff] [blame] | 207 | } |
| 208 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 209 | void DeviceDBusAdaptor::UnblockPin(const string& unblock_code, |
| 210 | const string& pin, |
| 211 | DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 212 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName(); |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 213 | Error e(Error::kOperationInitiated); |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 214 | DBus::Tag* tag = new DBus::Tag(); |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 215 | device_->UnblockPIN(unblock_code, pin, &e, GetMethodReplyCallback(tag)); |
| 216 | ReturnResultOrDefer(tag, e, &error); |
Chris Masone | ccc8881 | 2011-06-08 18:00:10 -0700 | [diff] [blame] | 217 | } |
| 218 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 219 | void DeviceDBusAdaptor::ChangePin(const string& old_pin, |
| 220 | const string& new_pin, |
| 221 | DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 222 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName(); |
Darin Petkov | c37a9c4 | 2012-09-06 15:28:22 +0200 | [diff] [blame] | 223 | Error e(Error::kOperationInitiated); |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 224 | DBus::Tag* tag = new DBus::Tag(); |
Eric Shienbrood | 9a24553 | 2012-03-07 14:20:39 -0500 | [diff] [blame] | 225 | device_->ChangePIN(old_pin, new_pin, &e, GetMethodReplyCallback(tag)); |
| 226 | ReturnResultOrDefer(tag, e, &error); |
Chris Masone | ccc8881 | 2011-06-08 18:00:10 -0700 | [diff] [blame] | 227 | } |
| 228 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 229 | void DeviceDBusAdaptor::Reset(DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 230 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName(); |
Ben Chan | ad663e1 | 2013-01-08 01:58:47 -0800 | [diff] [blame] | 231 | Error e(Error::kOperationInitiated); |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 232 | DBus::Tag* tag = new DBus::Tag(); |
Ben Chan | ad663e1 | 2013-01-08 01:58:47 -0800 | [diff] [blame] | 233 | device_->Reset(&e, GetMethodReplyCallback(tag)); |
| 234 | ReturnResultOrDefer(tag, e, &error); |
| 235 | } |
| 236 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 237 | string DeviceDBusAdaptor::PerformTDLSOperation(const string& operation, |
| 238 | const string& peer, |
| 239 | DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 240 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName(); |
Paul Stewart | c6fbad9 | 2013-11-13 14:50:52 -0800 | [diff] [blame] | 241 | Error e; |
| 242 | string return_value = device_->PerformTDLSOperation(operation, peer, &e); |
| 243 | e.ToDBusError(&error); |
| 244 | return return_value; |
| 245 | } |
| 246 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 247 | void DeviceDBusAdaptor::ResetByteCounters(DBus::Error& error) { // NOLINT |
Paul Stewart | 6ff27f5 | 2012-07-11 06:51:41 -0700 | [diff] [blame] | 248 | device_->ResetByteCounters(); |
| 249 | } |
| 250 | |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 251 | void DeviceDBusAdaptor::SetCarrier(const string& carrier, |
| 252 | DBus::Error& error) { // NOLINT |
Rebecca Silberstein | c9c31d8 | 2014-10-21 15:01:00 -0700 | [diff] [blame] | 253 | SLOG(this, 2) << __func__ << ": Device " << device_->UniqueName() |
Peter Qiu | 047a21c | 2014-04-01 11:48:50 -0700 | [diff] [blame] | 254 | << "(" << carrier << ")"; |
Darin Petkov | c37a9c4 | 2012-09-06 15:28:22 +0200 | [diff] [blame] | 255 | Error e(Error::kOperationInitiated); |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 256 | DBus::Tag* tag = new DBus::Tag(); |
Darin Petkov | c37a9c4 | 2012-09-06 15:28:22 +0200 | [diff] [blame] | 257 | device_->SetCarrier(carrier, &e, GetMethodReplyCallback(tag)); |
| 258 | ReturnResultOrDefer(tag, e, &error); |
| 259 | } |
| 260 | |
Samuel Tan | 96bdaec | 2014-11-05 18:27:38 -0800 | [diff] [blame] | 261 | void DeviceDBusAdaptor::AddWakeOnPacketConnection( |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 262 | const string& ip_endpoint, |
| 263 | DBus::Error& error) { // NOLINT |
Samuel Tan | 96bdaec | 2014-11-05 18:27:38 -0800 | [diff] [blame] | 264 | SLOG(this, 2) << __func__; |
| 265 | Error e; |
| 266 | device_->AddWakeOnPacketConnection(ip_endpoint, &e); |
| 267 | e.ToDBusError(&error); |
| 268 | } |
| 269 | |
| 270 | void DeviceDBusAdaptor::RemoveWakeOnPacketConnection( |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 271 | const string& ip_endpoint, DBus::Error& error) { // NOLINT |
Samuel Tan | 96bdaec | 2014-11-05 18:27:38 -0800 | [diff] [blame] | 272 | SLOG(this, 2) << __func__; |
| 273 | Error e; |
| 274 | device_->RemoveWakeOnPacketConnection(ip_endpoint, &e); |
| 275 | e.ToDBusError(&error); |
| 276 | } |
| 277 | |
| 278 | void DeviceDBusAdaptor::RemoveAllWakeOnPacketConnections( |
Paul Stewart | a794cd6 | 2015-06-16 13:13:10 -0700 | [diff] [blame] | 279 | DBus::Error& error) { // NOLINT |
Samuel Tan | 96bdaec | 2014-11-05 18:27:38 -0800 | [diff] [blame] | 280 | SLOG(this, 2) << __func__; |
| 281 | Error e; |
| 282 | device_->RemoveAllWakeOnPacketConnections(&e); |
| 283 | e.ToDBusError(&error); |
| 284 | } |
| 285 | |
Chris Masone | d7732e4 | 2011-05-20 11:08:56 -0700 | [diff] [blame] | 286 | } // namespace shill |