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 #ifndef CHROME_BROWSER_CHROMEOS_BLUETOOTH_BLUETOOTH_ADAPTER_H_ | 5 #ifndef CHROME_BROWSER_CHROMEOS_BLUETOOTH_BLUETOOTH_ADAPTER_CHROMEOS_H_ |
6 #define CHROME_BROWSER_CHROMEOS_BLUETOOTH_BLUETOOTH_ADAPTER_H_ | 6 #define CHROME_BROWSER_CHROMEOS_BLUETOOTH_BLUETOOTH_ADAPTER_CHROMEOS_H_ |
7 | 7 |
8 #include <map> | 8 #include <map> |
9 #include <string> | 9 #include <string> |
10 #include <vector> | 10 #include <vector> |
11 | 11 |
12 #include "base/basictypes.h" | 12 #include "base/basictypes.h" |
13 #include "base/callback.h" | 13 #include "base/callback.h" |
14 #include "base/memory/ref_counted.h" | |
15 #include "base/observer_list.h" | 14 #include "base/observer_list.h" |
| 15 #include "chrome/browser/chromeos/bluetooth/bluetooth_adapter.h" |
16 #include "chromeos/dbus/bluetooth_adapter_client.h" | 16 #include "chromeos/dbus/bluetooth_adapter_client.h" |
17 #include "chromeos/dbus/bluetooth_device_client.h" | 17 #include "chromeos/dbus/bluetooth_device_client.h" |
18 #include "chromeos/dbus/bluetooth_manager_client.h" | 18 #include "chromeos/dbus/bluetooth_manager_client.h" |
19 #include "chromeos/dbus/bluetooth_out_of_band_client.h" | |
20 #include "dbus/object_path.h" | 19 #include "dbus/object_path.h" |
21 | 20 |
22 namespace chromeos { | 21 namespace chromeos { |
23 | 22 |
24 class BluetoothDevice; | 23 class BluetoothDeviceChromeOs; |
25 | 24 |
26 // The BluetoothAdapter class represents a local Bluetooth adapter which | 25 struct BluetoothOutOfBandPairingData; |
27 // may be used to interact with remote Bluetooth devices. As well as | 26 |
28 // providing support for determining whether an adapter is present, and | 27 // The BluetoothAdapterChromeOs class is an implementation of BluetoothAdapter |
29 // whether the radio is powered, this class also provides support for | 28 // for Chrome OS platform. |
30 // obtaining the list of remote devices known to the adapter, discovering | 29 class BluetoothAdapterChromeOs : public BluetoothAdapter, |
31 // new devices, and providing notification of updates to device information. | 30 public BluetoothManagerClient::Observer, |
32 // | 31 public BluetoothAdapterClient::Observer, |
33 // The class may be instantiated for either a specific adapter, or for the | 32 public BluetoothDeviceClient::Observer { |
34 // generic "default adapter" which may change depending on availability. | |
35 class BluetoothAdapter : public base::RefCounted<BluetoothAdapter>, | |
36 public BluetoothManagerClient::Observer, | |
37 public BluetoothAdapterClient::Observer, | |
38 public BluetoothDeviceClient::Observer { | |
39 public: | 33 public: |
40 // Interface for observing changes from bluetooth adapters. | 34 // BluetoothAdapter override |
41 class Observer { | 35 virtual void AddObserver(BluetoothAdapter::Observer* observer) OVERRIDE; |
42 public: | 36 virtual void RemoveObserver(BluetoothAdapter::Observer* observer) OVERRIDE; |
43 virtual ~Observer() {} | 37 virtual bool IsPresent() const OVERRIDE; |
44 | 38 virtual bool IsPowered() const OVERRIDE; |
45 // Called when the presence of the adapter |adapter| changes, when | 39 virtual void SetPowered( |
46 // |present| is true the adapter is now present, false means the adapter | 40 bool powered, |
47 // has been removed from the system. | 41 const base::Closure& callback, |
48 virtual void AdapterPresentChanged(BluetoothAdapter* adapter, | 42 const ErrorCallback& error_callback) OVERRIDE; |
49 bool present) {} | 43 virtual bool IsDiscovering() const OVERRIDE; |
50 | 44 virtual void SetDiscovering( |
51 // Called when the radio power state of the adapter |adapter| changes, | 45 bool discovering, |
52 // when |powered| is true the adapter radio is powered, false means the | 46 const base::Closure& callback, |
53 // adapter radio is off. | 47 const ErrorCallback& error_callback) OVERRIDE; |
54 virtual void AdapterPoweredChanged(BluetoothAdapter* adapter, | 48 virtual ConstDeviceList GetDevices() const OVERRIDE; |
55 bool powered) {} | 49 virtual BluetoothDevice* GetDevice(const std::string& address) OVERRIDE; |
56 | 50 virtual const BluetoothDevice* GetDevice( |
57 // Called when the discovering state of the adapter |adapter| changes, | 51 const std::string& address) const OVERRIDE; |
58 // when |discovering| is true the adapter is seeking new devices, false | |
59 // means it is not. Note that device discovery involves both states when | |
60 // the adapter is seeking new devices and states when it is not because | |
61 // it is interrogating the devices it found. | |
62 virtual void AdapterDiscoveringChanged(BluetoothAdapter* adapter, | |
63 bool discovering) {} | |
64 | |
65 // Called when a new device |device| is added to the adapter |adapter|, | |
66 // either because it has been discovered or a connection made. |device| | |
67 // should not be cached, instead copy its address. | |
68 virtual void DeviceAdded(BluetoothAdapter* adapter, | |
69 BluetoothDevice* device) {} | |
70 | |
71 // Called when properties of the device |device| known to the adapter | |
72 // |adapter| change. |device| should not be cached, instead copy its | |
73 // address. | |
74 virtual void DeviceChanged(BluetoothAdapter* adapter, | |
75 BluetoothDevice* device) {} | |
76 | |
77 // Called when the device |device| is removed from the adapter |adapter|, | |
78 // either as a result of a discovered device being lost between discovering | |
79 // phases or pairing information deleted. |device| should not be cached. | |
80 virtual void DeviceRemoved(BluetoothAdapter* adapter, | |
81 BluetoothDevice* device) {} | |
82 }; | |
83 | |
84 // Adds and removes observers for events on this bluetooth adapter, | |
85 // if monitoring multiple adapters check the |adapter| parameter of | |
86 // observer methods to determine which adapter is issuing the event. | |
87 void AddObserver(Observer* observer); | |
88 void RemoveObserver(Observer* observer); | |
89 | |
90 // The ErrorCallback is used for methods that can fail in which case it | |
91 // is called, in the success case the callback is simply not called. | |
92 typedef base::Callback<void()> ErrorCallback; | |
93 | |
94 // The BluetoothOutOfBandPairingDataCallback is used to return | |
95 // BluetoothOutOfBandPairingData to the caller. | |
96 typedef base::Callback<void(const BluetoothOutOfBandPairingData& data)> | |
97 BluetoothOutOfBandPairingDataCallback; | |
98 | |
99 // The address of this adapter. The address format is "XX:XX:XX:XX:XX:XX", | |
100 // where each XX is a hexadecimal number. | |
101 const std::string& address() const { return address_; } | |
102 | |
103 // The name of the adapter. | |
104 const std::string& name() const { return name_; } | |
105 | |
106 // Indicates whether the adapter is actually present on the system, for | |
107 // the default adapter this indicates whether any adapter is present. An | |
108 // adapter is only considered present if the address has been obtained. | |
109 virtual bool IsPresent() const; | |
110 | |
111 // Indicates whether the adapter radio is powered. | |
112 virtual bool IsPowered() const; | |
113 | |
114 // Requests a change to the adapter radio power, setting |powered| to true | |
115 // will turn on the radio and false will turn it off. On success, callback | |
116 // will be called. On failure, |error_callback| will be called. | |
117 void SetPowered(bool powered, | |
118 const base::Closure& callback, | |
119 const ErrorCallback& error_callback); | |
120 | |
121 // Indicates whether the adapter is currently discovering new devices, | |
122 // note that a typical discovery process has phases of this being true | |
123 // followed by phases of being false when the adapter interrogates the | |
124 // devices found. | |
125 virtual bool IsDiscovering() const; | |
126 | |
127 // Requests that the adapter either begin discovering new devices when | |
128 // |discovering| is true, or cease any discovery when false. On success, | |
129 // callback will be called. On failure, |error_callback| will be called. | |
130 virtual void SetDiscovering(bool discovering, | |
131 const base::Closure& callback, | |
132 const ErrorCallback& error_callback); | |
133 | |
134 // Requests the list of devices from the adapter, all are returned | |
135 // including those currently connected and those paired. Use the | |
136 // returned device pointers to determine which they are. | |
137 typedef std::vector<BluetoothDevice*> DeviceList; | |
138 virtual DeviceList GetDevices(); | |
139 typedef std::vector<const BluetoothDevice*> ConstDeviceList; | |
140 virtual ConstDeviceList GetDevices() const; | |
141 | |
142 // Returns a pointer to the device with the given address |address| or | |
143 // NULL if no such device is known. | |
144 virtual BluetoothDevice* GetDevice(const std::string& address); | |
145 virtual const BluetoothDevice* GetDevice(const std::string& address) const; | |
146 | |
147 // Requests the local Out Of Band pairing data. | |
148 virtual void ReadLocalOutOfBandPairingData( | 52 virtual void ReadLocalOutOfBandPairingData( |
149 const BluetoothOutOfBandPairingDataCallback& callback, | 53 const BluetoothOutOfBandPairingDataCallback& callback, |
150 const ErrorCallback& error_callback); | 54 const ErrorCallback& error_callback) OVERRIDE; |
151 | |
152 // Returns the shared instance for the default adapter, whichever that may | |
153 // be at the time. Use IsPresent() and the AdapterPresentChanged() observer | |
154 // method to determine whether an adapter is actually available or not. | |
155 static scoped_refptr<BluetoothAdapter> DefaultAdapter(); | |
156 | |
157 // Creates an instance for a specific adapter named by |address|, which | |
158 // may be the bluetooth address of the adapter or a device name such as | |
159 // "hci0". | |
160 static BluetoothAdapter* Create(const std::string& address); | |
161 | 55 |
162 private: | 56 private: |
163 friend class base::RefCounted<BluetoothAdapter>; | 57 friend class BluetoothAdapterFactory; |
164 friend class BluetoothDevice; | 58 friend class BluetoothDeviceChromeOs; |
165 friend class MockBluetoothAdapter; | 59 friend class MockBluetoothAdapter; |
166 | 60 |
167 BluetoothAdapter(); | 61 BluetoothAdapterChromeOs(); |
168 virtual ~BluetoothAdapter(); | 62 virtual ~BluetoothAdapterChromeOs(); |
169 | 63 |
170 // Obtains the default adapter object path from the Bluetooth Daemon | 64 // Obtains the default adapter object path from the Bluetooth Daemon |
171 // and tracks future changes to it. | 65 // and tracks future changes to it. |
172 void TrackDefaultAdapter(); | 66 void TrackDefaultAdapter(); |
173 | 67 |
174 // Obtains the object paht for the adapter named by |address| from the | 68 // Obtains the object paht for the adapter named by |address| from the |
175 // Bluetooth Daemon. | 69 // Bluetooth Daemon. |
176 void FindAdapter(const std::string& address); | 70 void FindAdapter(const std::string& address); |
177 | 71 |
178 // Called by dbus:: in response to the method call sent by both | 72 // Called by dbus:: in response to the method call sent by both |
(...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
286 | 180 |
287 // BluetoothAdapterClient::Observer override. | 181 // BluetoothAdapterClient::Observer override. |
288 // | 182 // |
289 // Called when the adapter with object path |object_path| discovers | 183 // Called when the adapter with object path |object_path| discovers |
290 // a new remote device with address |address| and properties | 184 // a new remote device with address |address| and properties |
291 // |properties|, there is no device object path until connected. | 185 // |properties|, there is no device object path until connected. |
292 // | 186 // |
293 // |properties| supports only value() calls, not Get() or Set(), and | 187 // |properties| supports only value() calls, not Get() or Set(), and |
294 // should be copied if needed. | 188 // should be copied if needed. |
295 virtual void DeviceFound( | 189 virtual void DeviceFound( |
296 const dbus::ObjectPath& adapter_path, const std::string& address, | 190 const dbus::ObjectPath& adapter_path, |
| 191 const std::string& address, |
297 const BluetoothDeviceClient::Properties& properties) OVERRIDE; | 192 const BluetoothDeviceClient::Properties& properties) OVERRIDE; |
298 | 193 |
299 // BluetoothAdapterClient::Observer override. | 194 // BluetoothAdapterClient::Observer override. |
300 // | 195 // |
301 // Called when the adapter with object path |object_path| can no | 196 // Called when the adapter with object path |object_path| can no |
302 // longer communicate with the discovered removed device with | 197 // longer communicate with the discovered removed device with |
303 // address |address|. | 198 // address |address|. |
304 virtual void DeviceDisappeared(const dbus::ObjectPath& object_path, | 199 virtual void DeviceDisappeared(const dbus::ObjectPath& object_path, |
305 const std::string& address) OVERRIDE; | 200 const std::string& address) OVERRIDE; |
306 | 201 |
307 // List of observers interested in event notifications from us. | 202 // List of observers interested in event notifications from us. |
308 ObserverList<BluetoothAdapter::Observer> observers_; | 203 ObserverList<BluetoothAdapter::Observer> observers_; |
309 | 204 |
310 // Object path of adapter for this instance, this is fixed at creation time | 205 // Object path of adapter for this instance, this is fixed at creation time |
311 // unless |track_default_| is true in which case we update it to always | 206 // unless |track_default_| is true in which case we update it to always |
312 // point at the default adapter. | 207 // point at the default adapter. |
313 bool track_default_; | 208 bool track_default_; |
314 dbus::ObjectPath object_path_; | 209 dbus::ObjectPath object_path_; |
315 | 210 |
316 // Address of the adapter. | |
317 std::string address_; | |
318 | |
319 // Name of the adapter. | |
320 std::string name_; | |
321 | |
322 // Tracked adapter state, cached locally so we only send change notifications | 211 // Tracked adapter state, cached locally so we only send change notifications |
323 // to observers on a genuine change. | 212 // to observers on a genuine change. |
324 bool powered_; | 213 bool powered_; |
325 bool discovering_; | 214 bool discovering_; |
326 | 215 |
327 // Devices paired with, connected to, discovered by, or visible to the | 216 // Devices paired with, connected to, discovered by, or visible to the |
328 // adapter. The key is the Bluetooth address of the device and the value | 217 // adapter. The key is the Bluetooth address of the device and the value |
329 // is the BluetoothDevice object whose lifetime is managed by the adapter | 218 // is the BluetoothDeviceChromeOs object whose lifetime is managed by the |
330 // instance. | 219 // adapter instance. |
331 typedef std::map<const std::string, BluetoothDevice*> DevicesMap; | 220 typedef std::map<const std::string, BluetoothDeviceChromeOs*> DevicesMap; |
332 DevicesMap devices_; | 221 DevicesMap devices_; |
333 | 222 |
334 // Note: This should remain the last member so it'll be destroyed and | 223 // Note: This should remain the last member so it'll be destroyed and |
335 // invalidate its weak pointers before any other members are destroyed. | 224 // invalidate its weak pointers before any other members are destroyed. |
336 base::WeakPtrFactory<BluetoothAdapter> weak_ptr_factory_; | 225 base::WeakPtrFactory<BluetoothAdapterChromeOs> weak_ptr_factory_; |
337 | 226 |
338 DISALLOW_COPY_AND_ASSIGN(BluetoothAdapter); | 227 DISALLOW_COPY_AND_ASSIGN(BluetoothAdapterChromeOs); |
339 }; | 228 }; |
340 | 229 |
341 } // namespace chromeos | 230 } // namespace chromeos |
342 | 231 |
343 #endif // CHROME_BROWSER_CHROMEOS_BLUETOOTH_BLUETOOTH_ADAPTER_H_ | 232 #endif // CHROME_BROWSER_CHROMEOS_BLUETOOTH_BLUETOOTH_ADAPTER_CHROMEOS_H_ |
OLD | NEW |