| 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_H_ |
| 6 #define CHROME_BROWSER_CHROMEOS_BLUETOOTH_BLUETOOTH_ADAPTER_H_ | 6 #define CHROME_BROWSER_CHROMEOS_BLUETOOTH_BLUETOOTH_ADAPTER_H_ |
| 7 | 7 |
| 8 #include <map> | |
| 9 #include <string> | 8 #include <string> |
| 10 #include <vector> | 9 #include <vector> |
| 11 | 10 |
| 12 #include "base/basictypes.h" | |
| 13 #include "base/callback.h" | 11 #include "base/callback.h" |
| 14 #include "base/memory/ref_counted.h" | 12 #include "base/memory/ref_counted.h" |
| 15 #include "base/observer_list.h" | |
| 16 #include "chromeos/dbus/bluetooth_adapter_client.h" | |
| 17 #include "chromeos/dbus/bluetooth_device_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" | |
| 21 | 13 |
| 22 namespace chromeos { | 14 namespace chromeos { |
| 23 | 15 |
| 24 class BluetoothDevice; | 16 class BluetoothDevice; |
| 25 | 17 |
| 26 // The BluetoothAdapter class represents a local Bluetooth adapter which | 18 struct BluetoothOutOfBandPairingData; |
| 27 // may be used to interact with remote Bluetooth devices. As well as | 19 |
| 28 // providing support for determining whether an adapter is present, and | 20 // BluetoothAdapter represents a local Bluetooth adapter which may be used to |
| 29 // whether the radio is powered, this class also provides support for | 21 // interact with remote Bluetooth devices. As well as providing support for |
| 30 // obtaining the list of remote devices known to the adapter, discovering | 22 // determining whether an adapter is present, and whether the radio is powered, |
| 31 // new devices, and providing notification of updates to device information. | 23 // this class also provides support for obtaining the list of remote devices |
| 32 // | 24 // known to the adapter, discovering new devices, and providing notification of |
| 33 // The class may be instantiated for either a specific adapter, or for the | 25 // updates to device information. |
| 34 // generic "default adapter" which may change depending on availability. | 26 class BluetoothAdapter : public base::RefCounted<BluetoothAdapter> { |
| 35 class BluetoothAdapter : public base::RefCounted<BluetoothAdapter>, | |
| 36 public BluetoothManagerClient::Observer, | |
| 37 public BluetoothAdapterClient::Observer, | |
| 38 public BluetoothDeviceClient::Observer { | |
| 39 public: | 27 public: |
| 40 // Interface for observing changes from bluetooth adapters. | 28 // Interface for observing changes from bluetooth adapters. |
| 41 class Observer { | 29 class Observer { |
| 42 public: | 30 public: |
| 43 virtual ~Observer() {} | 31 virtual ~Observer() {} |
| 44 | 32 |
| 45 // Called when the presence of the adapter |adapter| changes, when | 33 // Called when the presence of the adapter |adapter| changes, when |
| 46 // |present| is true the adapter is now present, false means the adapter | 34 // |present| is true the adapter is now present, false means the adapter |
| 47 // has been removed from the system. | 35 // has been removed from the system. |
| 48 virtual void AdapterPresentChanged(BluetoothAdapter* adapter, | 36 virtual void AdapterPresentChanged(BluetoothAdapter* adapter, |
| (...skipping 25 matching lines...) Expand all Loading... |
| 74 virtual void DeviceChanged(BluetoothAdapter* adapter, | 62 virtual void DeviceChanged(BluetoothAdapter* adapter, |
| 75 BluetoothDevice* device) {} | 63 BluetoothDevice* device) {} |
| 76 | 64 |
| 77 // Called when the device |device| is removed from the adapter |adapter|, | 65 // Called when the device |device| is removed from the adapter |adapter|, |
| 78 // either as a result of a discovered device being lost between discovering | 66 // either as a result of a discovered device being lost between discovering |
| 79 // phases or pairing information deleted. |device| should not be cached. | 67 // phases or pairing information deleted. |device| should not be cached. |
| 80 virtual void DeviceRemoved(BluetoothAdapter* adapter, | 68 virtual void DeviceRemoved(BluetoothAdapter* adapter, |
| 81 BluetoothDevice* device) {} | 69 BluetoothDevice* device) {} |
| 82 }; | 70 }; |
| 83 | 71 |
| 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 | 72 // 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. | 73 // is called, in the success case the callback is simply not called. |
| 92 typedef base::Callback<void()> ErrorCallback; | 74 typedef base::Callback<void()> ErrorCallback; |
| 93 | 75 |
| 94 // The BluetoothOutOfBandPairingDataCallback is used to return | 76 // The BluetoothOutOfBandPairingDataCallback is used to return |
| 95 // BluetoothOutOfBandPairingData to the caller. | 77 // BluetoothOutOfBandPairingData to the caller. |
| 96 typedef base::Callback<void(const BluetoothOutOfBandPairingData& data)> | 78 typedef base::Callback<void(const BluetoothOutOfBandPairingData& data)> |
| 97 BluetoothOutOfBandPairingDataCallback; | 79 BluetoothOutOfBandPairingDataCallback; |
| 98 | 80 |
| 81 // Adds and removes observers for events on this bluetooth adapter, |
| 82 // if monitoring multiple adapters check the |adapter| parameter of |
| 83 // observer methods to determine which adapter is issuing the event. |
| 84 virtual void AddObserver(BluetoothAdapter::Observer* observer) = 0; |
| 85 virtual void RemoveObserver( |
| 86 BluetoothAdapter::Observer* observer) = 0; |
| 87 |
| 99 // The address of this adapter. The address format is "XX:XX:XX:XX:XX:XX", | 88 // The address of this adapter. The address format is "XX:XX:XX:XX:XX:XX", |
| 100 // where each XX is a hexadecimal number. | 89 // where each XX is a hexadecimal number. |
| 101 const std::string& address() const { return address_; } | 90 virtual const std::string& address() const; |
| 102 | 91 |
| 103 // The name of the adapter. | 92 // The name of the adapter. |
| 104 const std::string& name() const { return name_; } | 93 virtual const std::string& name() const; |
| 105 | 94 |
| 106 // Indicates whether the adapter is actually present on the system, for | 95 // Indicates whether the adapter is actually present on the system, for |
| 107 // the default adapter this indicates whether any adapter is present. An | 96 // the default adapter this indicates whether any adapter is present. An |
| 108 // adapter is only considered present if the address has been obtained. | 97 // adapter is only considered present if the address has been obtained. |
| 109 virtual bool IsPresent() const; | 98 virtual bool IsPresent() const = 0; |
| 110 | 99 |
| 111 // Indicates whether the adapter radio is powered. | 100 // Indicates whether the adapter radio is powered. |
| 112 virtual bool IsPowered() const; | 101 virtual bool IsPowered() const = 0; |
| 113 | 102 |
| 114 // Requests a change to the adapter radio power, setting |powered| to true | 103 // 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 | 104 // 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. | 105 // will be called. On failure, |error_callback| will be called. |
| 117 void SetPowered(bool powered, | 106 virtual void SetPowered(bool powered, |
| 118 const base::Closure& callback, | 107 const base::Closure& callback, |
| 119 const ErrorCallback& error_callback); | 108 const ErrorCallback& error_callback) = 0; |
| 120 | 109 |
| 121 // Indicates whether the adapter is currently discovering new devices, | 110 // Indicates whether the adapter is currently discovering new devices, |
| 122 // note that a typical discovery process has phases of this being true | 111 // note that a typical discovery process has phases of this being true |
| 123 // followed by phases of being false when the adapter interrogates the | 112 // followed by phases of being false when the adapter interrogates the |
| 124 // devices found. | 113 // devices found. |
| 125 virtual bool IsDiscovering() const; | 114 virtual bool IsDiscovering() const = 0; |
| 126 | 115 |
| 127 // Requests that the adapter either begin discovering new devices when | 116 // Requests that the adapter either begin discovering new devices when |
| 128 // |discovering| is true, or cease any discovery when false. On success, | 117 // |discovering| is true, or cease any discovery when false. On success, |
| 129 // callback will be called. On failure, |error_callback| will be called. | 118 // callback will be called. On failure, |error_callback| will be called. |
| 130 virtual void SetDiscovering(bool discovering, | 119 virtual void SetDiscovering(bool discovering, |
| 131 const base::Closure& callback, | 120 const base::Closure& callback, |
| 132 const ErrorCallback& error_callback); | 121 const ErrorCallback& error_callback) = 0; |
| 133 | 122 |
| 134 // Requests the list of devices from the adapter, all are returned | 123 // Requests the list of devices from the adapter, all are returned |
| 135 // including those currently connected and those paired. Use the | 124 // including those currently connected and those paired. Use the |
| 136 // returned device pointers to determine which they are. | 125 // returned device pointers to determine which they are. |
| 137 typedef std::vector<BluetoothDevice*> DeviceList; | 126 typedef std::vector<BluetoothDevice*> DeviceList; |
| 138 virtual DeviceList GetDevices(); | 127 virtual DeviceList GetDevices(); |
| 139 typedef std::vector<const BluetoothDevice*> ConstDeviceList; | 128 typedef std::vector<const BluetoothDevice*> ConstDeviceList; |
| 140 virtual ConstDeviceList GetDevices() const; | 129 virtual ConstDeviceList GetDevices() const = 0; |
| 141 | 130 |
| 142 // Returns a pointer to the device with the given address |address| or | 131 // Returns a pointer to the device with the given address |address| or |
| 143 // NULL if no such device is known. | 132 // NULL if no such device is known. |
| 144 virtual BluetoothDevice* GetDevice(const std::string& address); | 133 virtual BluetoothDevice* GetDevice(const std::string& address) = 0; |
| 145 virtual const BluetoothDevice* GetDevice(const std::string& address) const; | 134 virtual const BluetoothDevice* GetDevice( |
| 135 const std::string& address) const = 0; |
| 146 | 136 |
| 147 // Requests the local Out Of Band pairing data. | 137 // Requests the local Out Of Band pairing data. |
| 148 virtual void ReadLocalOutOfBandPairingData( | 138 virtual void ReadLocalOutOfBandPairingData( |
| 149 const BluetoothOutOfBandPairingDataCallback& callback, | 139 const BluetoothOutOfBandPairingDataCallback& callback, |
| 150 const ErrorCallback& error_callback); | 140 const ErrorCallback& error_callback) = 0; |
| 151 | 141 |
| 152 // Returns the shared instance for the default adapter, whichever that may | 142 protected: |
| 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 | |
| 162 private: | |
| 163 friend class base::RefCounted<BluetoothAdapter>; | 143 friend class base::RefCounted<BluetoothAdapter>; |
| 164 friend class BluetoothDevice; | |
| 165 friend class MockBluetoothAdapter; | |
| 166 | |
| 167 BluetoothAdapter(); | |
| 168 virtual ~BluetoothAdapter(); | 144 virtual ~BluetoothAdapter(); |
| 169 | 145 |
| 170 // Obtains the default adapter object path from the Bluetooth Daemon | |
| 171 // and tracks future changes to it. | |
| 172 void TrackDefaultAdapter(); | |
| 173 | |
| 174 // Obtains the object paht for the adapter named by |address| from the | |
| 175 // Bluetooth Daemon. | |
| 176 void FindAdapter(const std::string& address); | |
| 177 | |
| 178 // Called by dbus:: in response to the method call sent by both | |
| 179 // DefaultAdapter() and FindAdapter(), |object_path| will contain the | |
| 180 // dbus object path of the requested adapter when |success| is true. | |
| 181 void AdapterCallback(const dbus::ObjectPath& adapter_path, bool success); | |
| 182 | |
| 183 // BluetoothManagerClient::Observer override. | |
| 184 // | |
| 185 // Called when the default local bluetooth adapter changes. | |
| 186 // |object_path| is the dbus object path of the new default adapter. | |
| 187 // Not called if all adapters are removed. | |
| 188 virtual void DefaultAdapterChanged(const dbus::ObjectPath& adapter_path) | |
| 189 OVERRIDE; | |
| 190 | |
| 191 // BluetoothManagerClient::Observer override. | |
| 192 // | |
| 193 // Called when a local bluetooth adapter is removed. | |
| 194 // |object_path| is the dbus object path of the adapter. | |
| 195 virtual void AdapterRemoved(const dbus::ObjectPath& adapter_path) OVERRIDE; | |
| 196 | |
| 197 // Changes the tracked adapter to the dbus object path |adapter_path|, | |
| 198 // clearing information from the previously tracked adapter and updating | |
| 199 // to the new adapter. | |
| 200 void ChangeAdapter(const dbus::ObjectPath& adapter_path); | |
| 201 | |
| 202 // Clears the tracked adapter information. | |
| 203 void RemoveAdapter(); | |
| 204 | |
| 205 // Called by dbus:: in response to the method call send by SetPowered(). | |
| 206 // |callback| and |error_callback| are the callbacks passed to SetPowered(). | |
| 207 void OnSetPowered(const base::Closure& callback, | |
| 208 const ErrorCallback& error_callback, | |
| 209 bool success); | |
| 210 | |
| 211 // Updates the tracked state of the adapter's radio power to |powered| | |
| 212 // and notifies observers. Called on receipt of a property changed signal, | |
| 213 // and directly using values obtained from properties. | |
| 214 void PoweredChanged(bool powered); | |
| 215 | |
| 216 // Called by dbus:: in response to the method calls send by SetDiscovering(). | |
| 217 // |callback| and |error_callback| are the callbacks passed to | |
| 218 // SetDiscovering(). | |
| 219 void OnStartDiscovery(const base::Closure& callback, | |
| 220 const ErrorCallback& error_callback, | |
| 221 const dbus::ObjectPath& adapter_path, | |
| 222 bool success); | |
| 223 void OnStopDiscovery(const base::Closure& callback, | |
| 224 const ErrorCallback& error_callback, | |
| 225 const dbus::ObjectPath& adapter_path, | |
| 226 bool success); | |
| 227 | |
| 228 // Updates the tracked state of the adapter's discovering state to | |
| 229 // |discovering| and notifies observers. Called on receipt of a property | |
| 230 // changed signal, and directly using values obtained from properties. | |
| 231 void DiscoveringChanged(bool discovering); | |
| 232 | |
| 233 // Called by dbus:: in response to the ReadLocalData method call. | |
| 234 void OnReadLocalData(const BluetoothOutOfBandPairingDataCallback& callback, | |
| 235 const ErrorCallback& error_callback, | |
| 236 const BluetoothOutOfBandPairingData& data, | |
| 237 bool success); | |
| 238 | |
| 239 // BluetoothAdapterClient::Observer override. | |
| 240 // | |
| 241 // Called when the adapter with object path |adapter_path| has a | |
| 242 // change in value of the property named |property_name|. | |
| 243 virtual void AdapterPropertyChanged(const dbus::ObjectPath& adapter_path, | |
| 244 const std::string& property_name) | |
| 245 OVERRIDE; | |
| 246 | |
| 247 // BluetoothDeviceClient::Observer override. | |
| 248 // | |
| 249 // Called when the device with object path |device_path| has a | |
| 250 // change in value of the property named |property_name|. | |
| 251 virtual void DevicePropertyChanged(const dbus::ObjectPath& device_path, | |
| 252 const std::string& property_name) | |
| 253 OVERRIDE; | |
| 254 | |
| 255 // Updates information on the device with object path |device_path|, | |
| 256 // adding it to the |devices_| map if not already present. | |
| 257 void UpdateDevice(const dbus::ObjectPath& device_path); | |
| 258 | |
| 259 // Clears the |devices_| list, notifying obsevers of the device removal. | |
| 260 void ClearDevices(); | |
| 261 | |
| 262 // BluetoothAdapterClient::Observer override. | |
| 263 // | |
| 264 // Called when the adapter with object path |object_path| has a | |
| 265 // new known device with object path |object_path|. | |
| 266 virtual void DeviceCreated(const dbus::ObjectPath& adapter_path, | |
| 267 const dbus::ObjectPath& device_path) OVERRIDE; | |
| 268 | |
| 269 // BluetoothAdapterClient::Observer override. | |
| 270 // | |
| 271 // Called when the adapter with object path |object_path| removes | |
| 272 // the known device with object path |object_path|. | |
| 273 virtual void DeviceRemoved(const dbus::ObjectPath& adapter_path, | |
| 274 const dbus::ObjectPath& device_path) OVERRIDE; | |
| 275 | |
| 276 // Updates the adapter |devices_| list, adding or updating devices using | |
| 277 // the object paths in the|devices| list. This doesn't remove devices, | |
| 278 // relying instead on the DeviceRemoved() signal for that. Called on | |
| 279 // receipt of a property changed signal, and directly using values obtained | |
| 280 // from properties. | |
| 281 void DevicesChanged(const std::vector<dbus::ObjectPath>& devices); | |
| 282 | |
| 283 // Clears discovered devices from the |devices_| list, notifying | |
| 284 // observers, and leaving only those devices with a dbus object path. | |
| 285 void ClearDiscoveredDevices(); | |
| 286 | |
| 287 // BluetoothAdapterClient::Observer override. | |
| 288 // | |
| 289 // Called when the adapter with object path |object_path| discovers | |
| 290 // a new remote device with address |address| and properties | |
| 291 // |properties|, there is no device object path until connected. | |
| 292 // | |
| 293 // |properties| supports only value() calls, not Get() or Set(), and | |
| 294 // should be copied if needed. | |
| 295 virtual void DeviceFound( | |
| 296 const dbus::ObjectPath& adapter_path, const std::string& address, | |
| 297 const BluetoothDeviceClient::Properties& properties) OVERRIDE; | |
| 298 | |
| 299 // BluetoothAdapterClient::Observer override. | |
| 300 // | |
| 301 // Called when the adapter with object path |object_path| can no | |
| 302 // longer communicate with the discovered removed device with | |
| 303 // address |address|. | |
| 304 virtual void DeviceDisappeared(const dbus::ObjectPath& object_path, | |
| 305 const std::string& address) OVERRIDE; | |
| 306 | |
| 307 // List of observers interested in event notifications from us. | |
| 308 ObserverList<BluetoothAdapter::Observer> observers_; | |
| 309 | |
| 310 // 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 | |
| 312 // point at the default adapter. | |
| 313 bool track_default_; | |
| 314 dbus::ObjectPath object_path_; | |
| 315 | |
| 316 // Address of the adapter. | 146 // Address of the adapter. |
| 317 std::string address_; | 147 std::string address_; |
| 318 | 148 |
| 319 // Name of the adapter. | 149 // Name of the adapter. |
| 320 std::string name_; | 150 std::string name_; |
| 321 | |
| 322 // Tracked adapter state, cached locally so we only send change notifications | |
| 323 // to observers on a genuine change. | |
| 324 bool powered_; | |
| 325 bool discovering_; | |
| 326 | |
| 327 // 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 | |
| 329 // is the BluetoothDevice object whose lifetime is managed by the adapter | |
| 330 // instance. | |
| 331 typedef std::map<const std::string, BluetoothDevice*> DevicesMap; | |
| 332 DevicesMap devices_; | |
| 333 | |
| 334 // Note: This should remain the last member so it'll be destroyed and | |
| 335 // invalidate its weak pointers before any other members are destroyed. | |
| 336 base::WeakPtrFactory<BluetoothAdapter> weak_ptr_factory_; | |
| 337 | |
| 338 DISALLOW_COPY_AND_ASSIGN(BluetoothAdapter); | |
| 339 }; | 151 }; |
| 340 | 152 |
| 341 } // namespace chromeos | 153 } // namespace chromeos |
| 342 | 154 |
| 343 #endif // CHROME_BROWSER_CHROMEOS_BLUETOOTH_BLUETOOTH_ADAPTER_H_ | 155 #endif // CHROME_BROWSER_CHROMEOS_BLUETOOTH_BLUETOOTH_ADAPTER_H_ |
| OLD | NEW |