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 423deb3ec6SMatthias Ringwald #ifndef __SDP_CLIENT_H 433deb3ec6SMatthias 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 676c927b22SMatthias Ringwald * @return 1 when no query is active 686c927b22SMatthias Ringwald */ 696c927b22SMatthias Ringwald int sdp_client_ready(void); 706c927b22SMatthias Ringwald 713deb3ec6SMatthias Ringwald /** 7289374882SMatthias Ringwald * @brief Queries the SDP service of the remote device given a service search pattern and a list of attribute IDs. 736c927b22SMatthias Ringwald * The remote data is handled by the SDP parser. The SDP parser delivers attribute values and done event via the callback. 746c927b22SMatthias Ringwald * @param callback for attributes values and done event 756c927b22SMatthias Ringwald * @param remote address 766c927b22SMatthias Ringwald * @param des_service_search_pattern 776c927b22SMatthias Ringwald * @param des_attribute_id_list 783deb3ec6SMatthias Ringwald */ 796c927b22SMatthias Ringwald void 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); 803deb3ec6SMatthias Ringwald 81*023f2764SMatthias Ringwald /* 82*023f2764SMatthias Ringwald * @brief Searches SDP records on a remote device for all services with a given UUID. 83*023f2764SMatthias Ringwald * @note calls sdp_client_query with service search pattern based on uuid16 84*023f2764SMatthias Ringwald */ 85*023f2764SMatthias Ringwald void sdp_client_query_uuid16(btstack_packet_handler_t callback, bd_addr_t remote, uint16_t uuid16); 86*023f2764SMatthias Ringwald 87*023f2764SMatthias Ringwald /* 88*023f2764SMatthias Ringwald * @brief Searches SDP records on a remote device for all services with a given UUID. 89*023f2764SMatthias Ringwald * @note calls sdp_client_query with service search pattern based on uuid128 90*023f2764SMatthias Ringwald */ 91*023f2764SMatthias Ringwald void sdp_client_query_uuid128(btstack_packet_handler_t callback, bd_addr_t remote, const uint8_t* uuid128); 92*023f2764SMatthias Ringwald 93*023f2764SMatthias Ringwald 946c927b22SMatthias Ringwald /** 956c927b22SMatthias Ringwald * @brief Retrieves all attribute IDs of a SDP record specified by its service record handle and a list of attribute IDs. 966c927b22SMatthias Ringwald * The remote data is handled by the SDP parser. The SDP parser delivers attribute values and done event via the callback. 976c927b22SMatthias Ringwald * @note only provided if ENABLE_SDP_EXTRA_QUERIES is defined 986c927b22SMatthias Ringwald * @param callback for attributes values and done event 996c927b22SMatthias Ringwald * @param remote address 1006c927b22SMatthias Ringwald * @param search_service_record_handle 1016c927b22SMatthias Ringwald * @param des_attributeIDList 1026c927b22SMatthias Ringwald */ 1036c927b22SMatthias Ringwald void 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); 1046c927b22SMatthias Ringwald 1056c927b22SMatthias Ringwald /** 1066c927b22SMatthias Ringwald * @brief Query the list of SDP records that match a given service search pattern. 1076c927b22SMatthias Ringwald * The remote data is handled by the SDP parser. The SDP parser delivers attribute values and done event via the callback. 1086c927b22SMatthias Ringwald * @note only provided if ENABLE_SDP_EXTRA_QUERIES is defined 1096c927b22SMatthias Ringwald * @param callback for attributes values and done event 1106c927b22SMatthias Ringwald * @param remote address 1116c927b22SMatthias Ringwald * @param des_service_search_pattern 1126c927b22SMatthias Ringwald */ 1136c927b22SMatthias Ringwald void sdp_client_service_search(btstack_packet_handler_t callback, bd_addr_t remote, const uint8_t * des_service_search_pattern); 1146c927b22SMatthias Ringwald 1156c927b22SMatthias Ringwald 1163deb3ec6SMatthias Ringwald /* API_END */ 1173deb3ec6SMatthias Ringwald 1183deb3ec6SMatthias Ringwald #if defined __cplusplus 1193deb3ec6SMatthias Ringwald } 1203deb3ec6SMatthias Ringwald #endif 1213deb3ec6SMatthias Ringwald 1223deb3ec6SMatthias Ringwald #endif // __SDP_CLIENT_H 123