17c006017SMilanka Ringwald /* 27c006017SMilanka Ringwald * Copyright (C) 2019 BlueKitchen GmbH 37c006017SMilanka Ringwald * 47c006017SMilanka Ringwald * Redistribution and use in source and binary forms, with or without 57c006017SMilanka Ringwald * modification, are permitted provided that the following conditions 67c006017SMilanka Ringwald * are met: 77c006017SMilanka Ringwald * 87c006017SMilanka Ringwald * 1. Redistributions of source code must retain the above copyright 97c006017SMilanka Ringwald * notice, this list of conditions and the following disclaimer. 107c006017SMilanka Ringwald * 2. Redistributions in binary form must reproduce the above copyright 117c006017SMilanka Ringwald * notice, this list of conditions and the following disclaimer in the 127c006017SMilanka Ringwald * documentation and/or other materials provided with the distribution. 137c006017SMilanka Ringwald * 3. Neither the name of the copyright holders nor the names of 147c006017SMilanka Ringwald * contributors may be used to endorse or promote products derived 157c006017SMilanka Ringwald * from this software without specific prior written permission. 167c006017SMilanka Ringwald * 4. Any redistribution, use, or modification is done solely for 177c006017SMilanka Ringwald * personal benefit and not for any commercial purpose or for 187c006017SMilanka Ringwald * monetary gain. 197c006017SMilanka Ringwald * 207c006017SMilanka Ringwald * THIS SOFTWARE IS PROVIDED BY BLUEKITCHEN GMBH AND CONTRIBUTORS 217c006017SMilanka Ringwald * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 227c006017SMilanka Ringwald * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 232fca4dadSMilanka Ringwald * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BLUEKITCHEN 242fca4dadSMilanka Ringwald * GMBH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 257c006017SMilanka Ringwald * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 267c006017SMilanka Ringwald * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS 277c006017SMilanka Ringwald * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED 287c006017SMilanka Ringwald * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 297c006017SMilanka Ringwald * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 307c006017SMilanka Ringwald * THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 317c006017SMilanka Ringwald * SUCH DAMAGE. 327c006017SMilanka Ringwald * 337c006017SMilanka Ringwald * Please inquire about commercial licensing options at 347c006017SMilanka Ringwald * [email protected] 357c006017SMilanka Ringwald * 367c006017SMilanka Ringwald */ 377c006017SMilanka Ringwald 38fe5a6c4eSMilanka Ringwald /** 39fe5a6c4eSMilanka Ringwald * OBEX Message Builder 40fe5a6c4eSMilanka Ringwald * 41fe5a6c4eSMilanka Ringwald */ 42fe5a6c4eSMilanka Ringwald 4380e33422SMatthias Ringwald #ifndef OBEX_MESSAGE_BUILDER_H 4480e33422SMatthias Ringwald #define OBEX_MESSAGE_BUILDER_H 457c006017SMilanka Ringwald 467c006017SMilanka Ringwald #if defined __cplusplus 477c006017SMilanka Ringwald extern "C" { 487c006017SMilanka Ringwald #endif 497c006017SMilanka Ringwald 507c006017SMilanka Ringwald #include <stdint.h> 517c006017SMilanka Ringwald #include <string.h> 527c006017SMilanka Ringwald 537c006017SMilanka Ringwald #include "btstack_defines.h" 547c006017SMilanka Ringwald 557c006017SMilanka Ringwald //------------------------------------------------------------------------------------------------------------ 567c006017SMilanka Ringwald // obex_message_builder.h 577c006017SMilanka Ringwald // 5881fb6ec9SMilanka Ringwald // Functions to incrementaly construct an OBEX message. The current length of the message is stored at 5981fb6ec9SMilanka Ringwald // offset 1 in the buffer. All functions return status code ERROR_CODE_MEMORY_CAPACITY_EXCEEDED id the 6081fb6ec9SMilanka Ringwald // buffer is too small. 617c006017SMilanka Ringwald 627c006017SMilanka Ringwald /* API_START */ 631f6020d5SMilanka Ringwald /** 641f6020d5SMilanka Ringwald * @brief Get message lenght 651f6020d5SMilanka Ringwald * @param buffer 661f6020d5SMilanka Ringwald * @return buffer_length 671f6020d5SMilanka Ringwald */ 681f6020d5SMilanka Ringwald uint16_t obex_message_builder_get_message_length(uint8_t * buffer); 697c006017SMilanka Ringwald 707c006017SMilanka Ringwald /** 717c006017SMilanka Ringwald * @brief Start Connect request 727c006017SMilanka Ringwald * @param buffer 737c006017SMilanka Ringwald * @param buffer_len 747c006017SMilanka Ringwald * @param obex_version_number 757c006017SMilanka Ringwald * @param flags 767c006017SMilanka Ringwald * @param maximum_obex_packet_length 7781fb6ec9SMilanka Ringwald * @return status 787c006017SMilanka Ringwald */ 797c006017SMilanka Ringwald uint8_t obex_message_builder_request_create_connect(uint8_t * buffer, uint16_t buffer_len, uint8_t obex_version_number, uint8_t flags, uint16_t maximum_obex_packet_length); 807c006017SMilanka Ringwald 817c006017SMilanka Ringwald /** 821f6020d5SMilanka Ringwald * @brief Start Connect response 831f6020d5SMilanka Ringwald * @param buffer 841f6020d5SMilanka Ringwald * @param buffer_len 851f6020d5SMilanka Ringwald * @param obex_version_number 861f6020d5SMilanka Ringwald * @param flags 871f6020d5SMilanka Ringwald * @param maximum_obex_packet_length 881f6020d5SMilanka Ringwald * @param connection_id 891f6020d5SMilanka Ringwald * @return status 901f6020d5SMilanka Ringwald */ 911f6020d5SMilanka Ringwald uint8_t obex_message_builder_response_create_connect(uint8_t * buffer, uint16_t buffer_len, uint8_t obex_version_number, uint8_t flags, uint16_t maximum_obex_packet_length, uint32_t connection_id); 921f6020d5SMilanka Ringwald 931f6020d5SMilanka Ringwald /** 948460ee57SMatthias Ringwald * @brief Start General response with given response code 9509ef1e1eSMatthias Ringwald * @param buffer 9609ef1e1eSMatthias Ringwald * @param buffer_len 978460ee57SMatthias Ringwald * @param response_code 9809ef1e1eSMatthias Ringwald * @return status 9909ef1e1eSMatthias Ringwald */ 1008460ee57SMatthias Ringwald uint8_t obex_message_builder_response_create_general(uint8_t * buffer, uint16_t buffer_len, uint8_t response_code); 10109ef1e1eSMatthias Ringwald 10209ef1e1eSMatthias Ringwald /** 103c2e0c88eSMatthias Ringwald * @brief Update response code 104c2e0c88eSMatthias Ringwald * @param buffer 105c2e0c88eSMatthias Ringwald * @param buffer_len 106c2e0c88eSMatthias Ringwald * @param response_code 107c2e0c88eSMatthias Ringwald * @return status 108c2e0c88eSMatthias Ringwald */ 109c2e0c88eSMatthias Ringwald uint8_t obex_message_builder_response_update_code(uint8_t * buffer, uint16_t buffer_len, uint8_t response_code); 110c2e0c88eSMatthias Ringwald 111c2e0c88eSMatthias Ringwald /** 1127c006017SMilanka Ringwald * @brief Start Disconnect request 1137c006017SMilanka Ringwald * @param buffer 1147c006017SMilanka Ringwald * @param buffer_len 1157c006017SMilanka Ringwald * @param connection_id 11681fb6ec9SMilanka Ringwald * @return status 1177c006017SMilanka Ringwald */ 1187c006017SMilanka Ringwald uint8_t obex_message_builder_request_create_disconnect(uint8_t * buffer, uint16_t buffer_len, uint32_t connection_id); 1197c006017SMilanka Ringwald 1207c006017SMilanka Ringwald /** 1217c006017SMilanka Ringwald * @brief Create Get request 1227c006017SMilanka Ringwald * @param buffer 1237c006017SMilanka Ringwald * @param buffer_len 1247c006017SMilanka Ringwald * @param connection_id 12581fb6ec9SMilanka Ringwald * @return status 1267c006017SMilanka Ringwald */ 1277c006017SMilanka Ringwald uint8_t obex_message_builder_request_create_get(uint8_t * buffer, uint16_t buffer_len, uint32_t connection_id); 1287c006017SMilanka Ringwald 1297c006017SMilanka Ringwald /** 1307c006017SMilanka Ringwald * @brief Create Put request 1317c006017SMilanka Ringwald * @param buffer 1327c006017SMilanka Ringwald * @param buffer_len 1337c006017SMilanka Ringwald * @param connection_id 13481fb6ec9SMilanka Ringwald * @return status 1357c006017SMilanka Ringwald */ 1367c006017SMilanka Ringwald uint8_t obex_message_builder_request_create_put(uint8_t * buffer, uint16_t buffer_len, uint32_t connection_id); 1377c006017SMilanka Ringwald 1387c006017SMilanka Ringwald 1397c006017SMilanka Ringwald /** 1407c006017SMilanka Ringwald * @brief Create Abort request 1417c006017SMilanka Ringwald * @param buffer 1427c006017SMilanka Ringwald * @param buffer_len 1437c006017SMilanka Ringwald * @param connection_id 14481fb6ec9SMilanka Ringwald * @return status 1457c006017SMilanka Ringwald */ 1467c006017SMilanka Ringwald uint8_t obex_message_builder_request_create_abort(uint8_t * buffer, uint16_t buffer_len, uint32_t connection_id); 1477c006017SMilanka Ringwald 1487c006017SMilanka Ringwald /** 1497c006017SMilanka Ringwald * @brief Start Set Path request 1507c006017SMilanka Ringwald * @param buffer 1517c006017SMilanka Ringwald * @param buffer_len 1527c006017SMilanka Ringwald * @param connection_id 15381fb6ec9SMilanka Ringwald * @return status 1547c006017SMilanka Ringwald */ 1557c006017SMilanka Ringwald uint8_t obex_message_builder_request_create_set_path(uint8_t * buffer, uint16_t buffer_len, uint8_t flags, uint32_t connection_id); 1567c006017SMilanka Ringwald 1577c006017SMilanka Ringwald /** 158*49df53afSSimon Budig * @brief Control the "final" bit 159*49df53afSSimon Budig * @param buffer 160*49df53afSSimon Budig * @param buffer_len 161*49df53afSSimon Budig * @param final 162*49df53afSSimon Budig * @return status 163*49df53afSSimon Budig */ 164*49df53afSSimon Budig uint8_t obex_message_builder_set_final_bit (uint8_t * buffer, uint16_t buffer_len, bool final); 165*49df53afSSimon Budig 166*49df53afSSimon Budig /** 1677c006017SMilanka Ringwald * @brief Add SRM Enable 1687c006017SMilanka Ringwald * @param buffer 1697c006017SMilanka Ringwald * @param buffer_len 17081fb6ec9SMilanka Ringwald * @return status 1717c006017SMilanka Ringwald */ 1727c006017SMilanka Ringwald uint8_t obex_message_builder_header_add_srm_enable(uint8_t * buffer, uint16_t buffer_len); 1737c006017SMilanka Ringwald 17481fb6ec9SMilanka Ringwald /** 17581fb6ec9SMilanka Ringwald * @brief Add header with single byte value (8 bit) 17681fb6ec9SMilanka Ringwald * @param buffer 17781fb6ec9SMilanka Ringwald * @param buffer_len 17881fb6ec9SMilanka Ringwald * @param header_type 17981fb6ec9SMilanka Ringwald * @param value 18081fb6ec9SMilanka Ringwald * @return status 18181fb6ec9SMilanka Ringwald */ 18281fb6ec9SMilanka Ringwald uint8_t obex_message_builder_header_add_byte(uint8_t * buffer, uint16_t buffer_len, uint8_t header_type, uint8_t value); 1837c006017SMilanka Ringwald 18481fb6ec9SMilanka Ringwald /** 18581fb6ec9SMilanka Ringwald * @brief Add header with word value (32 bit) 18681fb6ec9SMilanka Ringwald * @param buffer 18781fb6ec9SMilanka Ringwald * @param buffer_len 18881fb6ec9SMilanka Ringwald * @param header_type 18981fb6ec9SMilanka Ringwald * @param value 19081fb6ec9SMilanka Ringwald * @return status 19181fb6ec9SMilanka Ringwald */ 19281fb6ec9SMilanka Ringwald uint8_t obex_message_builder_header_add_word(uint8_t * buffer, uint16_t buffer_len, uint8_t header_type, uint32_t value); 1937c006017SMilanka Ringwald 19481fb6ec9SMilanka Ringwald /** 19581fb6ec9SMilanka Ringwald * @brief Add header with variable size 19681fb6ec9SMilanka Ringwald * @param buffer 19781fb6ec9SMilanka Ringwald * @param buffer_len 19881fb6ec9SMilanka Ringwald * @param header_type 19981fb6ec9SMilanka Ringwald * @param header_data 20081fb6ec9SMilanka Ringwald * @param header_data_length 20181fb6ec9SMilanka Ringwald * @return status 20281fb6ec9SMilanka Ringwald */ 20381fb6ec9SMilanka Ringwald uint8_t obex_message_builder_header_add_variable(uint8_t * buffer, uint16_t buffer_len, uint8_t header_type, const uint8_t * header_data, uint16_t header_data_length); 2047c006017SMilanka Ringwald 2057c006017SMilanka Ringwald /** 206*49df53afSSimon Budig * @brief Add (partial) header with variable size 207*49df53afSSimon Budig * @param buffer 208*49df53afSSimon Budig * @param buffer_len 209*49df53afSSimon Budig * @param header_type 210*49df53afSSimon Budig * @param header_data 211*49df53afSSimon Budig * @param header_data_length 212*49df53afSSimon Budig * @param ret_length 213*49df53afSSimon Budig * @return status 214*49df53afSSimon Budig */ 215*49df53afSSimon Budig uint8_t obex_message_builder_header_fillup_variable(uint8_t * buffer, uint16_t buffer_len, uint8_t header_type, const uint8_t * header_data, uint16_t header_data_length, uint32_t * ret_length); 216*49df53afSSimon Budig 217*49df53afSSimon Budig /** 2187c006017SMilanka Ringwald * @brief Add name header to current request 2197c006017SMilanka Ringwald * @param buffer 2207c006017SMilanka Ringwald * @param buffer_len 2212946c1e3SMatthias Ringwald * @param name with trailing '\0' 22281fb6ec9SMilanka Ringwald * @return status 2237c006017SMilanka Ringwald */ 2247c006017SMilanka Ringwald uint8_t obex_message_builder_header_add_name(uint8_t * buffer, uint16_t buffer_len, const char * name); 2257c006017SMilanka Ringwald 2267c006017SMilanka Ringwald /** 2272946c1e3SMatthias Ringwald * @brief Add name header to current request 2282946c1e3SMatthias Ringwald * @param buffer 2292946c1e3SMatthias Ringwald * @param buffer_len 2302946c1e3SMatthias Ringwald * @param name 2312946c1e3SMatthias Ringwald * @param name_len 2322946c1e3SMatthias Ringwald * @return status 2332946c1e3SMatthias Ringwald */ 2342946c1e3SMatthias Ringwald uint8_t obex_message_builder_header_add_name_prefix(uint8_t * buffer, uint16_t buffer_len, const char * name, uint16_t name_len); 2352946c1e3SMatthias Ringwald 2362946c1e3SMatthias Ringwald /** 2377c006017SMilanka Ringwald * @brief Add target header to current request 2387c006017SMilanka Ringwald * @param buffer 2397c006017SMilanka Ringwald * @param buffer_len 2407c006017SMilanka Ringwald * @param target 2412946c1e3SMatthias Ringwald * @param length of target 24281fb6ec9SMilanka Ringwald * @return status 2437c006017SMilanka Ringwald */ 2447c006017SMilanka Ringwald uint8_t obex_message_builder_header_add_target(uint8_t * buffer, uint16_t buffer_len, const uint8_t * target, uint16_t length); 2457c006017SMilanka Ringwald 2467c006017SMilanka Ringwald /** 2471f6020d5SMilanka Ringwald * @brief Add target header to current request 2481f6020d5SMilanka Ringwald * @param buffer 2491f6020d5SMilanka Ringwald * @param buffer_len 2501f6020d5SMilanka Ringwald * @param who fixed len of 16 bytes 2511f6020d5SMilanka Ringwald * @return status 2521f6020d5SMilanka Ringwald */ 2531f6020d5SMilanka Ringwald uint8_t obex_message_builder_header_add_who(uint8_t * buffer, uint16_t buffer_len, const uint8_t * who); 2541f6020d5SMilanka Ringwald 2551f6020d5SMilanka Ringwald 2561f6020d5SMilanka Ringwald /** 2577c006017SMilanka Ringwald * @brief Add type header to current request 2587c006017SMilanka Ringwald * @param buffer 2597c006017SMilanka Ringwald * @param buffer_len 2607c006017SMilanka Ringwald * @param type 26181fb6ec9SMilanka Ringwald * @return status 2627c006017SMilanka Ringwald */ 2637c006017SMilanka Ringwald uint8_t obex_message_builder_header_add_type(uint8_t * buffer, uint16_t buffer_len, const char * type); 2647c006017SMilanka Ringwald 2657c006017SMilanka Ringwald /** 2667c006017SMilanka Ringwald * @brief Add count header to current request 2677c006017SMilanka Ringwald * @param buffer 2687c006017SMilanka Ringwald * @param buffer_len 2697c006017SMilanka Ringwald * @param count 27081fb6ec9SMilanka Ringwald * @return status 2717c006017SMilanka Ringwald */ 2727c006017SMilanka Ringwald uint8_t obex_message_builder_header_add_count(uint8_t * buffer, uint16_t buffer_len, uint32_t count); 2737c006017SMilanka Ringwald 2747c006017SMilanka Ringwald /** 275*49df53afSSimon Budig * @brief Add length header to current request 276*49df53afSSimon Budig * @param buffer 277*49df53afSSimon Budig * @param buffer_len 278*49df53afSSimon Budig * @param lenght 279*49df53afSSimon Budig * @return status 280*49df53afSSimon Budig */ 281*49df53afSSimon Budig uint8_t obex_message_builder_header_add_length(uint8_t * buffer, uint16_t buffer_len, uint32_t length); 282*49df53afSSimon Budig 283*49df53afSSimon Budig /** 2847c006017SMilanka Ringwald * @brief Add application parameters header to current request 2857c006017SMilanka Ringwald * @param buffer 2867c006017SMilanka Ringwald * @param buffer_len 2877c006017SMilanka Ringwald * @param data 2881f6020d5SMilanka Ringwald * @param length of application parameters 28981fb6ec9SMilanka Ringwald * @return status 2907c006017SMilanka Ringwald */ 2917c006017SMilanka Ringwald uint8_t obex_message_builder_header_add_application_parameters(uint8_t * buffer, uint16_t buffer_len, const uint8_t * data, uint16_t length); 2927c006017SMilanka Ringwald 2937c006017SMilanka Ringwald /** 2947c006017SMilanka Ringwald * @brief Add application parameters header to current request 2957c006017SMilanka Ringwald * @param buffer 2967c006017SMilanka Ringwald * @param buffer_len 2977c006017SMilanka Ringwald * @param data 2981f6020d5SMilanka Ringwald * @param length of challenge response 29981fb6ec9SMilanka Ringwald * @return status 3007c006017SMilanka Ringwald */ 3017c006017SMilanka Ringwald uint8_t obex_message_builder_header_add_challenge_response(uint8_t * buffer, uint16_t buffer_len, const uint8_t * data, uint16_t length); 3027c006017SMilanka Ringwald 3037c006017SMilanka Ringwald /** 3047c006017SMilanka Ringwald * @brief Add body 3057c006017SMilanka Ringwald * @param buffer 3067c006017SMilanka Ringwald * @param buffer_len 3077c006017SMilanka Ringwald * @param data 3081f6020d5SMilanka Ringwald * @param length 30981fb6ec9SMilanka Ringwald * @return status 3107c006017SMilanka Ringwald */ 311948b3642SMilanka Ringwald uint8_t obex_message_builder_body_add_static(uint8_t * buffer, uint16_t buffer_len, const uint8_t * data, uint32_t length); 3127c006017SMilanka Ringwald 313*49df53afSSimon Budig /** 314*49df53afSSimon Budig * @brief Add body 315*49df53afSSimon Budig * @param buffer 316*49df53afSSimon Budig * @param buffer_len 317*49df53afSSimon Budig * @param data 318*49df53afSSimon Budig * @param length 319*49df53afSSimon Budig * @param ret_length 320*49df53afSSimon Budig * @return status 321*49df53afSSimon Budig */ 322*49df53afSSimon Budig uint8_t obex_message_builder_body_fillup_static(uint8_t * buffer, uint16_t buffer_len, const uint8_t * data, uint32_t length, uint32_t *ret_length); 323*49df53afSSimon Budig 3247c006017SMilanka Ringwald /* API_END */ 3257c006017SMilanka Ringwald 326948b3642SMilanka Ringwald // int obex_message_builder_body_add_dynamic(uint8_t * buffer, uint16_t buffer_len, uint32_t length, void (*data_callback)(uint32_t offset, uint8_t * buffer, uint32_t len)); 32781fb6ec9SMilanka Ringwald 3287c006017SMilanka Ringwald #if defined __cplusplus 3297c006017SMilanka Ringwald } 3307c006017SMilanka Ringwald #endif 3317c006017SMilanka Ringwald #endif 3327c006017SMilanka Ringwald 333