| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | // Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // 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.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef __ESP_GATTC_API_H__
 | 
					
						
							|  |  |  | #define __ESP_GATTC_API_H__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "esp_bt_defs.h"
 | 
					
						
							|  |  |  | #include "esp_gatt_defs.h"
 | 
					
						
							|  |  |  | #include "esp_err.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | extern "C" { | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// GATT Client callback function events
 | 
					
						
							|  |  |  | typedef enum { | 
					
						
							| 
									
										
										
										
											2017-08-01 08:51:04 +03:00
										 |  |  |     ESP_GATTC_REG_EVT                 = 0,        /*!< When GATT client is registered, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_UNREG_EVT               = 1,        /*!< When GATT client is unregistered, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_OPEN_EVT                = 2,        /*!< When GATT virtual connection is set up, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_READ_CHAR_EVT           = 3,        /*!< When GATT characteristic is read, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_WRITE_CHAR_EVT          = 4,        /*!< When GATT characteristic write operation completes, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_CLOSE_EVT               = 5,        /*!< When GATT virtual connection is closed, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_SEARCH_CMPL_EVT         = 6,        /*!< When GATT service discovery is completed, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_SEARCH_RES_EVT          = 7,        /*!< When GATT service discovery result is got, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_READ_DESCR_EVT          = 8,        /*!< When GATT characteristic descriptor read completes, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_WRITE_DESCR_EVT         = 9,        /*!< When GATT characteristic descriptor write completes, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_NOTIFY_EVT              = 10,       /*!< When GATT notification or indication arrives, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_PREP_WRITE_EVT          = 11,       /*!< When GATT prepare-write operation completes, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_EXEC_EVT                = 12,       /*!< When write execution completes, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_ACL_EVT                 = 13,       /*!< When ACL connection is up, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_CANCEL_OPEN_EVT         = 14,       /*!< When GATT client ongoing connection is cancelled, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_SRVC_CHG_EVT            = 15,       /*!< When "service changed" occurs, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_ENC_CMPL_CB_EVT         = 17,       /*!< When encryption procedure completes, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_CFG_MTU_EVT             = 18,       /*!< When configuration of MTU completes, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_ADV_DATA_EVT            = 19,       /*!< When advertising of data, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_MULT_ADV_ENB_EVT        = 20,       /*!< When multi-advertising is enabled, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_MULT_ADV_UPD_EVT        = 21,       /*!< When multi-advertising parameters are updated, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_MULT_ADV_DATA_EVT       = 22,       /*!< When multi-advertising data arrives, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_MULT_ADV_DIS_EVT        = 23,       /*!< When multi-advertising is disabled, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_CONGEST_EVT             = 24,       /*!< When GATT connection congestion comes, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_BTH_SCAN_ENB_EVT        = 25,       /*!< When batch scan is enabled, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_BTH_SCAN_CFG_EVT        = 26,       /*!< When batch scan storage is configured, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_BTH_SCAN_RD_EVT         = 27,       /*!< When Batch scan read event is reported, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_BTH_SCAN_THR_EVT        = 28,       /*!< When Batch scan threshold is set, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_BTH_SCAN_PARAM_EVT      = 29,       /*!< When Batch scan parameters are set, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_BTH_SCAN_DIS_EVT        = 30,       /*!< When Batch scan is disabled, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_SCAN_FLT_CFG_EVT        = 31,       /*!< When Scan filter configuration completes, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_SCAN_FLT_PARAM_EVT      = 32,       /*!< When Scan filter parameters are set, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_SCAN_FLT_STATUS_EVT     = 33,       /*!< When Scan filter status is reported, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_ADV_VSC_EVT             = 34,       /*!< When advertising vendor spec content event is reported, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_REG_FOR_NOTIFY_EVT      = 38,       /*!< When register for notification of a service completes, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_UNREG_FOR_NOTIFY_EVT    = 39,       /*!< When unregister for notification of a service completes, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_CONNECT_EVT             = 40,       /*!< When the ble physical connection is set up, the event comes */ | 
					
						
							|  |  |  |     ESP_GATTC_DISCONNECT_EVT          = 41,       /*!< When the ble physical connection disconnected, the event comes */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | } esp_gattc_cb_event_t; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief Gatt client callback parameters union | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef union { | 
					
						
							|  |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |      * @brief ESP_GATTC_REG_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_reg_evt_param { | 
					
						
							|  |  |  |         esp_gatt_status_t status;       /*!< Operation status */ | 
					
						
							|  |  |  |         uint16_t app_id;                /*!< Application id which input in register API */ | 
					
						
							|  |  |  |     } reg;                              /*!< Gatt client callback param of ESP_GATTC_REG_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_OPEN_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_open_evt_param { | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         esp_gatt_status_t status;       /*!< Operation status */ | 
					
						
							|  |  |  |         uint16_t conn_id;               /*!< Connection id */ | 
					
						
							|  |  |  |         esp_bd_addr_t remote_bda;       /*!< Remote bluetooth device address */ | 
					
						
							|  |  |  |         uint16_t mtu;                   /*!< MTU size */ | 
					
						
							|  |  |  |     } open;                             /*!< Gatt client callback param of ESP_GATTC_OPEN_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_CLOSE_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_close_evt_param { | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         esp_gatt_status_t status;       /*!< Operation status */ | 
					
						
							|  |  |  |         uint16_t conn_id;               /*!< Connection id */ | 
					
						
							|  |  |  |         esp_bd_addr_t remote_bda;       /*!< Remote bluetooth device address */ | 
					
						
							|  |  |  |         esp_gatt_conn_reason_t reason;  /*!< The reason of gatt connection close */ | 
					
						
							|  |  |  |     } close;                            /*!< Gatt client callback param of ESP_GATTC_CLOSE_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_CFG_MTU_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_cfg_mtu_evt_param { | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         esp_gatt_status_t status;       /*!< Operation status */ | 
					
						
							|  |  |  |         uint16_t conn_id;               /*!< Connection id */ | 
					
						
							|  |  |  |         uint16_t mtu;                   /*!< MTU size */ | 
					
						
							|  |  |  |     } cfg_mtu;                          /*!< Gatt client callback param of ESP_GATTC_CFG_MTU_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_SEARCH_CMPL_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_search_cmpl_evt_param { | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         esp_gatt_status_t status;       /*!< Operation status */ | 
					
						
							|  |  |  |         uint16_t conn_id;               /*!< Connection id */ | 
					
						
							|  |  |  |     } search_cmpl;                      /*!< Gatt client callback param of ESP_GATTC_SEARCH_CMPL_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_SEARCH_RES_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_search_res_evt_param { | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         uint16_t conn_id;               /*!< Connection id */ | 
					
						
							|  |  |  |         uint16_t start_handle;          /*!< Service start handle */ | 
					
						
							|  |  |  |         uint16_t end_handle;            /*!< Service end handle */ | 
					
						
							|  |  |  |         esp_gatt_id_t srvc_id;          /*!< Service id, include service uuid and other information */ | 
					
						
							|  |  |  |     } search_res;                       /*!< Gatt client callback param of ESP_GATTC_SEARCH_RES_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_READ_CHAR_EVT,  ESP_GATTC_READ_DESCR_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_read_char_evt_param { | 
					
						
							| 
									
										
										
										
											2017-08-01 08:51:04 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |         esp_gatt_status_t status;       /*!< Operation status */ | 
					
						
							|  |  |  |         uint16_t conn_id;               /*!< Connection id */ | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         uint16_t handle;                /*!< Characteristic handle */ | 
					
						
							| 
									
										
										
										
											2017-08-01 08:51:04 +03:00
										 |  |  |         uint8_t *value;                 /*!< Characteristic value */ | 
					
						
							|  |  |  |         uint16_t value_len;             /*!< Characteristic value length */ | 
					
						
							|  |  |  |     } read;                             /*!< Gatt client callback param of ESP_GATTC_READ_CHAR_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_WRITE_CHAR_EVT, ESP_GATTC_PREP_WRITE_EVT, ESP_GATTC_WRITE_DESCR_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_write_evt_param { | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         esp_gatt_status_t status;       /*!< Operation status */ | 
					
						
							|  |  |  |         uint16_t conn_id;               /*!< Connection id */ | 
					
						
							|  |  |  |         uint16_t handle;                /*!< The Characteristic or descriptor handle */ | 
					
						
							|  |  |  |     } write;                            /*!< Gatt client callback param of ESP_GATTC_WRITE_DESCR_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_EXEC_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_exec_cmpl_evt_param { | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         esp_gatt_status_t status;       /*!< Operation status */ | 
					
						
							|  |  |  |         uint16_t conn_id;               /*!< Connection id */ | 
					
						
							|  |  |  |     } exec_cmpl;                        /*!< Gatt client callback param of ESP_GATTC_EXEC_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_NOTIFY_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_notify_evt_param { | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         uint16_t conn_id;               /*!< Connection id */ | 
					
						
							|  |  |  |         esp_bd_addr_t remote_bda;       /*!< Remote bluetooth device address */ | 
					
						
							|  |  |  |         uint16_t handle;                /*!< The Characteristic or descriptor handle */ | 
					
						
							|  |  |  |         uint16_t value_len;             /*!< Notify attribute value */ | 
					
						
							|  |  |  |         uint8_t *value;                 /*!< Notify attribute value */ | 
					
						
							|  |  |  |         bool is_notify;                 /*!< True means notify, false means indicate */ | 
					
						
							|  |  |  |     } notify;                           /*!< Gatt client callback param of ESP_GATTC_NOTIFY_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_SRVC_CHG_EVT | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  |     struct gattc_srvc_chg_evt_param { | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         esp_bd_addr_t remote_bda;       /*!< Remote bluetooth device address */ | 
					
						
							|  |  |  |     } srvc_chg;                         /*!< Gatt client callback param of ESP_GATTC_SRVC_CHG_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_CONGEST_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_congest_evt_param { | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         uint16_t conn_id;               /*!< Connection id */ | 
					
						
							|  |  |  |         bool congested;                 /*!< Congested or not */ | 
					
						
							|  |  |  |     } congest;                          /*!< Gatt client callback param of ESP_GATTC_CONGEST_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_REG_FOR_NOTIFY_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_reg_for_notify_evt_param { | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         esp_gatt_status_t status;       /*!< Operation status */ | 
					
						
							|  |  |  |         uint16_t handle;                /*!< The characteristic or descriptor handle */ | 
					
						
							|  |  |  |     } reg_for_notify;                   /*!< Gatt client callback param of ESP_GATTC_REG_FOR_NOTIFY_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |      * @brief ESP_GATTC_UNREG_FOR_NOTIFY_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_unreg_for_notify_evt_param { | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |         esp_gatt_status_t status;       /*!< Operation status */ | 
					
						
							|  |  |  |         uint16_t handle;                /*!< The characteristic or descriptor handle */ | 
					
						
							|  |  |  |     } unreg_for_notify;                 /*!< Gatt client callback param of ESP_GATTC_UNREG_FOR_NOTIFY_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-01 08:51:04 +03:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_CONNECT_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_connect_evt_param { | 
					
						
							|  |  |  |         esp_gatt_status_t status;       /*!< Operation status */ | 
					
						
							|  |  |  |         uint16_t conn_id;               /*!< Connection id */ | 
					
						
							|  |  |  |         esp_bd_addr_t remote_bda;       /*!< Remote bluetooth device address */ | 
					
						
							|  |  |  |     } connect;                          /*!< Gatt client callback param of ESP_GATTC_CONNECT_EVT */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * @brief ESP_GATTC_DISCONNECT_EVT | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     struct gattc_disconnect_evt_param { | 
					
						
							|  |  |  |         esp_gatt_status_t status;       /*!< Operation status */ | 
					
						
							|  |  |  |         uint16_t conn_id;               /*!< Connection id */ | 
					
						
							|  |  |  |         esp_bd_addr_t remote_bda;       /*!< Remote bluetooth device address */ | 
					
						
							|  |  |  |     } disconnect;                       /*!< Gatt client callback param of ESP_GATTC_DISCONNECT_EVT */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  | } esp_ble_gattc_cb_param_t;             /*!< GATT client callback parameter union type */ | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief GATT Client callback function type | 
					
						
							|  |  |  |  * @param event : Event type | 
					
						
							|  |  |  |  * @param gatts_if : GATT client access interface, normally | 
					
						
							|  |  |  |  *                   different gattc_if correspond to different profile | 
					
						
							|  |  |  |  * @param param : Point to callback parameter, currently is union type | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | typedef void (* esp_gattc_cb_t)(esp_gattc_cb_event_t event, esp_gatt_if_t gattc_if, esp_ble_gattc_cb_param_t *param); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to register application callbacks | 
					
						
							|  |  |  |  *                  with GATTC module. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       callback : pointer to the application callback function. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_err_t esp_ble_gattc_register_callback(esp_gattc_cb_t callback); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to register application callbacks | 
					
						
							|  |  |  |  *                  with GATTC module. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       app_id : Application Identify (UUID), for different application | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_err_t esp_ble_gattc_app_register(uint16_t app_id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to unregister an application | 
					
						
							|  |  |  |  *                  from GATTC module. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_err_t esp_ble_gattc_app_unregister(esp_gatt_if_t gattc_if); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           Open a direct connection or add a background auto connection | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       remote_bda: remote device bluetooth device address. | 
					
						
							|  |  |  |  * @param[in]       is_direct: direct connection or background auto connection | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_err_t esp_ble_gattc_open(esp_gatt_if_t gattc_if, esp_bd_addr_t remote_bda, bool is_direct); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2017-08-01 08:51:04 +03:00
										 |  |  |  * @brief           Close a virtual connection to a GATT server. gattc maybe have multiple virtual GATT server connections when multiple app_id registed, | 
					
						
							|  |  |  |  *                  this API only close one virtual GATT server connection. if there exist other virtual GATT server connections, | 
					
						
							|  |  |  |  *                  it does not disconnect the physical connection. | 
					
						
							|  |  |  |  *                  if you want to disconnect the physical connection directly, you can use esp_ble_gap_disconnect(esp_bd_addr_t remote_device). | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id: connection ID to be closed. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_err_t esp_ble_gattc_close (esp_gatt_if_t gattc_if, uint16_t conn_id); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           Configure the MTU size in the GATT channel. This can be done | 
					
						
							| 
									
										
										
										
											2017-09-12 09:40:52 +03:00
										 |  |  |  *                  only once per connection. Before using, use esp_ble_gatt_set_local_mtu() | 
					
						
							|  |  |  |  *                  to configure the local MTU size. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id: connection ID. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-12 09:40:52 +03:00
										 |  |  | esp_err_t esp_ble_gattc_send_mtu_req (esp_gatt_if_t gattc_if, uint16_t conn_id); | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to request a GATT service discovery | 
					
						
							|  |  |  |  *                  on a GATT server. This function report service search result | 
					
						
							|  |  |  |  *                  by a callback event, and followed by a service search complete | 
					
						
							|  |  |  |  *                  event. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id: connection ID. | 
					
						
							|  |  |  |  * @param[in]       filter_uuid: a UUID of the service application is interested in. | 
					
						
							|  |  |  |  *                  If Null, discover for all services. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_err_t esp_ble_gattc_search_service(esp_gatt_if_t gattc_if, uint16_t conn_id, esp_bt_uuid_t *filter_uuid); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           Find all the service with the given service uuid in the gattc cache, if the svc_uuid is NULL, find all the service. | 
					
						
							|  |  |  |  *                  Note: It just get service from local cache, won't get from remote devices. If want to get it from remote device, need | 
					
						
							|  |  |  |  *                  to used the esp_ble_gattc_search_service. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id: connection ID which identify the server. | 
					
						
							|  |  |  |  * @param[in]       svc_uuid: the pointer to the service uuid. | 
					
						
							|  |  |  |  * @param[out]      result: The pointer to the service whith has been found in the gattc cache. | 
					
						
							|  |  |  |  * @param[inout]   count: input the number of service want to find, | 
					
						
							|  |  |  |  *                         it will output the number of service has been found in the gattc cache with the given service uuid. | 
					
						
							|  |  |  |  * @param[in]       offset: Offset of the service position to get. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_gatt_status_t esp_ble_gattc_get_service(esp_gatt_if_t gattc_if, uint16_t conn_id, esp_bt_uuid_t *svc_uuid, | 
					
						
							|  |  |  |                                             esp_gattc_service_elem_t *result, uint16_t *count, uint16_t offset); | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @brief           Find all the characteristic with the given service in the gattc cache | 
					
						
							|  |  |  |  *                  Note: It just get characteristic from local cache, won't get from remote devices. | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id: connection ID which identify the server. | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @param[in]       start_handle: the attribute start handle. | 
					
						
							|  |  |  |  * @param[in]       end_handle: the attribute end handle | 
					
						
							|  |  |  |  * @param[out]      result: The pointer to the charateristic in the service. | 
					
						
							|  |  |  |  * @param[inout]   count: input the number of characteristic want to find, | 
					
						
							|  |  |  |  *                         it will output the number of characteristic has been found in the gattc cache with the given service. | 
					
						
							|  |  |  |  * @param[in]       offset: Offset of the characteristic position to get. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  | esp_gatt_status_t esp_ble_gattc_get_all_char(esp_gatt_if_t gattc_if, | 
					
						
							|  |  |  |                                              uint16_t conn_id, | 
					
						
							|  |  |  |                                              uint16_t start_handle, | 
					
						
							|  |  |  |                                              uint16_t end_handle, | 
					
						
							|  |  |  |                                              esp_gattc_char_elem_t *result, | 
					
						
							|  |  |  |                                              uint16_t *count, uint16_t offset); | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @brief           Find all the descriptor with the given characteristic in the gattc cache | 
					
						
							|  |  |  |  *                  Note: It just get descriptor from local cache, won't get from remote devices. | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id: connection ID which identify the server. | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @param[in]       char_handle: the given characteristic handle | 
					
						
							|  |  |  |  * @param[out]      result: The pointer to the descriptor in the characteristic. | 
					
						
							|  |  |  |  * @param[inout]    count: input the number of descriptor want to find, | 
					
						
							|  |  |  |  *                         it will output the number of descriptor has been found in the gattc cache with the given characteristic. | 
					
						
							|  |  |  |  * @param[in]       offset: Offset of the descriptor position to get. | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  | esp_gatt_status_t esp_ble_gattc_get_all_descr(esp_gatt_if_t gattc_if, | 
					
						
							|  |  |  |                                               uint16_t conn_id, | 
					
						
							|  |  |  |                                               uint16_t char_handle, | 
					
						
							|  |  |  |                                               esp_gattc_descr_elem_t *result, | 
					
						
							|  |  |  |                                               uint16_t *count, uint16_t offset); | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @brief           Find the characteristic with the given characteristic uuid in the gattc cache | 
					
						
							|  |  |  |  *                  Note: It just get characteristic from local cache, won't get from remote devices. | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id: connection ID which identify the server. | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @param[in]       start_handle: the attribute start handle | 
					
						
							|  |  |  |  * @param[in]       end_handle: the attribute end handle | 
					
						
							|  |  |  |  * @param[in]       char_uuid: the characteristic uuid | 
					
						
							|  |  |  |  * @param[out]      result: The pointer to the characteristic in the service. | 
					
						
							|  |  |  |  * @param[inout]   count: input the number of characteristic want to find, | 
					
						
							|  |  |  |  *                         it will output the number of characteristic has been found in the gattc cache with the given service. | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  | esp_gatt_status_t esp_ble_gattc_get_char_by_uuid(esp_gatt_if_t gattc_if, | 
					
						
							|  |  |  |                                                  uint16_t conn_id, | 
					
						
							|  |  |  |                                                  uint16_t start_handle, | 
					
						
							|  |  |  |                                                  uint16_t end_handle, | 
					
						
							|  |  |  |                                                  esp_bt_uuid_t char_uuid, | 
					
						
							|  |  |  |                                                  esp_gattc_char_elem_t *result, | 
					
						
							|  |  |  |                                                  uint16_t *count); | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           Find the descriptor with the given characteristic uuid in the gattc cache | 
					
						
							|  |  |  |  *                  Note: It just get descriptor from local cache, won't get from remote devices. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id: connection ID which identify the server. | 
					
						
							|  |  |  |  * @param[in]       start_handle: the attribute start handle | 
					
						
							|  |  |  |  * @param[in]       end_handle: the attribute end handle | 
					
						
							|  |  |  |  * @param[in]       char_uuid: the characteristic uuid. | 
					
						
							|  |  |  |  * @param[in]       descr_uuid: the descriptor uuid. | 
					
						
							|  |  |  |  * @param[out]      result: The pointer to the descriptor in the given characteristic. | 
					
						
							|  |  |  |  * @param[inout]   count: input the number of descriptor want to find, | 
					
						
							|  |  |  |  *                         it will output the number of descriptor has been found in the gattc cache with the given characteristic. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_gatt_status_t esp_ble_gattc_get_descr_by_uuid(esp_gatt_if_t gattc_if, | 
					
						
							|  |  |  |                                                   uint16_t conn_id, | 
					
						
							|  |  |  |                                                   uint16_t start_handle, | 
					
						
							|  |  |  |                                                   uint16_t end_handle, | 
					
						
							|  |  |  |                                                   esp_bt_uuid_t char_uuid, | 
					
						
							|  |  |  |                                                   esp_bt_uuid_t descr_uuid, | 
					
						
							|  |  |  |                                                   esp_gattc_descr_elem_t *result, | 
					
						
							|  |  |  |                                                   uint16_t *count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           Find the descriptor with the given characteristic handle in the gattc cache | 
					
						
							|  |  |  |  *                  Note: It just get descriptor from local cache, won't get from remote devices. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id: connection ID which identify the server. | 
					
						
							|  |  |  |  * @param[in]       char_handle: the characteristic handle. | 
					
						
							|  |  |  |  * @param[in]       descr_uuid: the descriptor uuid. | 
					
						
							|  |  |  |  * @param[out]      result: The pointer to the descriptor in the given characteristic. | 
					
						
							|  |  |  |  * @param[inout]   count: input the number of descriptor want to find, | 
					
						
							|  |  |  |  *                         it will output the number of descriptor has been found in the gattc cache with the given characteristic. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_gatt_status_t esp_ble_gattc_get_descr_by_char_handle(esp_gatt_if_t gattc_if, | 
					
						
							|  |  |  |                                                          uint16_t conn_id, | 
					
						
							|  |  |  |                                                          uint16_t char_handle, | 
					
						
							|  |  |  |                                                          esp_bt_uuid_t descr_uuid, | 
					
						
							|  |  |  |                                                          esp_gattc_descr_elem_t *result, | 
					
						
							|  |  |  |                                                          uint16_t *count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           Find the include service with the given service handle in the gattc cache | 
					
						
							|  |  |  |  *                  Note: It just get include service from local cache, won't get from remote devices. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id: connection ID which identify the server. | 
					
						
							|  |  |  |  * @param[in]       start_handle: the attribute start handle | 
					
						
							|  |  |  |  * @param[in]       end_handle: the attribute end handle | 
					
						
							|  |  |  |  * @param[in]       incl_uuid: the include service uuid | 
					
						
							|  |  |  |  * @param[out]      result: The pointer to the include service in the given service. | 
					
						
							|  |  |  |  * @param[inout]   count: input the number of include service want to find, | 
					
						
							|  |  |  |  *                         it will output the number of include service has been found in the gattc cache with the given service. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_gatt_status_t esp_ble_gattc_get_include_service(esp_gatt_if_t gattc_if, | 
					
						
							|  |  |  |                                                     uint16_t conn_id, | 
					
						
							|  |  |  |                                                     uint16_t start_handle, | 
					
						
							|  |  |  |                                                     uint16_t end_handle, | 
					
						
							|  |  |  |                                                     esp_bt_uuid_t *incl_uuid, | 
					
						
							|  |  |  |                                                     esp_gattc_incl_svc_elem_t *result, | 
					
						
							|  |  |  |                                                     uint16_t *count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           Find the attribute count with the given service or characteristic in the gattc cache | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id: connection ID which identify the server. | 
					
						
							|  |  |  |  * @param[in]       type: the attribute type. | 
					
						
							|  |  |  |  * @param[in]       start_handle: the attribute start handle, if the type is ESP_GATT_DB_DESCRIPTOR, this parameter should be ignore | 
					
						
							|  |  |  |  * @param[in]       end_handle: the attribute end handle, if the type is ESP_GATT_DB_DESCRIPTOR, this parameter should be ignore | 
					
						
							|  |  |  |  * @param[in]       char_handle: the characteristic handle, this parameter valid when the type is ESP_GATT_DB_DESCRIPTOR. If the type | 
					
						
							|  |  |  |  *                               isn't ESP_GATT_DB_DESCRIPTOR, this parameter should be ignore. | 
					
						
							|  |  |  |  * @param[out]      count: output the number of attribute has been found in the gattc cache with the given attribute type. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_gatt_status_t esp_ble_gattc_get_attr_count(esp_gatt_if_t gattc_if, | 
					
						
							|  |  |  |                                                uint16_t conn_id, | 
					
						
							|  |  |  |                                                esp_gatt_db_attr_type_t type, | 
					
						
							|  |  |  |                                                uint16_t start_handle, | 
					
						
							|  |  |  |                                                uint16_t end_handle, | 
					
						
							|  |  |  |                                                uint16_t char_handle, | 
					
						
							|  |  |  |                                                uint16_t *count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to get the GATT database. | 
					
						
							|  |  |  |  *                  Note: It just get attribute data base from local cache, won't get from remote devices. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       start_handle: the attribute start handle | 
					
						
							|  |  |  |  * @param[in]       end_handle: the attribute end handle | 
					
						
							|  |  |  |  * @param[in]       conn_id: connection ID which identify the server. | 
					
						
							|  |  |  |  * @param[in]       db: output parameter which will contain the GATT database copy. | 
					
						
							|  |  |  |  *                      Caller is responsible for freeing it. | 
					
						
							|  |  |  |  * @param[in]       count: number of elements in database. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_gatt_status_t esp_ble_gattc_get_db(esp_gatt_if_t gattc_if, uint16_t conn_id, uint16_t start_handle, uint16_t end_handle, | 
					
						
							|  |  |  |                                         esp_gattc_db_elem_t *db, uint16_t *count); | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to read a service's characteristics of | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  *                  the given characteristic handle | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id : connection ID. | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @param[in]       handle : characteritic handle to read. | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * @param[in]       auth_req : authenticate request type | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  | esp_err_t esp_ble_gattc_read_char (esp_gatt_if_t gattc_if, | 
					
						
							|  |  |  |                                    uint16_t conn_id, | 
					
						
							|  |  |  |                                    uint16_t handle, | 
					
						
							|  |  |  |                                    esp_gatt_auth_req_t auth_req); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to read multiple characteristic or | 
					
						
							|  |  |  |  *                  characteristic descriptors. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id : connection ID. | 
					
						
							|  |  |  |  * @param[in]       read_multi : pointer to the read multiple parameter. | 
					
						
							|  |  |  |  * @param[in]       auth_req : authenticate request type | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_err_t esp_ble_gattc_read_multiple(esp_gatt_if_t gattc_if, | 
					
						
							|  |  |  |                                       uint16_t conn_id, esp_gattc_multi_t *read_multi, | 
					
						
							|  |  |  |                                       esp_gatt_auth_req_t auth_req); | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to read a characteristics descriptor. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id : connection ID. | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @param[in]       handle : descriptor handle to read. | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * @param[in]       auth_req : authenticate request type | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_err_t esp_ble_gattc_read_char_descr (esp_gatt_if_t gattc_if, | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |                                          uint16_t conn_id, | 
					
						
							|  |  |  |                                          uint16_t handle, | 
					
						
							|  |  |  |                                          esp_gatt_auth_req_t auth_req); | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to write characteristic value. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id : connection ID. | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @param[in]       handle : characteristic handle to write. | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * @param[in]       value_len: length of the value to be written. | 
					
						
							|  |  |  |  * @param[in]       value : the value to be written. | 
					
						
							|  |  |  |  * @param[in]       write_type : the type of attribute write operation. | 
					
						
							|  |  |  |  * @param[in]       auth_req : authentication request. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_err_t esp_ble_gattc_write_char( esp_gatt_if_t gattc_if, | 
					
						
							|  |  |  |                                     uint16_t conn_id, | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |                                     uint16_t handle, | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |                                     uint16_t value_len, | 
					
						
							|  |  |  |                                     uint8_t *value, | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |                                     esp_gatt_write_type_t write_type, | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |                                     esp_gatt_auth_req_t auth_req); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to write characteristic descriptor value. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id : connection ID | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @param[in]       handle : descriptor hadle to write. | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * @param[in]       value_len: length of the value to be written. | 
					
						
							|  |  |  |  * @param[in]       value : the value to be written. | 
					
						
							|  |  |  |  * @param[in]       write_type : the type of attribute write operation. | 
					
						
							|  |  |  |  * @param[in]       auth_req : authentication request. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-05-06 20:29:12 +03:00
										 |  |  | esp_err_t esp_ble_gattc_write_char_descr (esp_gatt_if_t gattc_if, | 
					
						
							|  |  |  |                                          uint16_t conn_id, | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |                                          uint16_t handle, | 
					
						
							| 
									
										
										
										
											2017-05-06 20:29:12 +03:00
										 |  |  |                                          uint16_t value_len, | 
					
						
							|  |  |  |                                          uint8_t *value, | 
					
						
							|  |  |  |                                          esp_gatt_write_type_t write_type, | 
					
						
							|  |  |  |                                          esp_gatt_auth_req_t auth_req); | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to prepare write a characteristic value. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id : connection ID. | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @param[in]       handle : charateristic handle to prepare write. | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * @param[in]       offset : offset of the write value. | 
					
						
							|  |  |  |  * @param[in]       value_len: length of the value to be written. | 
					
						
							|  |  |  |  * @param[in]       value : the value to be written. | 
					
						
							|  |  |  |  * @param[in]       auth_req : authentication request. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  | esp_err_t esp_ble_gattc_prepare_write(esp_gatt_if_t gattc_if, | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |                                       uint16_t conn_id, | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |                                       uint16_t handle, | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |                                       uint16_t offset, | 
					
						
							|  |  |  |                                       uint16_t value_len, | 
					
						
							|  |  |  |                                       uint8_t *value, | 
					
						
							|  |  |  |                                       esp_gatt_auth_req_t auth_req); | 
					
						
							| 
									
										
										
										
											2017-05-06 20:29:12 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to prepare write a characteristic descriptor value. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id : connection ID. | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @param[in]       handle : characteristic descriptor hanlde to prepare write. | 
					
						
							| 
									
										
										
										
											2017-05-06 20:29:12 +03:00
										 |  |  |  * @param[in]       offset : offset of the write value. | 
					
						
							|  |  |  |  * @param[in]       value_len: length of the value to be written. | 
					
						
							|  |  |  |  * @param[in]       value : the value to be written. | 
					
						
							|  |  |  |  * @param[in]       auth_req : authentication request. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_err_t esp_ble_gattc_prepare_write_char_descr(esp_gatt_if_t gattc_if, | 
					
						
							|  |  |  |                                                  uint16_t conn_id, | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |                                                  uint16_t handle, | 
					
						
							| 
									
										
										
										
											2017-05-06 20:29:12 +03:00
										 |  |  |                                                  uint16_t offset, | 
					
						
							|  |  |  |                                                  uint16_t value_len, | 
					
						
							|  |  |  |                                                  uint8_t *value, | 
					
						
							|  |  |  |                                                  esp_gatt_auth_req_t auth_req); | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to execute write a prepare write sequence. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       conn_id : connection ID. | 
					
						
							|  |  |  |  * @param[in]       is_execute : execute or cancel. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: success | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | esp_err_t esp_ble_gattc_execute_write (esp_gatt_if_t gattc_if, uint16_t conn_id, bool is_execute); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to register for notification of a service. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       server_bda : target GATT server. | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @param[in]       handle : GATT characteristic handle. | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: registration succeeds | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-12 09:40:52 +03:00
										 |  |  | esp_err_t esp_ble_gattc_register_for_notify (esp_gatt_if_t gattc_if, | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |                                              esp_bd_addr_t server_bda, | 
					
						
							|  |  |  |                                              uint16_t handle); | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * @brief           This function is called to de-register for notification of a service. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @param[in]       gattc_if: Gatt client access interface. | 
					
						
							|  |  |  |  * @param[in]       server_bda : target GATT server. | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |  * @param[in]       handle : GATT characteristic handle. | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  |  * | 
					
						
							|  |  |  |  * @return | 
					
						
							|  |  |  |  *                  - ESP_OK: unregister succeeds | 
					
						
							|  |  |  |  *                  - other: failed | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-09-12 09:40:52 +03:00
										 |  |  | esp_err_t esp_ble_gattc_unregister_for_notify (esp_gatt_if_t gattc_if, | 
					
						
							| 
									
										
										
										
											2017-09-22 17:28:54 +08:00
										 |  |  |                                                esp_bd_addr_t server_bda, | 
					
						
							|  |  |  |                                                uint16_t handle); | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-01 08:51:04 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  | * @brief           Refresh the server cache store in the gattc stack of the remote device | 
					
						
							|  |  |  | * | 
					
						
							|  |  |  | * @param[in]       remote_bda: remote device BD address. | 
					
						
							|  |  |  | * | 
					
						
							|  |  |  | * @return | 
					
						
							|  |  |  | *                  - ESP_OK: success | 
					
						
							|  |  |  | *                  - other: failed | 
					
						
							|  |  |  | * | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | esp_err_t esp_ble_gattc_cache_refresh(esp_bd_addr_t remote_bda); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-06 15:17:11 +02:00
										 |  |  | #ifdef __cplusplus
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* __ESP_GATTC_API_H__ */
 |