summaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorlijia <[email protected]>2024-08-30 19:09:11 +0800
committerlijia <[email protected]>2024-09-02 09:42:09 +0800
commit94a75460e9547389d5b7f72dd8467d1dfc29b599 (patch)
tree7c50427feb585589f81528fb3b0df33828999b54 /include
parent82cb1eaeeba92f34405744c6b2449b7b80930678 (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.h63
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)