OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "device/bluetooth/dbus/bluetooth_gatt_manager_client.h" | 5 #include "device/bluetooth/dbus/bluetooth_gatt_manager_client.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/macros.h" | 8 #include "base/macros.h" |
9 #include "base/memory/weak_ptr.h" | 9 #include "base/memory/weak_ptr.h" |
10 #include "dbus/bus.h" | 10 #include "dbus/bus.h" |
11 #include "dbus/message.h" | 11 #include "dbus/message.h" |
12 #include "dbus/object_proxy.h" | 12 #include "dbus/object_proxy.h" |
13 #include "third_party/cros_system_api/dbus/service_constants.h" | 13 #include "third_party/cros_system_api/dbus/service_constants.h" |
14 | 14 |
15 namespace bluez { | 15 namespace bluez { |
16 | 16 |
17 const char BluetoothGattManagerClient::kNoResponseError[] = | 17 const char BluetoothGattManagerClient::kNoResponseError[] = |
18 "org.chromium.Error.NoResponse"; | 18 "org.chromium.Error.NoResponse"; |
19 | 19 |
20 // The BluetoothGattManagerClient implementation used in production. | 20 // The BluetoothGattManagerClient implementation used in production. |
21 class BluetoothGattManagerClientImpl : public BluetoothGattManagerClient { | 21 class BluetoothGattManagerClientImpl : public BluetoothGattManagerClient { |
22 public: | 22 public: |
23 BluetoothGattManagerClientImpl() | 23 BluetoothGattManagerClientImpl() |
24 : object_proxy_(NULL), weak_ptr_factory_(this) {} | 24 : object_proxy_(NULL), weak_ptr_factory_(this) {} |
25 | 25 |
26 ~BluetoothGattManagerClientImpl() override {} | 26 ~BluetoothGattManagerClientImpl() override {} |
27 | 27 |
28 // BluetoothGattManagerClient override. | 28 // BluetoothGattManagerClient override. |
29 void RegisterService(const dbus::ObjectPath& service_path, | 29 void RegisterApplication(const dbus::ObjectPath& application_path, |
30 const Options& options, | 30 const Options& options, |
31 const base::Closure& callback, | 31 const base::Closure& callback, |
32 const ErrorCallback& error_callback) override { | 32 const ErrorCallback& error_callback) override { |
33 dbus::MethodCall method_call( | 33 dbus::MethodCall method_call( |
34 bluetooth_gatt_manager::kBluetoothGattManagerInterface, | 34 bluetooth_gatt_manager::kBluetoothGattManagerInterface, |
35 bluetooth_gatt_manager::kRegisterService); | 35 bluetooth_gatt_manager::kRegisterService); |
36 | 36 |
37 dbus::MessageWriter writer(&method_call); | 37 dbus::MessageWriter writer(&method_call); |
38 writer.AppendObjectPath(service_path); | 38 writer.AppendObjectPath(application_path); |
39 | 39 |
40 // TODO(armansito): The parameters of the Options dictionary are undefined | 40 // The parameters of the Options dictionary are undefined but the method |
41 // but the method signature still requires a value dictionary. Pass an | 41 // signature still requires a value dictionary. Pass an empty dictionary |
42 // empty dictionary and fill in the contents later once this is defined. | 42 // and fill in the contents later if and when we add any options. |
43 dbus::MessageWriter array_writer(NULL); | 43 dbus::MessageWriter array_writer(NULL); |
44 writer.OpenArray("{sv}", &array_writer); | 44 writer.OpenArray("{sv}", &array_writer); |
45 writer.CloseContainer(&array_writer); | 45 writer.CloseContainer(&array_writer); |
46 | 46 |
47 DCHECK(object_proxy_); | 47 DCHECK(object_proxy_); |
48 object_proxy_->CallMethodWithErrorCallback( | 48 object_proxy_->CallMethodWithErrorCallback( |
49 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | 49 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
50 base::Bind(&BluetoothGattManagerClientImpl::OnSuccess, | 50 base::Bind(&BluetoothGattManagerClientImpl::OnSuccess, |
51 weak_ptr_factory_.GetWeakPtr(), callback), | 51 weak_ptr_factory_.GetWeakPtr(), callback), |
52 base::Bind(&BluetoothGattManagerClientImpl::OnError, | 52 base::Bind(&BluetoothGattManagerClientImpl::OnError, |
53 weak_ptr_factory_.GetWeakPtr(), error_callback)); | 53 weak_ptr_factory_.GetWeakPtr(), error_callback)); |
54 } | 54 } |
55 | 55 |
56 // BluetoothGattManagerClient override. | 56 // BluetoothGattManagerClient override. |
57 void UnregisterService(const dbus::ObjectPath& service_path, | 57 void UnregisterApplication(const dbus::ObjectPath& application_path, |
58 const base::Closure& callback, | 58 const base::Closure& callback, |
59 const ErrorCallback& error_callback) override { | 59 const ErrorCallback& error_callback) override { |
60 dbus::MethodCall method_call( | 60 dbus::MethodCall method_call( |
61 bluetooth_gatt_manager::kBluetoothGattManagerInterface, | 61 bluetooth_gatt_manager::kBluetoothGattManagerInterface, |
62 bluetooth_gatt_manager::kUnregisterService); | 62 bluetooth_gatt_manager::kUnregisterService); |
63 | 63 |
64 dbus::MessageWriter writer(&method_call); | 64 dbus::MessageWriter writer(&method_call); |
65 writer.AppendObjectPath(service_path); | 65 writer.AppendObjectPath(application_path); |
66 | 66 |
67 DCHECK(object_proxy_); | 67 DCHECK(object_proxy_); |
68 object_proxy_->CallMethodWithErrorCallback( | 68 object_proxy_->CallMethodWithErrorCallback( |
69 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | 69 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
70 base::Bind(&BluetoothGattManagerClientImpl::OnSuccess, | 70 base::Bind(&BluetoothGattManagerClientImpl::OnSuccess, |
71 weak_ptr_factory_.GetWeakPtr(), callback), | 71 weak_ptr_factory_.GetWeakPtr(), callback), |
72 base::Bind(&BluetoothGattManagerClientImpl::OnError, | 72 base::Bind(&BluetoothGattManagerClientImpl::OnError, |
73 weak_ptr_factory_.GetWeakPtr(), error_callback)); | 73 weak_ptr_factory_.GetWeakPtr(), error_callback)); |
74 } | 74 } |
75 | 75 |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
121 BluetoothGattManagerClient::BluetoothGattManagerClient() {} | 121 BluetoothGattManagerClient::BluetoothGattManagerClient() {} |
122 | 122 |
123 BluetoothGattManagerClient::~BluetoothGattManagerClient() {} | 123 BluetoothGattManagerClient::~BluetoothGattManagerClient() {} |
124 | 124 |
125 // static | 125 // static |
126 BluetoothGattManagerClient* BluetoothGattManagerClient::Create() { | 126 BluetoothGattManagerClient* BluetoothGattManagerClient::Create() { |
127 return new BluetoothGattManagerClientImpl(); | 127 return new BluetoothGattManagerClientImpl(); |
128 } | 128 } |
129 | 129 |
130 } // namespace bluez | 130 } // namespace bluez |
OLD | NEW |