http_header.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. /*
  2. * SPDX-FileCopyrightText: 2015-2021 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #ifndef _HTTP_HEADER_H_
  7. #define _HTTP_HEADER_H_
  8. #include "sys/queue.h"
  9. #include "esp_err.h"
  10. #ifdef __cplusplus
  11. extern "C" {
  12. #endif
  13. typedef struct http_header *http_header_handle_t;
  14. typedef struct http_header_item *http_header_item_handle_t;
  15. /**
  16. * @brief initialize and allocate the memory for the header object
  17. *
  18. * @return
  19. * - http_header_handle_t
  20. * - NULL if any errors
  21. */
  22. http_header_handle_t http_header_init(void);
  23. /**
  24. * @brief Cleanup and free all http header pairs
  25. *
  26. * @param[in] header The header
  27. *
  28. * @return
  29. * - ESP_OK
  30. * - ESP_FAIL
  31. */
  32. esp_err_t http_header_clean(http_header_handle_t header);
  33. /**
  34. * @brief Cleanup with http_header_clean and destroy http header handle object
  35. *
  36. * @param[in] header The header
  37. *
  38. * @return
  39. * - ESP_OK
  40. * - ESP_FAIL
  41. */
  42. esp_err_t http_header_destroy(http_header_handle_t header);
  43. /**
  44. * @brief Add a key-value pair of http header to the list,
  45. * note that with value = NULL, this function will remove the header with `key` already exists in the list.
  46. *
  47. * @param[in] header The header
  48. * @param[in] key The key
  49. * @param[in] value The value
  50. *
  51. * @return
  52. * - ESP_OK
  53. * - ESP_FAIL
  54. */
  55. esp_err_t http_header_set(http_header_handle_t header, const char *key, const char *value);
  56. /**
  57. * @brief Sample as `http_header_set` but the value can be formated
  58. *
  59. * @param[in] header The header
  60. * @param[in] key The key
  61. * @param[in] format The format
  62. * @param[in] ... format parameters
  63. *
  64. * @return Total length of value
  65. */
  66. int http_header_set_format(http_header_handle_t header, const char *key, const char *format, ...);
  67. /**
  68. * @brief Get a value of header in header list
  69. * The address of the value will be assign set to `value` parameter or NULL if no header with the key exists in the list
  70. *
  71. * @param[in] header The header
  72. * @param[in] key The key
  73. * @param[out] value The value
  74. *
  75. * @return
  76. * - ESP_OK
  77. * - ESP_FAIL
  78. */
  79. esp_err_t http_header_get(http_header_handle_t header, const char *key, char **value);
  80. /**
  81. * @brief Create HTTP header string from the header with index, output string to buffer with buffer_len
  82. * Also return the last index of header was generated
  83. *
  84. * @param[in] header The header
  85. * @param[in] index The index
  86. * @param buffer The buffer
  87. * @param buffer_len The buffer length
  88. *
  89. * @return The last index of header was generated
  90. */
  91. int http_header_generate_string(http_header_handle_t header, int index, char *buffer, int *buffer_len);
  92. /**
  93. * @brief Remove the header with key from the headers list
  94. *
  95. * @param[in] header The header
  96. * @param[in] key The key
  97. *
  98. * @return
  99. * - ESP_OK
  100. * - ESP_FAIL
  101. */
  102. esp_err_t http_header_delete(http_header_handle_t header, const char *key);
  103. #ifdef __cplusplus
  104. }
  105. #endif
  106. #endif