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 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
74 } | 74 } |
75 | 75 |
76 virtual base::DictionaryValue* CallGetPropertiesAndBlock() OVERRIDE { | 76 virtual base::DictionaryValue* CallGetPropertiesAndBlock() OVERRIDE { |
77 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 77 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
78 flimflam::kGetPropertiesFunction); | 78 flimflam::kGetPropertiesFunction); |
79 return helper_.CallDictionaryValueMethodAndBlock(&method_call); | 79 return helper_.CallDictionaryValueMethodAndBlock(&method_call); |
80 } | 80 } |
81 | 81 |
82 virtual void SetProperty(const std::string& name, | 82 virtual void SetProperty(const std::string& name, |
83 const base::Value& value, | 83 const base::Value& value, |
84 const VoidDBusMethodCallback& callback) OVERRIDE { | 84 const base::Closure& callback, |
| 85 const ErrorCallback& error_callback) OVERRIDE { |
85 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 86 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
86 flimflam::kSetPropertyFunction); | 87 flimflam::kSetPropertyFunction); |
87 dbus::MessageWriter writer(&method_call); | 88 dbus::MessageWriter writer(&method_call); |
88 writer.AppendString(name); | 89 writer.AppendString(name); |
89 ShillClientHelper::AppendValueDataAsVariant(&writer, value); | 90 ShillClientHelper::AppendValueDataAsVariant(&writer, value); |
90 helper_.CallVoidMethod(&method_call, callback); | 91 helper_.CallVoidMethodWithErrorCallback(&method_call, |
| 92 callback, |
| 93 error_callback); |
91 } | 94 } |
92 | 95 |
93 virtual void RequestScan(const std::string& type, | 96 virtual void RequestScan(const std::string& type, |
94 const VoidDBusMethodCallback& callback) OVERRIDE { | 97 const base::Closure& callback, |
| 98 const ErrorCallback& error_callback) OVERRIDE { |
95 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 99 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
96 flimflam::kRequestScanFunction); | 100 flimflam::kRequestScanFunction); |
97 dbus::MessageWriter writer(&method_call); | 101 dbus::MessageWriter writer(&method_call); |
98 writer.AppendString(type); | 102 writer.AppendString(type); |
99 helper_.CallVoidMethod(&method_call, callback); | 103 helper_.CallVoidMethodWithErrorCallback(&method_call, |
| 104 callback, |
| 105 error_callback); |
100 } | 106 } |
101 | 107 |
102 virtual void EnableTechnology( | 108 virtual void EnableTechnology( |
103 const std::string& type, | 109 const std::string& type, |
104 const VoidDBusMethodCallback& callback) OVERRIDE { | 110 const base::Closure& callback, |
| 111 const ErrorCallback& error_callback) OVERRIDE { |
105 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 112 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
106 flimflam::kEnableTechnologyFunction); | 113 flimflam::kEnableTechnologyFunction); |
107 dbus::MessageWriter writer(&method_call); | 114 dbus::MessageWriter writer(&method_call); |
108 writer.AppendString(type); | 115 writer.AppendString(type); |
109 helper_.CallVoidMethod(&method_call, callback); | 116 helper_.CallVoidMethodWithErrorCallback(&method_call, |
| 117 callback, |
| 118 error_callback); |
110 } | 119 } |
111 | 120 |
112 virtual void DisableTechnology( | 121 virtual void DisableTechnology( |
113 const std::string& type, | 122 const std::string& type, |
114 const VoidDBusMethodCallback& callback) OVERRIDE { | 123 const base::Closure& callback, |
| 124 const ErrorCallback& error_callback) OVERRIDE { |
115 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 125 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
116 flimflam::kDisableTechnologyFunction); | 126 flimflam::kDisableTechnologyFunction); |
117 dbus::MessageWriter writer(&method_call); | 127 dbus::MessageWriter writer(&method_call); |
118 writer.AppendString(type); | 128 writer.AppendString(type); |
119 helper_.CallVoidMethod(&method_call, callback); | 129 helper_.CallVoidMethodWithErrorCallback(&method_call, |
| 130 callback, |
| 131 error_callback); |
120 } | 132 } |
121 | 133 |
122 virtual void ConfigureService( | 134 virtual void ConfigureService( |
123 const base::DictionaryValue& properties, | 135 const base::DictionaryValue& properties, |
124 const VoidDBusMethodCallback& callback) OVERRIDE { | 136 const base::Closure& callback, |
| 137 const ErrorCallback& error_callback) OVERRIDE { |
125 DCHECK(AreServicePropertiesValid(properties)); | 138 DCHECK(AreServicePropertiesValid(properties)); |
126 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 139 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
127 flimflam::kConfigureServiceFunction); | 140 flimflam::kConfigureServiceFunction); |
128 dbus::MessageWriter writer(&method_call); | 141 dbus::MessageWriter writer(&method_call); |
129 AppendServicePropertiesDictionary(&writer, properties); | 142 AppendServicePropertiesDictionary(&writer, properties); |
130 helper_.CallVoidMethod(&method_call, callback); | 143 helper_.CallVoidMethodWithErrorCallback(&method_call, |
| 144 callback, |
| 145 error_callback); |
131 } | 146 } |
132 | 147 |
133 virtual void GetService( | 148 virtual void GetService( |
134 const base::DictionaryValue& properties, | 149 const base::DictionaryValue& properties, |
135 const ObjectPathDBusMethodCallback& callback) OVERRIDE { | 150 const ObjectPathCallbackWithoutStatus& callback, |
| 151 const ErrorCallback& error_callback) OVERRIDE { |
136 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, | 152 dbus::MethodCall method_call(flimflam::kFlimflamManagerInterface, |
137 flimflam::kGetServiceFunction); | 153 flimflam::kGetServiceFunction); |
138 dbus::MessageWriter writer(&method_call); | 154 dbus::MessageWriter writer(&method_call); |
139 AppendServicePropertiesDictionary(&writer, properties); | 155 AppendServicePropertiesDictionary(&writer, properties); |
140 helper_.CallObjectPathMethod(&method_call, callback); | 156 helper_.CallObjectPathMethodWithErrorCallback(&method_call, |
| 157 callback, |
| 158 error_callback); |
141 } | 159 } |
142 | 160 |
143 private: | 161 private: |
144 dbus::ObjectProxy* proxy_; | 162 dbus::ObjectProxy* proxy_; |
145 ShillClientHelper helper_; | 163 ShillClientHelper helper_; |
146 | 164 |
147 DISALLOW_COPY_AND_ASSIGN(ShillManagerClientImpl); | 165 DISALLOW_COPY_AND_ASSIGN(ShillManagerClientImpl); |
148 }; | 166 }; |
149 | 167 |
150 // A stub implementation of ShillManagerClient. | 168 // A stub implementation of ShillManagerClient. |
(...skipping 29 matching lines...) Expand all Loading... |
180 } | 198 } |
181 | 199 |
182 // ShillManagerClient override. | 200 // ShillManagerClient override. |
183 virtual base::DictionaryValue* CallGetPropertiesAndBlock() OVERRIDE { | 201 virtual base::DictionaryValue* CallGetPropertiesAndBlock() OVERRIDE { |
184 return new base::DictionaryValue; | 202 return new base::DictionaryValue; |
185 } | 203 } |
186 | 204 |
187 // ShillManagerClient override. | 205 // ShillManagerClient override. |
188 virtual void SetProperty(const std::string& name, | 206 virtual void SetProperty(const std::string& name, |
189 const base::Value& value, | 207 const base::Value& value, |
190 const VoidDBusMethodCallback& callback) OVERRIDE { | 208 const base::Closure& callback, |
| 209 const ErrorCallback& error_callback) OVERRIDE { |
191 stub_properties_.Set(name, value.DeepCopy()); | 210 stub_properties_.Set(name, value.DeepCopy()); |
192 MessageLoop::current()->PostTask(FROM_HERE, | 211 MessageLoop::current()->PostTask(FROM_HERE, callback); |
193 base::Bind(callback, | |
194 DBUS_METHOD_CALL_SUCCESS)); | |
195 } | 212 } |
196 | 213 |
197 // ShillManagerClient override. | 214 // ShillManagerClient override. |
198 virtual void RequestScan(const std::string& type, | 215 virtual void RequestScan(const std::string& type, |
199 const VoidDBusMethodCallback& callback) OVERRIDE { | 216 const base::Closure& callback, |
200 MessageLoop::current()->PostTask(FROM_HERE, | 217 const ErrorCallback& error_callback) OVERRIDE { |
201 base::Bind(callback, | 218 MessageLoop::current()->PostTask(FROM_HERE, callback); |
202 DBUS_METHOD_CALL_SUCCESS)); | |
203 } | 219 } |
204 | 220 |
205 // ShillManagerClient override. | 221 // ShillManagerClient override. |
206 virtual void EnableTechnology( | 222 virtual void EnableTechnology( |
207 const std::string& type, | 223 const std::string& type, |
208 const VoidDBusMethodCallback& callback) OVERRIDE { | 224 const base::Closure& callback, |
209 MessageLoop::current()->PostTask(FROM_HERE, | 225 const ErrorCallback& error_callback) OVERRIDE { |
210 base::Bind(callback, | 226 MessageLoop::current()->PostTask(FROM_HERE, callback); |
211 DBUS_METHOD_CALL_SUCCESS)); | |
212 } | 227 } |
213 | 228 |
214 // ShillManagerClient override. | 229 // ShillManagerClient override. |
215 virtual void DisableTechnology( | 230 virtual void DisableTechnology( |
216 const std::string& type, | 231 const std::string& type, |
217 const VoidDBusMethodCallback& callback) OVERRIDE { | 232 const base::Closure& callback, |
218 MessageLoop::current()->PostTask(FROM_HERE, | 233 const ErrorCallback& error_callback) OVERRIDE { |
219 base::Bind(callback, | 234 MessageLoop::current()->PostTask(FROM_HERE, callback); |
220 DBUS_METHOD_CALL_SUCCESS)); | |
221 } | 235 } |
222 | 236 |
223 // ShillManagerClient override. | 237 // ShillManagerClient override. |
224 virtual void ConfigureService( | 238 virtual void ConfigureService( |
225 const base::DictionaryValue& properties, | 239 const base::DictionaryValue& properties, |
226 const VoidDBusMethodCallback& callback) OVERRIDE { | 240 const base::Closure& callback, |
227 MessageLoop::current()->PostTask(FROM_HERE, | 241 const ErrorCallback& error_callback) OVERRIDE { |
228 base::Bind(callback, | 242 MessageLoop::current()->PostTask(FROM_HERE, callback); |
229 DBUS_METHOD_CALL_SUCCESS)); | |
230 } | 243 } |
231 | 244 |
232 // ShillManagerClient override. | 245 // ShillManagerClient override. |
233 virtual void GetService( | 246 virtual void GetService( |
234 const base::DictionaryValue& properties, | 247 const base::DictionaryValue& properties, |
235 const ObjectPathDBusMethodCallback& callback) OVERRIDE { | 248 const ObjectPathCallbackWithoutStatus& callback, |
| 249 const ErrorCallback& error_callback) OVERRIDE { |
236 MessageLoop::current()->PostTask(FROM_HERE, | 250 MessageLoop::current()->PostTask(FROM_HERE, |
237 base::Bind(callback, | 251 base::Bind(callback, |
238 DBUS_METHOD_CALL_SUCCESS, | |
239 dbus::ObjectPath())); | 252 dbus::ObjectPath())); |
240 } | 253 } |
241 | 254 |
242 private: | 255 private: |
243 void PassStubProperties(const DictionaryValueCallback& callback) const { | 256 void PassStubProperties(const DictionaryValueCallback& callback) const { |
244 callback.Run(DBUS_METHOD_CALL_SUCCESS, stub_properties_); | 257 callback.Run(DBUS_METHOD_CALL_SUCCESS, stub_properties_); |
245 } | 258 } |
246 | 259 |
247 base::DictionaryValue stub_properties_; | 260 base::DictionaryValue stub_properties_; |
248 | 261 |
(...skipping 14 matching lines...) Expand all Loading... |
263 ShillManagerClient* ShillManagerClient::Create( | 276 ShillManagerClient* ShillManagerClient::Create( |
264 DBusClientImplementationType type, | 277 DBusClientImplementationType type, |
265 dbus::Bus* bus) { | 278 dbus::Bus* bus) { |
266 if (type == REAL_DBUS_CLIENT_IMPLEMENTATION) | 279 if (type == REAL_DBUS_CLIENT_IMPLEMENTATION) |
267 return new ShillManagerClientImpl(bus); | 280 return new ShillManagerClientImpl(bus); |
268 DCHECK_EQ(STUB_DBUS_CLIENT_IMPLEMENTATION, type); | 281 DCHECK_EQ(STUB_DBUS_CLIENT_IMPLEMENTATION, type); |
269 return new ShillManagerClientStubImpl(); | 282 return new ShillManagerClientStubImpl(); |
270 } | 283 } |
271 | 284 |
272 } // namespace chromeos | 285 } // namespace chromeos |
OLD | NEW |