Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(79)

Side by Side Diff: chrome/browser/chromeos/bluetooth/bluetooth_adapter_chromeos.h

Issue 10899037: Refactoring bluetooth API code. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: C Created 8 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 const std::string& address() const OVERRIDE;
44 38 virtual const std::string& name() const OVERRIDE;
45 // Called when the presence of the adapter |adapter| changes, when 39 virtual bool IsPresent() const OVERRIDE;
46 // |present| is true the adapter is now present, false means the adapter 40 virtual bool IsPowered() const OVERRIDE;
47 // has been removed from the system. 41 virtual void SetPowered(bool powered,
48 virtual void AdapterPresentChanged(BluetoothAdapter* adapter, 42 const base::Closure& callback,
49 bool present) {} 43 const ErrorCallback& error_callback) OVERRIDE;
50 44 virtual bool IsDiscovering() const OVERRIDE;
51 // Called when the radio power state of the adapter |adapter| changes,
52 // when |powered| is true the adapter radio is powered, false means the
53 // adapter radio is off.
54 virtual void AdapterPoweredChanged(BluetoothAdapter* adapter,
55 bool powered) {}
56
57 // Called when the discovering state of the adapter |adapter| changes,
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, 45 virtual void SetDiscovering(bool discovering,
131 const base::Closure& callback, 46 const base::Closure& callback,
132 const ErrorCallback& error_callback); 47 const ErrorCallback& error_callback) OVERRIDE;
133 48 virtual DeviceList GetDevices() OVERRIDE;
134 // Requests the list of devices from the adapter, all are returned 49 virtual ConstDeviceList GetDevices() const OVERRIDE;
135 // including those currently connected and those paired. Use the 50 virtual BluetoothDevice* GetDevice(const std::string& address) OVERRIDE;
136 // returned device pointers to determine which they are. 51 virtual const BluetoothDevice* GetDevice(
137 typedef std::vector<BluetoothDevice*> DeviceList; 52 const std::string& address) const OVERRIDE;
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( 53 virtual void ReadLocalOutOfBandPairingData(
149 const BluetoothOutOfBandPairingDataCallback& callback, 54 const BluetoothOutOfBandPairingDataCallback& callback,
150 const ErrorCallback& error_callback); 55 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 56
162 private: 57 private:
163 friend class base::RefCounted<BluetoothAdapter>; 58 friend class BluetoothAdapterFactory;
164 friend class BluetoothDevice; 59 friend class BluetoothDeviceChromeOs;
165 friend class MockBluetoothAdapter; 60 friend class MockBluetoothAdapter;
166 61
167 BluetoothAdapter(); 62 BluetoothAdapterChromeOs();
168 virtual ~BluetoothAdapter(); 63 virtual ~BluetoothAdapterChromeOs();
169 64
170 // Obtains the default adapter object path from the Bluetooth Daemon 65 // Obtains the default adapter object path from the Bluetooth Daemon
171 // and tracks future changes to it. 66 // and tracks future changes to it.
172 void TrackDefaultAdapter(); 67 void TrackDefaultAdapter();
173 68
174 // Obtains the object paht for the adapter named by |address| from the 69 // Obtains the object paht for the adapter named by |address| from the
175 // Bluetooth Daemon. 70 // Bluetooth Daemon.
176 void FindAdapter(const std::string& address); 71 void FindAdapter(const std::string& address);
177 72
178 // Called by dbus:: in response to the method call sent by both 73 // Called by dbus:: in response to the method call sent by both
(...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after
286 181
287 // BluetoothAdapterClient::Observer override. 182 // BluetoothAdapterClient::Observer override.
288 // 183 //
289 // Called when the adapter with object path |object_path| discovers 184 // Called when the adapter with object path |object_path| discovers
290 // a new remote device with address |address| and properties 185 // a new remote device with address |address| and properties
291 // |properties|, there is no device object path until connected. 186 // |properties|, there is no device object path until connected.
292 // 187 //
293 // |properties| supports only value() calls, not Get() or Set(), and 188 // |properties| supports only value() calls, not Get() or Set(), and
294 // should be copied if needed. 189 // should be copied if needed.
295 virtual void DeviceFound( 190 virtual void DeviceFound(
296 const dbus::ObjectPath& adapter_path, const std::string& address, 191 const dbus::ObjectPath& adapter_path,
192 const std::string& address,
297 const BluetoothDeviceClient::Properties& properties) OVERRIDE; 193 const BluetoothDeviceClient::Properties& properties) OVERRIDE;
298 194
299 // BluetoothAdapterClient::Observer override. 195 // BluetoothAdapterClient::Observer override.
300 // 196 //
301 // Called when the adapter with object path |object_path| can no 197 // Called when the adapter with object path |object_path| can no
302 // longer communicate with the discovered removed device with 198 // longer communicate with the discovered removed device with
303 // address |address|. 199 // address |address|.
304 virtual void DeviceDisappeared(const dbus::ObjectPath& object_path, 200 virtual void DeviceDisappeared(const dbus::ObjectPath& object_path,
305 const std::string& address) OVERRIDE; 201 const std::string& address) OVERRIDE;
306 202
(...skipping 12 matching lines...) Expand all
319 // Name of the adapter. 215 // Name of the adapter.
320 std::string name_; 216 std::string name_;
321 217
322 // Tracked adapter state, cached locally so we only send change notifications 218 // Tracked adapter state, cached locally so we only send change notifications
323 // to observers on a genuine change. 219 // to observers on a genuine change.
324 bool powered_; 220 bool powered_;
325 bool discovering_; 221 bool discovering_;
326 222
327 // Devices paired with, connected to, discovered by, or visible to the 223 // 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 224 // 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 225 // is the BluetoothDeviceChromeOs object whose lifetime is managed by the
330 // instance. 226 // adapter instance.
331 typedef std::map<const std::string, BluetoothDevice*> DevicesMap; 227 typedef std::map<const std::string, BluetoothDeviceChromeOs*> DevicesMap;
332 DevicesMap devices_; 228 DevicesMap devices_;
333 229
334 // Note: This should remain the last member so it'll be destroyed and 230 // Note: This should remain the last member so it'll be destroyed and
335 // invalidate its weak pointers before any other members are destroyed. 231 // invalidate its weak pointers before any other members are destroyed.
336 base::WeakPtrFactory<BluetoothAdapter> weak_ptr_factory_; 232 base::WeakPtrFactory<BluetoothAdapterChromeOs> weak_ptr_factory_;
337 233
338 DISALLOW_COPY_AND_ASSIGN(BluetoothAdapter); 234 DISALLOW_COPY_AND_ASSIGN(BluetoothAdapterChromeOs);
339 }; 235 };
340 236
341 } // namespace chromeos 237 } // namespace chromeos
342 238
343 #endif // CHROME_BROWSER_CHROMEOS_BLUETOOTH_BLUETOOTH_ADAPTER_H_ 239 #endif // CHROME_BROWSER_CHROMEOS_BLUETOOTH_BLUETOOTH_ADAPTER_CHROMEOS_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698