| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chromeos/dbus/shill_manager_client.h" | 5 #include "chromeos/dbus/shill_manager_client.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/chromeos/chromeos_version.h" | 8 #include "base/chromeos/chromeos_version.h" |
| 9 #include "base/message_loop.h" | 9 #include "base/message_loop.h" |
| 10 #include "base/values.h" | 10 #include "base/values.h" |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 50 class ShillManagerClientImpl : public ShillManagerClient { | 50 class ShillManagerClientImpl : public ShillManagerClient { |
| 51 public: | 51 public: |
| 52 explicit ShillManagerClientImpl(dbus::Bus* bus) | 52 explicit ShillManagerClientImpl(dbus::Bus* bus) |
| 53 : proxy_(bus->GetObjectProxy( | 53 : proxy_(bus->GetObjectProxy( |
| 54 flimflam::kFlimflamServiceName, | 54 flimflam::kFlimflamServiceName, |
| 55 dbus::ObjectPath(flimflam::kFlimflamServicePath))), | 55 dbus::ObjectPath(flimflam::kFlimflamServicePath))), |
| 56 helper_(bus, proxy_) { | 56 helper_(bus, proxy_) { |
| 57 helper_.MonitorPropertyChanged(flimflam::kFlimflamManagerInterface); | 57 helper_.MonitorPropertyChanged(flimflam::kFlimflamManagerInterface); |
| 58 } | 58 } |
| 59 | 59 |
| 60 // ShillManagerClient overrides: | 60 //////////////////////////////////// |
| 61 virtual void SetPropertyChangedHandler( | 61 // ShillManagerClient overrides. |
| 62 const PropertyChangedHandler& handler) OVERRIDE { | 62 virtual void AddPropertyChangedObserver( |
| 63 helper_.SetPropertyChangedHandler(handler); | 63 PropertyChangedObserver* observer) OVERRIDE { |
| 64 helper_.AddPropertyChangedObserver(observer); |
| 64 } | 65 } |
| 65 | 66 |
| 66 virtual void ResetPropertyChangedHandler() OVERRIDE { | 67 virtual void RemovePropertyChangedObserver( |
| 67 helper_.ResetPropertyChangedHandler(); | 68 PropertyChangedObserver* observer) OVERRIDE { |
| 69 helper_.RemovePropertyChangedObserver(observer); |
| 68 } | 70 } |
| 69 | 71 |
| 70 virtual void GetProperties(const DictionaryValueCallback& callback) OVERRIDE { | 72 virtual void GetProperties(const DictionaryValueCallback& callback) OVERRIDE { |
| 71 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 73 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
| 72 flimflam::kGetPropertiesFunction); | 74 flimflam::kGetPropertiesFunction); |
| 73 helper_.CallDictionaryValueMethod(&method_call, callback); | 75 helper_.CallDictionaryValueMethod(&method_call, callback); |
| 74 } | 76 } |
| 75 | 77 |
| 76 virtual base::DictionaryValue* CallGetPropertiesAndBlock() OVERRIDE { | 78 virtual base::DictionaryValue* CallGetPropertiesAndBlock() OVERRIDE { |
| 77 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 79 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
| 78 flimflam::kGetPropertiesFunction); | 80 flimflam::kGetPropertiesFunction); |
| 79 return helper_.CallDictionaryValueMethodAndBlock(&method_call); | 81 return helper_.CallDictionaryValueMethodAndBlock(&method_call); |
| 80 } | 82 } |
| 81 | 83 |
| 82 virtual void SetProperty(const std::string& name, | 84 virtual void SetProperty(const std::string& name, |
| 83 const base::Value& value, | 85 const base::Value& value, |
| 84 const VoidDBusMethodCallback& callback) OVERRIDE { | 86 const base::Closure& callback, |
| 87 const ErrorCallback& error_callback) OVERRIDE { |
| 85 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 88 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
| 86 flimflam::kSetPropertyFunction); | 89 flimflam::kSetPropertyFunction); |
| 87 dbus::MessageWriter writer(&method_call); | 90 dbus::MessageWriter writer(&method_call); |
| 88 writer.AppendString(name); | 91 writer.AppendString(name); |
| 89 ShillClientHelper::AppendValueDataAsVariant(&writer, value); | 92 ShillClientHelper::AppendValueDataAsVariant(&writer, value); |
| 90 helper_.CallVoidMethod(&method_call, callback); | 93 helper_.CallVoidMethodWithErrorCallback(&method_call, |
| 94 callback, |
| 95 error_callback); |
| 91 } | 96 } |
| 92 | 97 |
| 93 virtual void RequestScan(const std::string& type, | 98 virtual void RequestScan(const std::string& type, |
| 94 const VoidDBusMethodCallback& callback) OVERRIDE { | 99 const base::Closure& callback, |
| 100 const ErrorCallback& error_callback) OVERRIDE { |
| 95 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 101 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
| 96 flimflam::kRequestScanFunction); | 102 flimflam::kRequestScanFunction); |
| 97 dbus::MessageWriter writer(&method_call); | 103 dbus::MessageWriter writer(&method_call); |
| 98 writer.AppendString(type); | 104 writer.AppendString(type); |
| 99 helper_.CallVoidMethod(&method_call, callback); | 105 helper_.CallVoidMethodWithErrorCallback(&method_call, |
| 106 callback, |
| 107 error_callback); |
| 100 } | 108 } |
| 101 | 109 |
| 102 virtual void EnableTechnology( | 110 virtual void EnableTechnology( |
| 103 const std::string& type, | 111 const std::string& type, |
| 104 const VoidDBusMethodCallback& callback) OVERRIDE { | 112 const base::Closure& callback, |
| 113 const ErrorCallback& error_callback) OVERRIDE { |
| 105 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 114 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
| 106 flimflam::kEnableTechnologyFunction); | 115 flimflam::kEnableTechnologyFunction); |
| 107 dbus::MessageWriter writer(&method_call); | 116 dbus::MessageWriter writer(&method_call); |
| 108 writer.AppendString(type); | 117 writer.AppendString(type); |
| 109 helper_.CallVoidMethod(&method_call, callback); | 118 helper_.CallVoidMethodWithErrorCallback(&method_call, |
| 119 callback, |
| 120 error_callback); |
| 110 } | 121 } |
| 111 | 122 |
| 112 virtual void DisableTechnology( | 123 virtual void DisableTechnology( |
| 113 const std::string& type, | 124 const std::string& type, |
| 114 const VoidDBusMethodCallback& callback) OVERRIDE { | 125 const base::Closure& callback, |
| 126 const ErrorCallback& error_callback) OVERRIDE { |
| 115 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 127 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
| 116 flimflam::kDisableTechnologyFunction); | 128 flimflam::kDisableTechnologyFunction); |
| 117 dbus::MessageWriter writer(&method_call); | 129 dbus::MessageWriter writer(&method_call); |
| 118 writer.AppendString(type); | 130 writer.AppendString(type); |
| 119 helper_.CallVoidMethod(&method_call, callback); | 131 helper_.CallVoidMethodWithErrorCallback(&method_call, |
| 132 callback, |
| 133 error_callback); |
| 120 } | 134 } |
| 121 | 135 |
| 122 virtual void ConfigureService( | 136 virtual void ConfigureService( |
| 123 const base::DictionaryValue& properties, | 137 const base::DictionaryValue& properties, |
| 124 const VoidDBusMethodCallback& callback) OVERRIDE { | 138 const base::Closure& callback, |
| 139 const ErrorCallback& error_callback) OVERRIDE { |
| 125 DCHECK(AreServicePropertiesValid(properties)); | 140 DCHECK(AreServicePropertiesValid(properties)); |
| 126 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 141 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
| 127 flimflam::kConfigureServiceFunction); | 142 flimflam::kConfigureServiceFunction); |
| 128 dbus::MessageWriter writer(&method_call); | 143 dbus::MessageWriter writer(&method_call); |
| 129 AppendServicePropertiesDictionary(&writer, properties); | 144 AppendServicePropertiesDictionary(&writer, properties); |
| 130 helper_.CallVoidMethod(&method_call, callback); | 145 helper_.CallVoidMethodWithErrorCallback(&method_call, |
| 146 callback, |
| 147 error_callback); |
| 131 } | 148 } |
| 132 | 149 |
| 133 virtual void GetService( | 150 virtual void GetService( |
| 134 const base::DictionaryValue& properties, | 151 const base::DictionaryValue& properties, |
| 135 const ObjectPathDBusMethodCallback& callback) OVERRIDE { | 152 const ObjectPathDBusMethodCallback& callback, |
| 153 const ErrorCallback& error_callback) OVERRIDE { |
| 136 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 154 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
| 137 flimflam::kGetServiceFunction); | 155 flimflam::kGetServiceFunction); |
| 138 dbus::MessageWriter writer(&method_call); | 156 dbus::MessageWriter writer(&method_call); |
| 139 AppendServicePropertiesDictionary(&writer, properties); | 157 AppendServicePropertiesDictionary(&writer, properties); |
| 140 helper_.CallObjectPathMethod(&method_call, callback); | 158 helper_.CallObjectPathMethodWithErrorCallback(&method_call, |
| 159 callback, |
| 160 error_callback); |
| 141 } | 161 } |
| 142 | 162 |
| 143 private: | 163 private: |
| 144 dbus::ObjectProxy* proxy_; | 164 dbus::ObjectProxy* proxy_; |
| 145 ShillClientHelper helper_; | 165 ShillClientHelper helper_; |
| 146 | 166 |
| 147 DISALLOW_COPY_AND_ASSIGN(ShillManagerClientImpl); | 167 DISALLOW_COPY_AND_ASSIGN(ShillManagerClientImpl); |
| 148 }; | 168 }; |
| 149 | 169 |
| 150 // A stub implementation of ShillManagerClient. | 170 // A stub implementation of ShillManagerClient. |
| 151 // Implemented: Stub cellular DeviceList entry for SMS testing. | 171 // Implemented: Stub cellular DeviceList entry for SMS testing. |
| 152 class ShillManagerClientStubImpl : public ShillManagerClient { | 172 class ShillManagerClientStubImpl : public ShillManagerClient { |
| 153 public: | 173 public: |
| 154 ShillManagerClientStubImpl() : weak_ptr_factory_(this) { | 174 ShillManagerClientStubImpl() : weak_ptr_factory_(this) { |
| 155 base::ListValue* device_list = new base::ListValue; | 175 base::ListValue* device_list = new base::ListValue; |
| 156 // Note: names match Device stub map. | 176 // Note: names match Device stub map. |
| 157 const char kStubCellular1[] = "stub_cellular1"; | 177 const char kStubCellular1[] = "stub_cellular1"; |
| 158 const char kStubCellular2[] = "stub_cellular2"; | 178 const char kStubCellular2[] = "stub_cellular2"; |
| 159 device_list->Append(base::Value::CreateStringValue(kStubCellular1)); | 179 device_list->Append(base::Value::CreateStringValue(kStubCellular1)); |
| 160 device_list->Append(base::Value::CreateStringValue(kStubCellular2)); | 180 device_list->Append(base::Value::CreateStringValue(kStubCellular2)); |
| 161 stub_properties_.Set(flimflam::kDevicesProperty, device_list); | 181 stub_properties_.Set(flimflam::kDevicesProperty, device_list); |
| 162 } | 182 } |
| 163 | 183 |
| 164 virtual ~ShillManagerClientStubImpl() {} | 184 virtual ~ShillManagerClientStubImpl() {} |
| 165 | 185 |
| 166 // ShillManagerClient override. | 186 ////////////////////////////////// |
| 167 virtual void SetPropertyChangedHandler( | 187 // ShillManagerClient overrides. |
| 168 const PropertyChangedHandler& handler) OVERRIDE {} | 188 virtual void AddPropertyChangedObserver( |
| 189 PropertyChangedObserver* observer) OVERRIDE {} |
| 169 | 190 |
| 170 // ShillManagerClient override. | 191 virtual void RemovePropertyChangedObserver( |
| 171 virtual void ResetPropertyChangedHandler() OVERRIDE {} | 192 PropertyChangedObserver* observer) OVERRIDE {} |
| 172 | 193 |
| 173 // ShillManagerClient override. | 194 // ShillManagerClient override. |
| 174 virtual void GetProperties(const DictionaryValueCallback& callback) OVERRIDE { | 195 virtual void GetProperties(const DictionaryValueCallback& callback) OVERRIDE { |
| 175 MessageLoop::current()->PostTask( | 196 MessageLoop::current()->PostTask( |
| 176 FROM_HERE, base::Bind( | 197 FROM_HERE, base::Bind( |
| 177 &ShillManagerClientStubImpl::PassStubProperties, | 198 &ShillManagerClientStubImpl::PassStubProperties, |
| 178 weak_ptr_factory_.GetWeakPtr(), | 199 weak_ptr_factory_.GetWeakPtr(), |
| 179 callback)); | 200 callback)); |
| 180 } | 201 } |
| 181 | 202 |
| 182 // ShillManagerClient override. | 203 // ShillManagerClient override. |
| 183 virtual base::DictionaryValue* CallGetPropertiesAndBlock() OVERRIDE { | 204 virtual base::DictionaryValue* CallGetPropertiesAndBlock() OVERRIDE { |
| 184 return new base::DictionaryValue; | 205 return new base::DictionaryValue; |
| 185 } | 206 } |
| 186 | 207 |
| 187 // ShillManagerClient override. | 208 // ShillManagerClient override. |
| 188 virtual void SetProperty(const std::string& name, | 209 virtual void SetProperty(const std::string& name, |
| 189 const base::Value& value, | 210 const base::Value& value, |
| 190 const VoidDBusMethodCallback& callback) OVERRIDE { | 211 const base::Closure& callback, |
| 212 const ErrorCallback& error_callback) OVERRIDE { |
| 191 stub_properties_.Set(name, value.DeepCopy()); | 213 stub_properties_.Set(name, value.DeepCopy()); |
| 192 MessageLoop::current()->PostTask(FROM_HERE, | 214 MessageLoop::current()->PostTask(FROM_HERE, callback); |
| 193 base::Bind(callback, | |
| 194 DBUS_METHOD_CALL_SUCCESS)); | |
| 195 } | 215 } |
| 196 | 216 |
| 197 // ShillManagerClient override. | 217 // ShillManagerClient override. |
| 198 virtual void RequestScan(const std::string& type, | 218 virtual void RequestScan(const std::string& type, |
| 199 const VoidDBusMethodCallback& callback) OVERRIDE { | 219 const base::Closure& callback, |
| 200 MessageLoop::current()->PostTask(FROM_HERE, | 220 const ErrorCallback& error_callback) OVERRIDE { |
| 201 base::Bind(callback, | 221 MessageLoop::current()->PostTask(FROM_HERE, callback); |
| 202 DBUS_METHOD_CALL_SUCCESS)); | |
| 203 } | 222 } |
| 204 | 223 |
| 205 // ShillManagerClient override. | 224 // ShillManagerClient override. |
| 206 virtual void EnableTechnology( | 225 virtual void EnableTechnology( |
| 207 const std::string& type, | 226 const std::string& type, |
| 208 const VoidDBusMethodCallback& callback) OVERRIDE { | 227 const base::Closure& callback, |
| 209 MessageLoop::current()->PostTask(FROM_HERE, | 228 const ErrorCallback& error_callback) OVERRIDE { |
| 210 base::Bind(callback, | 229 MessageLoop::current()->PostTask(FROM_HERE, callback); |
| 211 DBUS_METHOD_CALL_SUCCESS)); | |
| 212 } | 230 } |
| 213 | 231 |
| 214 // ShillManagerClient override. | 232 // ShillManagerClient override. |
| 215 virtual void DisableTechnology( | 233 virtual void DisableTechnology( |
| 216 const std::string& type, | 234 const std::string& type, |
| 217 const VoidDBusMethodCallback& callback) OVERRIDE { | 235 const base::Closure& callback, |
| 218 MessageLoop::current()->PostTask(FROM_HERE, | 236 const ErrorCallback& error_callback) OVERRIDE { |
| 219 base::Bind(callback, | 237 MessageLoop::current()->PostTask(FROM_HERE, callback); |
| 220 DBUS_METHOD_CALL_SUCCESS)); | |
| 221 } | 238 } |
| 222 | 239 |
| 223 // ShillManagerClient override. | 240 // ShillManagerClient override. |
| 224 virtual void ConfigureService( | 241 virtual void ConfigureService( |
| 225 const base::DictionaryValue& properties, | 242 const base::DictionaryValue& properties, |
| 226 const VoidDBusMethodCallback& callback) OVERRIDE { | 243 const base::Closure& callback, |
| 227 MessageLoop::current()->PostTask(FROM_HERE, | 244 const ErrorCallback& error_callback) OVERRIDE { |
| 228 base::Bind(callback, | 245 MessageLoop::current()->PostTask(FROM_HERE, callback); |
| 229 DBUS_METHOD_CALL_SUCCESS)); | |
| 230 } | 246 } |
| 231 | 247 |
| 232 // ShillManagerClient override. | 248 // ShillManagerClient override. |
| 233 virtual void GetService( | 249 virtual void GetService( |
| 234 const base::DictionaryValue& properties, | 250 const base::DictionaryValue& properties, |
| 235 const ObjectPathDBusMethodCallback& callback) OVERRIDE { | 251 const ObjectPathDBusMethodCallback& callback, |
| 252 const ErrorCallback& error_callback) OVERRIDE { |
| 236 MessageLoop::current()->PostTask(FROM_HERE, | 253 MessageLoop::current()->PostTask(FROM_HERE, |
| 237 base::Bind(callback, | 254 base::Bind(callback, |
| 238 DBUS_METHOD_CALL_SUCCESS, | 255 DBUS_METHOD_CALL_SUCCESS, |
| 239 dbus::ObjectPath())); | 256 dbus::ObjectPath())); |
| 240 } | 257 } |
| 241 | 258 |
| 242 private: | 259 private: |
| 243 void PassStubProperties(const DictionaryValueCallback& callback) const { | 260 void PassStubProperties(const DictionaryValueCallback& callback) const { |
| 244 callback.Run(DBUS_METHOD_CALL_SUCCESS, stub_properties_); | 261 callback.Run(DBUS_METHOD_CALL_SUCCESS, stub_properties_); |
| 245 } | 262 } |
| (...skipping 17 matching lines...) Expand all Loading... |
| 263 ShillManagerClient* ShillManagerClient::Create( | 280 ShillManagerClient* ShillManagerClient::Create( |
| 264 DBusClientImplementationType type, | 281 DBusClientImplementationType type, |
| 265 dbus::Bus* bus) { | 282 dbus::Bus* bus) { |
| 266 if (type == REAL_DBUS_CLIENT_IMPLEMENTATION) | 283 if (type == REAL_DBUS_CLIENT_IMPLEMENTATION) |
| 267 return new ShillManagerClientImpl(bus); | 284 return new ShillManagerClientImpl(bus); |
| 268 DCHECK_EQ(STUB_DBUS_CLIENT_IMPLEMENTATION, type); | 285 DCHECK_EQ(STUB_DBUS_CLIENT_IMPLEMENTATION, type); |
| 269 return new ShillManagerClientStubImpl(); | 286 return new ShillManagerClientStubImpl(); |
| 270 } | 287 } |
| 271 | 288 |
| 272 } // namespace chromeos | 289 } // namespace chromeos |
| OLD | NEW |