13deb3ec6SMatthias Ringwald /* 23deb3ec6SMatthias Ringwald * Copyright (C) 2014 BlueKitchen GmbH 33deb3ec6SMatthias Ringwald * 43deb3ec6SMatthias Ringwald * Redistribution and use in source and binary forms, with or without 53deb3ec6SMatthias Ringwald * modification, are permitted provided that the following conditions 63deb3ec6SMatthias Ringwald * are met: 73deb3ec6SMatthias Ringwald * 83deb3ec6SMatthias Ringwald * 1. Redistributions of source code must retain the above copyright 93deb3ec6SMatthias Ringwald * notice, this list of conditions and the following disclaimer. 103deb3ec6SMatthias Ringwald * 2. Redistributions in binary form must reproduce the above copyright 113deb3ec6SMatthias Ringwald * notice, this list of conditions and the following disclaimer in the 123deb3ec6SMatthias Ringwald * documentation and/or other materials provided with the distribution. 133deb3ec6SMatthias Ringwald * 3. Neither the name of the copyright holders nor the names of 143deb3ec6SMatthias Ringwald * contributors may be used to endorse or promote products derived 153deb3ec6SMatthias Ringwald * from this software without specific prior written permission. 163deb3ec6SMatthias Ringwald * 4. Any redistribution, use, or modification is done solely for 173deb3ec6SMatthias Ringwald * personal benefit and not for any commercial purpose or for 183deb3ec6SMatthias Ringwald * monetary gain. 193deb3ec6SMatthias Ringwald * 203deb3ec6SMatthias Ringwald * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS 213deb3ec6SMatthias Ringwald * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 223deb3ec6SMatthias Ringwald * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 233deb3ec6SMatthias Ringwald * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL MATTHIAS 243deb3ec6SMatthias Ringwald * RINGWALD OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 253deb3ec6SMatthias Ringwald * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 263deb3ec6SMatthias Ringwald * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 273deb3ec6SMatthias Ringwald * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 283deb3ec6SMatthias Ringwald * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 293deb3ec6SMatthias Ringwald * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 303deb3ec6SMatthias Ringwald * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 313deb3ec6SMatthias Ringwald * SUCH DAMAGE. 323deb3ec6SMatthias Ringwald * 333deb3ec6SMatthias Ringwald * Please inquire about commercial licensing options at 343deb3ec6SMatthias Ringwald * [email protected] 353deb3ec6SMatthias Ringwald * 363deb3ec6SMatthias Ringwald */ 373deb3ec6SMatthias Ringwald 383deb3ec6SMatthias Ringwald /* 393deb3ec6SMatthias Ringwald * sdp_client.h 403deb3ec6SMatthias Ringwald */ 413deb3ec6SMatthias Ringwald 4280e33422SMatthias Ringwald #ifndef SDP_CLIENT_H 4380e33422SMatthias Ringwald #define SDP_CLIENT_H 443deb3ec6SMatthias Ringwald 457907f069SMatthias Ringwald #include "btstack_config.h" 463deb3ec6SMatthias Ringwald 47eb886013SMatthias Ringwald #include "btstack_util.h" 483deb3ec6SMatthias Ringwald 493deb3ec6SMatthias Ringwald #if defined __cplusplus 503deb3ec6SMatthias Ringwald extern "C" { 513deb3ec6SMatthias Ringwald #endif 523deb3ec6SMatthias Ringwald 533deb3ec6SMatthias Ringwald /* API_START */ 543deb3ec6SMatthias Ringwald 556c927b22SMatthias Ringwald typedef struct de_state { 566c927b22SMatthias Ringwald uint8_t in_state_GET_DE_HEADER_LENGTH ; 576c927b22SMatthias Ringwald uint32_t addon_header_bytes; 586c927b22SMatthias Ringwald uint32_t de_size; 596c927b22SMatthias Ringwald uint32_t de_offset; 606c927b22SMatthias Ringwald } de_state_t; 616c927b22SMatthias Ringwald 626c927b22SMatthias Ringwald void de_state_init(de_state_t * state); 636c927b22SMatthias Ringwald int de_state_size(uint8_t eventByte, de_state_t *de_state); 646c927b22SMatthias Ringwald 656c927b22SMatthias Ringwald /** 666c927b22SMatthias Ringwald * @brief Checks if the SDP Client is ready 67e094740eSMatthias Ringwald * @deprecated Please use sdp_client_register_query_callback instead 68*b443d25dSMatthias Ringwald * @return true when no query is active 696c927b22SMatthias Ringwald */ 70*b443d25dSMatthias Ringwald bool sdp_client_ready(void); 716c927b22SMatthias Ringwald 723deb3ec6SMatthias Ringwald /** 73e094740eSMatthias Ringwald * @brief Requests a callback, when the SDP Client is ready and can be used 74e094740eSMatthias Ringwald * @note The callback might happens before sdp_client_register_query_callback has returned 75e094740eSMatthias Ringwald * @param callback_registration 76e094740eSMatthias Ringwald */ 77e094740eSMatthias Ringwald uint8_t sdp_client_register_query_callback(btstack_context_callback_registration_t * callback_registration); 78e094740eSMatthias Ringwald 79e094740eSMatthias Ringwald /** 8089374882SMatthias Ringwald * @brief Queries the SDP service of the remote device given a service search pattern and a list of attribute IDs. 816c927b22SMatthias Ringwald * The remote data is handled by the SDP parser. The SDP parser delivers attribute values and done event via the callback. 826c927b22SMatthias Ringwald * @param callback for attributes values and done event 836c927b22SMatthias Ringwald * @param remote address 846c927b22SMatthias Ringwald * @param des_service_search_pattern 856c927b22SMatthias Ringwald * @param des_attribute_id_list 863deb3ec6SMatthias Ringwald */ 87282ceebcSMatthias Ringwald uint8_t sdp_client_query(btstack_packet_handler_t callback, bd_addr_t remote, const uint8_t * des_service_search_pattern, const uint8_t * des_attribute_id_list); 883deb3ec6SMatthias Ringwald 89023f2764SMatthias Ringwald /* 90023f2764SMatthias Ringwald * @brief Searches SDP records on a remote device for all services with a given UUID. 91023f2764SMatthias Ringwald * @note calls sdp_client_query with service search pattern based on uuid16 92023f2764SMatthias Ringwald */ 93282ceebcSMatthias Ringwald uint8_t sdp_client_query_uuid16(btstack_packet_handler_t callback, bd_addr_t remote, uint16_t uuid16); 94023f2764SMatthias Ringwald 95023f2764SMatthias Ringwald /* 96023f2764SMatthias Ringwald * @brief Searches SDP records on a remote device for all services with a given UUID. 97023f2764SMatthias Ringwald * @note calls sdp_client_query with service search pattern based on uuid128 98023f2764SMatthias Ringwald */ 99282ceebcSMatthias Ringwald uint8_t sdp_client_query_uuid128(btstack_packet_handler_t callback, bd_addr_t remote, const uint8_t* uuid128); 100023f2764SMatthias Ringwald 101023f2764SMatthias Ringwald 1026c927b22SMatthias Ringwald /** 1036c927b22SMatthias Ringwald * @brief Retrieves all attribute IDs of a SDP record specified by its service record handle and a list of attribute IDs. 1046c927b22SMatthias Ringwald * The remote data is handled by the SDP parser. The SDP parser delivers attribute values and done event via the callback. 1056c927b22SMatthias Ringwald * @note only provided if ENABLE_SDP_EXTRA_QUERIES is defined 1066c927b22SMatthias Ringwald * @param callback for attributes values and done event 1076c927b22SMatthias Ringwald * @param remote address 1086c927b22SMatthias Ringwald * @param search_service_record_handle 1096c927b22SMatthias Ringwald * @param des_attributeIDList 1106c927b22SMatthias Ringwald */ 111282ceebcSMatthias Ringwald uint8_t sdp_client_service_attribute_search(btstack_packet_handler_t callback, bd_addr_t remote, uint32_t search_service_record_handle, const uint8_t * des_attributeIDList); 1126c927b22SMatthias Ringwald 1136c927b22SMatthias Ringwald /** 1146c927b22SMatthias Ringwald * @brief Query the list of SDP records that match a given service search pattern. 1156c927b22SMatthias Ringwald * The remote data is handled by the SDP parser. The SDP parser delivers attribute values and done event via the callback. 1166c927b22SMatthias Ringwald * @note only provided if ENABLE_SDP_EXTRA_QUERIES is defined 1176c927b22SMatthias Ringwald * @param callback for attributes values and done event 1186c927b22SMatthias Ringwald * @param remote address 1196c927b22SMatthias Ringwald * @param des_service_search_pattern 1206c927b22SMatthias Ringwald */ 121282ceebcSMatthias Ringwald uint8_t sdp_client_service_search(btstack_packet_handler_t callback, bd_addr_t remote, const uint8_t * des_service_search_pattern); 1226c927b22SMatthias Ringwald 1238eaf1b42SMilanka Ringwald #ifdef ENABLE_SDP_EXTRA_QUERIES 1248eaf1b42SMilanka Ringwald void sdp_client_parse_service_record_handle_list(uint8_t* packet, uint16_t total_count, uint16_t current_count); 1258eaf1b42SMilanka Ringwald #endif 1266c927b22SMatthias Ringwald 1273deb3ec6SMatthias Ringwald /* API_END */ 1283deb3ec6SMatthias Ringwald 1293deb3ec6SMatthias Ringwald #if defined __cplusplus 1303deb3ec6SMatthias Ringwald } 1313deb3ec6SMatthias Ringwald #endif 1323deb3ec6SMatthias Ringwald 13380e33422SMatthias Ringwald #endif // SDP_CLIENT_H 134