diff options
| author | lijia <[email protected]> | 2024-08-30 19:09:11 +0800 |
|---|---|---|
| committer | lijia <[email protected]> | 2024-09-02 09:42:09 +0800 |
| commit | 94a75460e9547389d5b7f72dd8467d1dfc29b599 (patch) | |
| tree | 7c50427feb585589f81528fb3b0df33828999b54 /include | |
| parent | 82cb1eaeeba92f34405744c6b2449b7b80930678 (diff) | |
rename *.cpp to *.c; renmae API. move benchmarks/* to test/decoder/http; fix TSG-22347
Diffstat (limited to 'include')
| -rw-r--r-- | include/stellar/http.h | 63 |
1 files changed, 36 insertions, 27 deletions
diff --git a/include/stellar/http.h b/include/stellar/http.h index 3c749ca..1cc5bec 100644 --- a/include/stellar/http.h +++ b/include/stellar/http.h @@ -1,12 +1,11 @@ #pragma once - +#include <stddef.h> #ifdef __cplusplus extern "C" { #endif -#include <bits/types/struct_iovec.h> -#define HTTP_DECODER_TOPIC "HTTP_DECODER_MESSAGE" +#define HTTP_TOPIC "HTTP_MESSAGE" struct http_message; enum http_message_type @@ -15,14 +14,14 @@ extern "C" HTTP_MESSAGE_REQ_LINE, HTTP_MESSAGE_REQ_HEADER, - HTTP_MESSAGE_REQ_HEADER_END, + HTTP_MESSAGE_REQ_HEADER_END, // todo, delete END, push all fileds at once HTTP_MESSAGE_REQ_BODY_START, HTTP_MESSAGE_REQ_BODY, HTTP_MESSAGE_REQ_BODY_END, HTTP_MESSAGE_RES_LINE, HTTP_MESSAGE_RES_HEADER, - HTTP_MESSAGE_RES_HEADER_END, + HTTP_MESSAGE_RES_HEADER_END, // todo, delete END, push all fileds at once HTTP_MESSAGE_RES_BODY_START, HTTP_MESSAGE_RES_BODY, HTTP_MESSAGE_RES_BODY_END, @@ -32,67 +31,77 @@ extern "C" HTTP_MESSAGE_MAX }; - struct http_header + struct http_header_field { - struct iovec key; - struct iovec val; + char *name; + size_t name_len; + char *value; + size_t value_len; }; struct http_request_line { - struct iovec method; - struct iovec uri; - struct iovec version; + char *method; + size_t method_len; + char *uri; + size_t uri_len; + char *version; + size_t version_len; + int major_version; int minor_version; }; struct http_response_line { - struct iovec version; - struct iovec status; + char *version; + size_t version_len; + char *status; + size_t status_len; int major_version; int minor_version; int status_code; }; - typedef struct iovec hstring; + enum http_message_type http_message_get_type(const struct http_message *msg); - enum http_message_type http_message_type_get(const struct http_message *msg); + void http_message_get0_request_line(const struct http_message *msg, struct http_request_line *line); - void http_message_request_line_get0(const struct http_message *msg, struct http_request_line *line); - - void http_message_response_line_get0(const struct http_message *msg, struct http_response_line *line); + void http_message_get0_response_line(const struct http_message *msg, struct http_response_line *line); /* * Pay attention: key->iov_base is case-insensitive. */ - void http_message_header_get0(const struct http_message *msg, const struct iovec *key, struct http_header *hdr_result); + void http_message_get0_header(const struct http_message *msg, const char *name, size_t name_len, struct http_header_field *field_result); /** * @brief loop reading all headers. * * @retval succeed( >= 0) failed(-1) */ - int http_message_header_next(const struct http_message *msg, struct http_header *header); + int http_message_get0_next_header(const struct http_message *msg, struct http_header_field *header); /** * @retval succeed( >= 0) failed(-1) */ - int http_message_reset_header_iter(struct http_message *msg); + int http_message_reset_header_iter(struct http_message *msg); // to do , obsoleted - void http_message_raw_body_get0(const struct http_message *msg, struct iovec *body); + void http_message_get0_uncompressed_body(const struct http_message *msg, const char **body, size_t *body_len); /** - * @brief If the body hasn't been compressed, same as http_message_raw_body_get0(). + * @brief If the body hasn't been compressed, same as http_message_get0_uncompressed_body(). * */ - void http_message_decompress_body_get0(const struct http_message *msg, struct iovec *body); + void http_message_get0_decompressed_body(const struct http_message *msg, const char **body, size_t *body_len); - // raw - void http_message_raw_url_get0(const struct http_message *msg, struct iovec *url); + void http_message_get0_raw_url(const struct http_message *msg, const char **url, size_t *url_len); - void http_message_decoded_url_get0(const struct http_message *msg, struct iovec *url); + /* + return value: + 0: failed + >1: success, length of decoded_url_buffer, not C string( no EOF with '\0' ) + */ + size_t http_url_decode(const char *raw_url, size_t raw_url_len, char *decoded_url_buffer, size_t decoded_url_buffer_len); /** * @retval succeed( >= 0) failed(-1) |
