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

Side by Side Diff: components/proximity_auth/ble/bluetooth_low_energy_weave_client_connection.h

Issue 2075313002: Substituting legacy protocol with uWeave protocol (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: minor change Created 4 years, 5 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
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 COMPONENTS_PROXIMITY_AUTH_BLE_BLUETOOTH_LOW_ENERGY_CONNECTION_H_ 5 #ifndef COMPONENTS_PROXIMITY_AUTH_BLE_BLUETOOTH_LOW_ENERGY_WEAVE_CLIENT_CONNECTI ON_H_
6 #define COMPONENTS_PROXIMITY_AUTH_BLE_BLUETOOTH_LOW_ENERGY_CONNECTION_H_ 6 #define COMPONENTS_PROXIMITY_AUTH_BLE_BLUETOOTH_LOW_ENERGY_WEAVE_CLIENT_CONNECTI ON_H_
7 7
8 #include <stddef.h> 8 #include <stddef.h>
9 #include <stdint.h> 9 #include <stdint.h>
10 10
11 #include <memory> 11 #include <memory>
12 #include <queue> 12 #include <queue>
13 #include <string> 13 #include <string>
14 14
15 #include "base/macros.h" 15 #include "base/macros.h"
16 #include "base/memory/ref_counted.h" 16 #include "base/memory/ref_counted.h"
17 #include "base/memory/weak_ptr.h" 17 #include "base/memory/weak_ptr.h"
18 #include "base/time/time.h" 18 #include "base/time/time.h"
19 #include "components/proximity_auth/ble/bluetooth_low_energy_characteristics_fin der.h" 19 #include "components/proximity_auth/ble/bluetooth_low_energy_characteristics_fin der.h"
20 #include "components/proximity_auth/ble/bluetooth_low_energy_weave_packet_genera tor.h"
21 #include "components/proximity_auth/ble/bluetooth_low_energy_weave_packet_receiv er.h"
20 #include "components/proximity_auth/ble/fake_wire_message.h" 22 #include "components/proximity_auth/ble/fake_wire_message.h"
21 #include "components/proximity_auth/ble/remote_attribute.h" 23 #include "components/proximity_auth/ble/remote_attribute.h"
22 #include "components/proximity_auth/connection.h" 24 #include "components/proximity_auth/connection.h"
23 #include "device/bluetooth/bluetooth_adapter.h" 25 #include "device/bluetooth/bluetooth_adapter.h"
24 #include "device/bluetooth/bluetooth_device.h" 26 #include "device/bluetooth/bluetooth_device.h"
25 #include "device/bluetooth/bluetooth_gatt_notify_session.h" 27 #include "device/bluetooth/bluetooth_gatt_notify_session.h"
26 #include "device/bluetooth/bluetooth_remote_gatt_characteristic.h" 28 #include "device/bluetooth/bluetooth_remote_gatt_characteristic.h"
27 #include "device/bluetooth/bluetooth_uuid.h" 29 #include "device/bluetooth/bluetooth_uuid.h"
28 30
29 namespace base { 31 namespace base {
30 class TaskRunner; 32 class TaskRunner;
31 } 33 }
32 34
33 namespace proximity_auth { 35 namespace proximity_auth {
34
35 class BluetoothThrottler; 36 class BluetoothThrottler;
36 37
37 // Represents a connection with a remote device over Bluetooth low energy. The 38 namespace weave {
38 // connection is a persistent bidirectional channel for sending and receiving 39 // Creates GATT connection on top of the BLE connection and act as a Client.
39 // wire messages. The remote device is the peripheral mode and the service 40 // uWeave communication follows the flow:
40 // contains two characteristics: one to send data and another to receive it. 41 // Client | Server
41 // 42 // ---------------------------------|--------------------------------
42 // The connection flow is described below. 43 // send connection request |
43 // 44 // | receive connection request
44 // Discover Reader and Writer Characteristics 45 // | send connection response
45 // | 46 // receive connection response |
46 // | 47 // opt: send data | opt: send data
47 // | 48 // receive data | receive data
48 // Start Notify Session 49 // opt: close connection | opt: close connection
49 // | 50 class BluetoothLowEnergyWeaveClientConnection
50 // | 51 : public Connection,
51 // | 52 public device::BluetoothAdapter::Observer {
52 // Write kInviteToConnectSignal to Writer Characteristic
53 // |
54 // |
55 // |
56 // Read kInvitationResponseSignal from Reader Characteristic
57 // |
58 // |
59 // |
60 // Proximity Auth Connection Established
61 class BluetoothLowEnergyConnection : public Connection,
62 public device::BluetoothAdapter::Observer {
63 public: 53 public:
64 // Signals sent to the remote device to indicate connection related events. 54 class Factory {
65 enum class ControlSignal : uint32_t { 55 public:
66 kInviteToConnectSignal = 0, 56 static std::unique_ptr<BluetoothLowEnergyWeaveClientConnection>
67 kInvitationResponseSignal = 1, 57 NewInstance();
68 kSendSignal = 2, 58
69 kDisconnectSignal = 3, 59 // Exposed for testing.
60 static void SetInstanceForTesting(Factory* factory);
61
62 protected:
63 // Exposed for testing.
64 virtual std::unique_ptr<BluetoothLowEnergyWeaveClientConnection>
65 BuildInstance();
66
67 private:
68 static Factory* factory_instance_;
70 }; 69 };
71 70
72 // The sub-state of a proximity_auth::BluetoothLowEnergyConnection class 71 // The sub-state of a proximity_auth::BluetoothLowEnergyWeaveClientConnection
73 // extends the IN_PROGRESS state of proximity_auth::Connection::Status. 72 // extends the IN_PROGRESS state of proximity_auth::Connection::Status.
74 enum class SubStatus { 73 enum SubStatus {
75 DISCONNECTED, 74 DISCONNECTED,
76 WAITING_GATT_CONNECTION, 75 WAITING_GATT_CONNECTION,
77 WAITING_CHARACTERISTICS, 76 WAITING_CHARACTERISTICS,
78 CHARACTERISTICS_FOUND, 77 CHARACTERISTICS_FOUND,
79 WAITING_NOTIFY_SESSION, 78 WAITING_NOTIFY_SESSION,
80 NOTIFY_SESSION_READY, 79 NOTIFY_SESSION_READY,
81 WAITING_RESPONSE_SIGNAL, 80 WAITING_CONNECTION_RESPONSE,
82 CONNECTED, 81 CONNECTED,
83 }; 82 };
84 83
85 // Constructs a Bluetooth low energy connection to the service with 84 // Constructs a Bluetooth low energy connection to the service with
86 // |remote_service_| on the |remote_device|. The |adapter| must be already 85 // |remote_service_| on the |remote_device|. The |adapter| must be already
87 // initaalized and ready. The GATT connection may alreaady be established and 86 // initialized and ready. The GATT connection may alreaady be established and
88 // pass through |gatt_connection|. A subsequent call to Connect() must be 87 // pass through |gatt_connection|. A subsequent call to Connect() must be
89 // made. 88 // made.
90 BluetoothLowEnergyConnection( 89 BluetoothLowEnergyWeaveClientConnection(
91 const RemoteDevice& remote_device, 90 const RemoteDevice& remote_device,
92 scoped_refptr<device::BluetoothAdapter> adapter, 91 scoped_refptr<device::BluetoothAdapter> adapter,
93 const device::BluetoothUUID remote_service_uuid, 92 const device::BluetoothUUID remote_service_uuid,
94 BluetoothThrottler* bluetooth_throttler, 93 BluetoothThrottler* bluetooth_throttler,
95 int max_number_of_write_attempts); 94 int max_number_of_write_attempts);
96 95
97 ~BluetoothLowEnergyConnection() override; 96 ~BluetoothLowEnergyWeaveClientConnection() override;
98 97
99 // proximity_auth::Connection: 98 // proximity_auth::Connection:
100 void Connect() override; 99 void Connect() override;
101 void Disconnect() override; 100 void Disconnect() override;
102 std::string GetDeviceAddress() override; 101 std::string GetDeviceAddress() override;
103 102
104 protected: 103 protected:
105 // Exposed for testing. 104 // Exposed for testing.
106 void SetSubStatus(SubStatus status); 105 void SetSubStatus(SubStatus status);
107 SubStatus sub_status() { return sub_status_; } 106 SubStatus sub_status() { return sub_status_; }
(...skipping 12 matching lines...) Expand all
120 void SendMessageImpl(std::unique_ptr<WireMessage> message) override; 119 void SendMessageImpl(std::unique_ptr<WireMessage> message) override;
121 120
122 // device::BluetoothAdapter::Observer: 121 // device::BluetoothAdapter::Observer:
123 void DeviceChanged(device::BluetoothAdapter* adapter, 122 void DeviceChanged(device::BluetoothAdapter* adapter,
124 device::BluetoothDevice* device) override; 123 device::BluetoothDevice* device) override;
125 void DeviceRemoved(device::BluetoothAdapter* adapter, 124 void DeviceRemoved(device::BluetoothAdapter* adapter,
126 device::BluetoothDevice* device) override; 125 device::BluetoothDevice* device) override;
127 void GattCharacteristicValueChanged( 126 void GattCharacteristicValueChanged(
128 device::BluetoothAdapter* adapter, 127 device::BluetoothAdapter* adapter,
129 device::BluetoothRemoteGattCharacteristic* characteristic, 128 device::BluetoothRemoteGattCharacteristic* characteristic,
130 const std::vector<uint8_t>& value) override; 129 const Packet& value) override;
131 130
132 private: 131 private:
133 // Represents a request to write |value| to a some characteristic. 132 // Represents a request to write |value| to a some characteristic.
134 // |is_last_write_for_wire_messsage| indicates whether this request 133 // |is_last_write_for_wire_messsage| indicates whether this request
135 // corresponds to the last write request for some wire message. 134 // corresponds to the last write request for some wire message.
136 // A WireMessage corresponds to exactly two WriteRequest: the first containing
137 // a kSendSignal + the size of the WireMessage, and the second containing a
138 // SendStatusSignal + the serialized WireMessage.
139 struct WriteRequest { 135 struct WriteRequest {
140 WriteRequest(const std::vector<uint8_t>& val, bool flag); 136 WriteRequest(const Packet& val, bool is_last_write_for_wire_message);
141 WriteRequest(const WriteRequest& other); 137 WriteRequest(const WriteRequest& other);
142 ~WriteRequest(); 138 ~WriteRequest();
143 139
144 std::vector<uint8_t> value; 140 Packet value;
145 bool is_last_write_for_wire_message; 141 bool is_last_write_for_wire_message;
146 int number_of_failed_attempts; 142 int number_of_failed_attempts;
147 }; 143 };
148 144
149 // Creates the GATT connection with |remote_device|. 145 // Creates the GATT connection with |remote_device|.
150 void CreateGattConnection(); 146 void CreateGattConnection();
151 147
152 // Called when a GATT connection is created. 148 // Called when a GATT connection is created.
153 void OnGattConnectionCreated( 149 void OnGattConnectionCreated(
154 std::unique_ptr<device::BluetoothGattConnection> gatt_connection); 150 std::unique_ptr<device::BluetoothGattConnection> gatt_connection);
155 151
156 // Callback called when there is an error creating the GATT connection. 152 // Callback called when there is an error creating the GATT connection.
157 void OnCreateGattConnectionError( 153 void OnCreateGattConnectionError(
158 device::BluetoothDevice::ConnectErrorCode error_code); 154 device::BluetoothDevice::ConnectErrorCode error_code);
159 155
160 // Callback called when |to_peripheral_char_| and |from_peripheral_char_| were 156 // Callback called when |tx_characteristic_| and |rx_characteristic_| were
161 // found. 157 // found.
162 void OnCharacteristicsFound(const RemoteAttribute& service, 158 void OnCharacteristicsFound(const RemoteAttribute& service,
163 const RemoteAttribute& to_peripheral_char, 159 const RemoteAttribute& tx_characteristic,
164 const RemoteAttribute& from_peripheral_char); 160 const RemoteAttribute& rx_characteristic);
165 161
166 // Callback called there was an error finding the characteristics. 162 // Callback called there was an error finding the characteristics.
167 void OnCharacteristicsFinderError( 163 void OnCharacteristicsFinderError(const RemoteAttribute& tx_characteristic,
168 const RemoteAttribute& to_peripheral_char, 164 const RemoteAttribute& rx_characteristic);
169 const RemoteAttribute& from_peripheral_char);
170 165
171 // Starts a notify session for |from_peripheral_char_| when ready 166 // Starts a notify session for |rx_characteristic_| when ready
172 // (SubStatus::CHARACTERISTICS_FOUND). 167 // (SubStatus::CHARACTERISTICS_FOUND).
173 void StartNotifySession(); 168 void StartNotifySession();
174 169
175 // Called when a notification session is successfully started for 170 // Called when a notification session is successfully started for
176 // |from_peripheral_char_| characteristic. 171 // |rx_characteristic_| characteristic.
177 void OnNotifySessionStarted( 172 void OnNotifySessionStarted(
178 std::unique_ptr<device::BluetoothGattNotifySession> notify_session); 173 std::unique_ptr<device::BluetoothGattNotifySession> notify_session);
179 174
180 // Called when there is an error starting a notification session for 175 // Called when there is an error starting a notification session for
181 // |from_peripheral_char_| characteristic. 176 // |rx_characteristic_| characteristic.
182 void OnNotifySessionError(device::BluetoothGattService::GattErrorCode); 177 void OnNotifySessionError(device::BluetoothGattService::GattErrorCode);
183 178
184 // Stops |notify_session_|. 179 // Stops |notify_session_|.
185 void StopNotifySession(); 180 void StopNotifySession();
186 181
187 // Sends an invite to connect signal to the peripheral if when ready 182 // Sends a connection request to server if ready
188 // (SubStatus::NOTIFY_SESSION_READY). 183 // (SubStatus::NOTIFY_SESSION_READY).
189 void SendInviteToConnectSignal(); 184 void SendConnectionRequest();
190 185
191 // Completes and updates the status accordingly. 186 // Completes and updates the status accordingly.
192 void CompleteConnection(); 187 void CompleteConnection();
193 188
189 void WriteConnectionClose(const Packet& connection_close);
190 void OnConnectionCloseWritten();
191 void OnConnectionCloseError(
192 device::BluetoothRemoteGattService::GattErrorCode error);
193
194 // This is the only entry point for WriteRequests, which are processed 194 // This is the only entry point for WriteRequests, which are processed
195 // accordingly the following flow: 195 // accordingly the following flow:
196 // 1) |request| is enqueued; 196 // 1) |request| is enqueued;
197 // 2) |request| will be processed by ProcessNextWriteRequest() when there is 197 // 2) |request| will be processed by ProcessNextWriteRequest() when there is
198 // no pending write request; 198 // no pending write request;
199 // 3) |request| will be dequeued when it's successfully processed 199 // 3) |request| will be dequeued when it's successfully processed
200 // (OnRemoteCharacteristicWritten()); 200 // (OnRemoteCharacteristicWritten());
201 // 4) |request| is not dequeued if it fails 201 // 4) |request| is not dequeued if it fails
202 // (OnWriteRemoteCharacteristicError()), it remains on the queue and will be 202 // (OnWriteRemoteCharacteristicError()), it remains on the queue and will be
203 // retried. |request| will remain on the queue until it succeeds or it 203 // retried. |request| will remain on the queue until it succeeds or it
204 // triggers a Disconnect() call (after |max_number_of_tries_|). 204 // triggers a Disconnect() call (after |max_number_of_tries_|).
205 void WriteRemoteCharacteristic(WriteRequest request); 205 void WriteRemoteCharacteristic(const WriteRequest& request);
206 206
207 // Processes the next request in |write_requests_queue_|. 207 // Processes the next request in |write_requests_queue_|.
208 void ProcessNextWriteRequest(); 208 void ProcessNextWriteRequest();
209 209
210 // Called when the 210 // Called when the
211 // BluetoothRemoteGattCharacteristic::RemoteCharacteristicWrite() is 211 // BluetoothRemoteGattCharacteristic::RemoteCharacteristicWrite() is
212 // successfully complete. 212 // successfully complete.
213 void OnRemoteCharacteristicWritten(bool run_did_send_message_callback); 213 void OnRemoteCharacteristicWritten(bool run_did_send_message_callback);
214 214
215 // Called when there is an error writing to the remote characteristic 215 // Called when there is an error writing to the remote characteristic
216 // |to_peripheral_char_|. 216 // |tx_characteristic_|.
217 void OnWriteRemoteCharacteristicError( 217 void OnWriteRemoteCharacteristicError(
218 bool run_did_send_message_callback, 218 bool run_did_send_message_callback,
219 device::BluetoothRemoteGattService::GattErrorCode error); 219 device::BluetoothRemoteGattService::GattErrorCode error);
220 220
221 // Builds the value to be written on |to_peripheral_char_|. The value
222 // corresponds to |signal| concatenated with |payload|.
223 WriteRequest BuildWriteRequest(const std::vector<uint8_t>& signal,
224 const std::vector<uint8_t>& bytes,
225 bool is_last_message_for_wire_message);
226
227 // Prints the time elapsed since |Connect()| was called. 221 // Prints the time elapsed since |Connect()| was called.
228 void PrintTimeElapsed(); 222 void PrintTimeElapsed();
229 223
230 // Returns the device corresponding to |remote_device_address_|. 224 // Returns the device corresponding to |remote_device_address_|.
231 device::BluetoothDevice* GetRemoteDevice(); 225 device::BluetoothDevice* GetRemoteDevice();
232 226
233 // Returns the service corresponding to |remote_service_| in the current 227 // Returns the service corresponding to |remote_service_| in the current
234 // device. 228 // device.
235 device::BluetoothRemoteGattService* GetRemoteService(); 229 device::BluetoothRemoteGattService* GetRemoteService();
236 230
237 // Returns the characteristic corresponding to |identifier| in the current 231 // Returns the characteristic corresponding to |identifier| in the current
238 // service. 232 // service.
239 device::BluetoothRemoteGattCharacteristic* GetGattCharacteristic( 233 device::BluetoothRemoteGattCharacteristic* GetGattCharacteristic(
240 const std::string& identifier); 234 const std::string& identifier);
241 235
242 // Convert the first 4 bytes from a byte vector to a uint32_t. 236 // Get the reason that the other side of the connection decided to close the
243 uint32_t ToUint32(const std::vector<uint8_t>& bytes); 237 // connection.
244 238 // Will crash if the receiver is not in CONNECTION_CLOSED state.
245 // Convert an uint32_t to a byte vector. 239 std::string GetReasonForClose();
246 const std::vector<uint8_t> ToByteVector(uint32_t value);
247 240
248 // The Bluetooth adapter over which the Bluetooth connection will be made. 241 // The Bluetooth adapter over which the Bluetooth connection will be made.
249 scoped_refptr<device::BluetoothAdapter> adapter_; 242 scoped_refptr<device::BluetoothAdapter> adapter_;
250 243
251 // Remote service the |gatt_connection_| was established with. 244 // Remote service the |gatt_connection_| was established with.
252 RemoteAttribute remote_service_; 245 RemoteAttribute remote_service_;
253 246
247 // uWeave packet generator.
248 std::unique_ptr<BluetoothLowEnergyWeavePacketGenerator> packet_generator_;
249
250 // uWeave packet receiver.
251 std::unique_ptr<BluetoothLowEnergyWeavePacketReceiver> packet_receiver_;
252
254 // Characteristic used to send data to the remote device. 253 // Characteristic used to send data to the remote device.
255 RemoteAttribute to_peripheral_char_; 254 RemoteAttribute tx_characteristic_;
256 255
257 // Characteristic used to receive data from the remote device. 256 // Characteristic used to receive data from the remote device.
258 RemoteAttribute from_peripheral_char_; 257 RemoteAttribute rx_characteristic_;
259 258
260 // Throttles repeated connection attempts to the same device. This is a 259 // Throttles repeated connection attempts to the same device. This is a
261 // workaround for crbug.com/508919. Not owned, must outlive this instance. 260 // workaround for crbug.com/508919. Not owned, must outlive this instance.
262 BluetoothThrottler* bluetooth_throttler_; 261 BluetoothThrottler* bluetooth_throttler_;
263 262
264 scoped_refptr<base::TaskRunner> task_runner_; 263 scoped_refptr<base::TaskRunner> task_runner_;
265 264
266 // The GATT connection with the remote device. 265 // The GATT connection with the remote device.
267 std::unique_ptr<device::BluetoothGattConnection> gatt_connection_; 266 std::unique_ptr<device::BluetoothGattConnection> gatt_connection_;
268 267
269 // The characteristics finder for remote device. 268 // The characteristics finder for remote device.
270 std::unique_ptr<BluetoothLowEnergyCharacteristicsFinder> 269 std::unique_ptr<BluetoothLowEnergyCharacteristicsFinder>
271 characteristic_finder_; 270 characteristic_finder_;
272 271
273 // The notify session for |from_peripheral_char|. 272 // The notify session for |rx_characteristic|.
274 std::unique_ptr<device::BluetoothGattNotifySession> notify_session_; 273 std::unique_ptr<device::BluetoothGattNotifySession> notify_session_;
275 274
276 // Internal connection status 275 // Internal connection status
277 SubStatus sub_status_; 276 SubStatus sub_status_;
278 277
279 // Indicates a receiving operation is in progress. This is set after a
280 // ControlSignal::kSendSignal was received from the remote device.
281 bool receiving_bytes_;
282
283 // Total number of bytes expected for the current receive operation.
284 std::size_t expected_number_of_incoming_bytes_;
285
286 // Bytes already received for the current receive operation. 278 // Bytes already received for the current receive operation.
287 std::string incoming_bytes_buffer_; 279 std::string incoming_bytes_buffer_;
288 280
289 // Indicates there is a 281 // Indicates there is a
290 // BluetoothRemoteGattCharacteristic::WriteRemoteCharacteristic 282 // BluetoothRemoteGattCharacteristic::WriteRemoteCharacteristic
291 // operation pending. 283 // operation pending.
292 bool write_remote_characteristic_pending_; 284 bool write_remote_characteristic_pending_;
293 285
294 std::queue<WriteRequest> write_requests_queue_; 286 std::queue<WriteRequest> write_requests_queue_;
295 287
296 // Maximum number of tries to send any write request. 288 // Maximum number of tries to send any write request.
297 int max_number_of_write_attempts_; 289 int max_number_of_write_attempts_;
298 290
299 // Maximum number of bytes that fit in a single chunk to be written in
300 // |to_peripheral_char_|. Ideally, this should be the maximum value the
301 // peripheral supports and it should be agreed when the GATT connection is
302 // created. Currently, there is no API to find this value. The implementation
303 // uses a hard-coded constant.
304 int max_chunk_size_;
305
306 // Stores when the instace was created. 291 // Stores when the instace was created.
307 base::TimeTicks start_time_; 292 base::TimeTicks start_time_;
308 293
309 base::WeakPtrFactory<BluetoothLowEnergyConnection> weak_ptr_factory_; 294 base::WeakPtrFactory<BluetoothLowEnergyWeaveClientConnection>
295 weak_ptr_factory_;
310 296
311 DISALLOW_COPY_AND_ASSIGN(BluetoothLowEnergyConnection); 297 DISALLOW_COPY_AND_ASSIGN(BluetoothLowEnergyWeaveClientConnection);
312 }; 298 };
313 299
300 } // namespace weave
301
314 } // namespace proximity_auth 302 } // namespace proximity_auth
315 303
316 #endif // COMPONENTS_PROXIMITY_AUTH_BLE_BLUETOOTH_LOW_ENERGY_CONNECTION_H_ 304 #endif // COMPONENTS_PROXIMITY_AUTH_BLE_BLUETOOTH_LOW_ENERGY_WEAVE_CLIENT_CONNE CTION_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698