| // |
| // Copyright 2015 Google, Inc. |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at: |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| // |
| |
| #pragma once |
| |
| #include <mutex> |
| #include <unordered_set> |
| #include <vector> |
| |
| #include <base/macros.h> |
| #include <hardware/bluetooth.h> |
| #include <hardware/bt_gatt.h> |
| |
| namespace bluetooth { |
| namespace hal { |
| |
| // This class represents the standard BT-GATT interface. This class combines |
| // GATT profile server and client role operations with general GAP profile |
| // operations of various roles (central, scanner, peripheral, advertiser), |
| // wrapping around the underlying bt_gatt_interface_t structure. A single |
| // instance of this class exists per application and it allows multiple classes |
| // to interface with the global HAL interface by multiplexing callbacks among |
| // registered clients. |
| // |
| // This is declared as an abstract interface so that a fake implementation can |
| // be injected for testing the upper layer. |
| class BluetoothGattInterface { |
| public: |
| // The HAL interface doesn't allow registering "user data" that carries |
| // context beyond the callback parameters, forcing implementations to deal |
| // with global variables. The *Observer interface is to redirect these events |
| // to interested parties in an object-oriented manner. |
| |
| // The standard LE scanner callback interface. |
| class ScannerObserver { |
| public: |
| virtual ~ScannerObserver() = default; |
| |
| // All of the events below correspond to callbacks defined in |
| // "btgatt_scanner_callbacks_t" in the HAL API definitions. |
| |
| virtual void ScanResultCallback( |
| BluetoothGattInterface* gatt_iface, const RawAddress& bda, int rssi, |
| std::vector<uint8_t> adv_data); // NOLINT(pass-by-value) |
| }; |
| |
| // The standard BT-GATT client callback interface. |
| class ClientObserver { |
| public: |
| virtual ~ClientObserver() = default; |
| |
| // All of the events below correspond to callbacks defined in |
| // "bt_gatt_client_callbacks_t" in the HAL API definitions. |
| |
| virtual void RegisterClientCallback(BluetoothGattInterface* gatt_iface, |
| int status, int client_if, |
| const bluetooth::Uuid& app_uuid); |
| |
| virtual void ConnectCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, int status, int client_if, |
| const RawAddress& bda); |
| |
| virtual void DisconnectCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, int status, int client_if, |
| const RawAddress& bda); |
| |
| virtual void SearchCompleteCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, int status); |
| |
| virtual void RegisterForNotificationCallback( |
| BluetoothGattInterface* gatt_iface, int conn_id, int registered, |
| int status, uint16_t handle); |
| |
| virtual void NotifyCallback(BluetoothGattInterface* gatt_iface, int conn_id, |
| const btgatt_notify_params_t& p_data); |
| |
| virtual void WriteCharacteristicCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, int status, |
| uint16_t handle); |
| |
| virtual void WriteDescriptorCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, int status, |
| uint16_t handle); |
| |
| virtual void MtuChangedCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, int status, int mtu); |
| |
| virtual void GetGattDbCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, |
| const btgatt_db_element_t* gatt_db, |
| int size); |
| |
| virtual void ServicesRemovedCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, uint16_t start_handle, |
| uint16_t end_handle); |
| |
| virtual void ServicesAddedCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, |
| const btgatt_db_element_t& added, |
| int added_count); |
| }; |
| |
| // The standard BT-GATT server callback interface. |
| class ServerObserver { |
| public: |
| virtual ~ServerObserver() = default; |
| |
| virtual void RegisterServerCallback(BluetoothGattInterface* gatt_iface, |
| int status, int server_if, |
| const bluetooth::Uuid& app_uuid); |
| |
| virtual void ConnectionCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, int server_if, int connected, |
| const RawAddress& bda); |
| |
| virtual void ServiceAddedCallback( |
| BluetoothGattInterface* gatt_iface, int status, int server_if, |
| std::vector<btgatt_db_element_t> service); // NOLINT(pass-by-value) |
| |
| virtual void ServiceStoppedCallback(BluetoothGattInterface* gatt_iface, |
| int status, int server_if, |
| int srvc_handle); |
| |
| virtual void ServiceDeletedCallback(BluetoothGattInterface* gatt_iface, |
| int status, int server_if, |
| int srvc_handle); |
| |
| virtual void RequestReadCharacteristicCallback( |
| BluetoothGattInterface* gatt_iface, int conn_id, int trans_id, |
| const RawAddress& bda, int attr_handle, int offset, bool is_long); |
| |
| virtual void RequestReadDescriptorCallback( |
| BluetoothGattInterface* gatt_iface, int conn_id, int trans_id, |
| const RawAddress& bda, int attr_handle, int offset, bool is_long); |
| |
| virtual void RequestWriteCharacteristicCallback( |
| BluetoothGattInterface* gatt_iface, int conn_id, int trans_id, |
| const RawAddress& bda, int attr_handle, int offset, bool need_rsp, |
| bool is_prep, |
| std::vector<uint8_t> value); // NOLINT(pass-by-value) |
| |
| virtual void RequestWriteDescriptorCallback( |
| BluetoothGattInterface* gatt_iface, int conn_id, int trans_id, |
| const RawAddress& bda, int attr_handle, int offset, bool need_rsp, |
| bool is_prep, |
| std::vector<uint8_t> value); // NOLINT(pass-by-alue) |
| |
| virtual void RequestExecWriteCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, int trans_id, |
| const RawAddress& bda, |
| int exec_write); |
| |
| virtual void ResponseConfirmationCallback( |
| BluetoothGattInterface* gatt_iface, int status, int handle); |
| |
| virtual void IndicationSentCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, int status); |
| |
| virtual void MtuChangedCallback(BluetoothGattInterface* gatt_iface, |
| int conn_id, int mtu); |
| }; |
| |
| // Initialize and clean up the BluetoothInterface singleton. Returns false if |
| // the underlying HAL interface failed to initialize, and true on success. |
| static bool Initialize(); |
| |
| // Shuts down and cleans up the interface. CleanUp must be called on the same |
| // thread that called Initialize. |
| static void CleanUp(); |
| |
| // Returns true if the interface was initialized and a global singleton has |
| // been created. |
| static bool IsInitialized(); |
| |
| // Initialize for testing. Use this to inject a test version of |
| // BluetoothGattInterface. To be used from unit tests only. |
| static void InitializeForTesting(BluetoothGattInterface* test_instance); |
| |
| // Returns the BluetoothGattInterface singleton. If the interface has |
| // not been initialized, returns nullptr. This method is thread-safe, in that |
| // it will block if the internal lock is being held by another thread. Don't |
| // call this re-entrantly from an observer event as this may cause a deadlock. |
| static BluetoothGattInterface* Get(); |
| |
| // Add or remove an observer that is interested in LE scanner interface |
| // notifications from us. Thread-safety is guaranteed by ObserverList. |
| virtual void AddScannerObserver(ScannerObserver* observer) = 0; |
| virtual void RemoveScannerObserver(ScannerObserver* observer) = 0; |
| |
| // Add or remove an observer that is interested in GATT client interface |
| // notifications from us. Thread-safety is guaranteed by ObserverList. |
| virtual void AddClientObserver(ClientObserver* observer) = 0; |
| virtual void RemoveClientObserver(ClientObserver* observer) = 0; |
| |
| // Add or remove an observer that is interested in GATT server interface |
| // notifications from us. Thread-safety is guaranteed by ObserverList. |
| virtual void AddServerObserver(ServerObserver* observer) = 0; |
| virtual void RemoveServerObserver(ServerObserver* observer) = 0; |
| |
| // The HAL module pointer that represents the standard BT LE advertiser |
| // interface. This is implemented in and provided by the shared Bluetooth |
| // library, so this isn't owned by us. |
| // |
| // Upper layers can make ble_advertiser_interface_t API calls through this |
| // structure. |
| virtual BleAdvertiserInterface* GetAdvertiserHALInterface() const = 0; |
| |
| // The HAL module pointer that represents the standard BT LE scanner |
| // interface. This is implemented in and provided by the shared Bluetooth |
| // library, so this isn't owned by us. |
| // |
| // Upper layers can make ble_scanner_interface_t API calls through this |
| // structure. |
| virtual BleScannerInterface* GetScannerHALInterface() const = 0; |
| |
| // The HAL module pointer that represents the standard BT-GATT client |
| // interface. This is implemented in and provided by the shared Bluetooth |
| // library, so this isn't owned by us. |
| // |
| // Upper layers can make btgatt_client_interface_t API calls through this |
| // structure. |
| virtual const btgatt_client_interface_t* GetClientHALInterface() const = 0; |
| |
| // The HAL module pointer that represents the standard BT-GATT server |
| // interface. This is implemented in and provided by the shared Bluetooth |
| // library, so this isn't owned by us. |
| // |
| // Upper layers can make btgatt_server_interface_t API calls through this |
| // structure. |
| virtual const btgatt_server_interface_t* GetServerHALInterface() const = 0; |
| |
| // Initiates a regular BLE device scan. This is called internally from each |
| // LowEnergyClient. This function synchronizes the scan requests and maintains |
| // an internal reference count for each scan client that is interested. |
| bt_status_t StartScan(int client_id); |
| bt_status_t StopScan(int client_id); |
| |
| protected: |
| BluetoothGattInterface() = default; |
| virtual ~BluetoothGattInterface() = default; |
| |
| private: |
| // Used to keep a reference count for the different BLE scan clients. |
| std::mutex scan_clients_lock_; |
| std::unordered_set<int> scan_client_set_; |
| |
| DISALLOW_COPY_AND_ASSIGN(BluetoothGattInterface); |
| }; |
| |
| } // namespace hal |
| } // namespace bluetooth |