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