123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296 |
- /* SPDX-License-Identifier: MIT */
- /* Copyright Joyent, Inc. and other Node contributors. All rights reserved.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to
- * deal in the Software without restriction, including without limitation the
- * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
- * sell copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
- * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
- * IN THE SOFTWARE.
- */
- #ifndef ZEPHYR_INCLUDE_NET_HTTP_PARSER_H_
- #define ZEPHYR_INCLUDE_NET_HTTP_PARSER_H_
- /* Also update SONAME in the Makefile whenever you change these. */
- #define HTTP_PARSER_VERSION_MAJOR 2
- #define HTTP_PARSER_VERSION_MINOR 7
- #define HTTP_PARSER_VERSION_PATCH 1
- #include <sys/types.h>
- #if defined(_WIN32) && !defined(__MINGW32__) && \
- (!defined(_MSC_VER) || _MSC_VER < 1600) && !defined(__WINE__)
- #include <BaseTsd.h>
- #include <stddef.h>
- typedef __int8 int8_t;
- typedef unsigned __int8 uint8_t;
- typedef __int16 int16_t;
- typedef unsigned __int16 uint16_t;
- typedef __int32 int32_t;
- typedef unsigned __int32 uint32_t;
- typedef __int64 int64_t;
- typedef unsigned __int64 uint64_t;
- #else
- #include <zephyr/types.h>
- #include <stddef.h>
- #endif
- #include <net/http_parser_state.h>
- #include <net/http_parser_url.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- /* Maximium header size allowed. If the macro is not defined
- * before including this header then the default is used. To
- * change the maximum header size, define the macro in the build
- * environment (e.g. -DHTTP_MAX_HEADER_SIZE=<value>). To remove
- * the effective limit on the size of the header, define the macro
- * to a very large number (e.g. -DHTTP_MAX_HEADER_SIZE=0x7fffffff)
- */
- #ifndef HTTP_MAX_HEADER_SIZE
- # define HTTP_MAX_HEADER_SIZE (80 * 1024)
- #endif
- struct http_parser;
- struct http_parser_settings;
- /* Callbacks should return non-zero to indicate an error. The parser will
- * then halt execution.
- *
- * The one exception is on_headers_complete. In a HTTP_RESPONSE parser
- * returning '1' from on_headers_complete will tell the parser that it
- * should not expect a body. This is used when receiving a response to a
- * HEAD request which may contain 'Content-Length' or 'Transfer-Encoding:
- * chunked' headers that indicate the presence of a body.
- *
- * Returning `2` from on_headers_complete will tell parser that it should not
- * expect neither a body nor any further responses on this connection. This is
- * useful for handling responses to a CONNECT request which may not contain
- * `Upgrade` or `Connection: upgrade` headers.
- *
- * http_data_cb does not return data chunks. It will be called arbitrarily
- * many times for each string. E.G. you might get 10 callbacks for "on_url"
- * each providing just a few characters more data.
- */
- typedef int (*http_data_cb)(struct http_parser *, const char *at,
- size_t length);
- typedef int (*http_cb)(struct http_parser *);
- enum http_method {
- HTTP_DELETE = 0,
- HTTP_GET = 1,
- HTTP_HEAD = 2,
- HTTP_POST = 3,
- HTTP_PUT = 4,
- HTTP_CONNECT = 5,
- HTTP_OPTIONS = 6,
- HTTP_TRACE = 7,
- HTTP_COPY = 8,
- HTTP_LOCK = 9,
- HTTP_MKCOL = 10,
- HTTP_MOVE = 11,
- HTTP_PROPFIND = 12,
- HTTP_PROPPATCH = 13,
- HTTP_SEARCH = 14,
- HTTP_UNLOCK = 15,
- HTTP_BIND = 16,
- HTTP_REBIND = 17,
- HTTP_UNBIND = 18,
- HTTP_ACL = 19,
- HTTP_REPORT = 20,
- HTTP_MKACTIVITY = 21,
- HTTP_CHECKOUT = 22,
- HTTP_MERGE = 23,
- HTTP_MSEARCH = 24,
- HTTP_NOTIFY = 25,
- HTTP_SUBSCRIBE = 26,
- HTTP_UNSUBSCRIBE = 27,
- HTTP_PATCH = 28,
- HTTP_PURGE = 29,
- HTTP_MKCALENDAR = 30,
- HTTP_LINK = 31,
- HTTP_UNLINK = 32
- };
- enum http_parser_type { HTTP_REQUEST, HTTP_RESPONSE, HTTP_BOTH };
- /* Flag values for http_parser.flags field */
- enum flags {
- F_CHUNKED = 1 << 0,
- F_CONNECTION_KEEP_ALIVE = 1 << 1,
- F_CONNECTION_CLOSE = 1 << 2,
- F_CONNECTION_UPGRADE = 1 << 3,
- F_TRAILING = 1 << 4,
- F_UPGRADE = 1 << 5,
- F_SKIPBODY = 1 << 6,
- F_CONTENTLENGTH = 1 << 7
- };
- enum http_errno {
- HPE_OK,
- HPE_CB_message_begin,
- HPE_CB_url,
- HPE_CB_header_field,
- HPE_CB_header_value,
- HPE_CB_headers_complete,
- HPE_CB_body,
- HPE_CB_message_complete,
- HPE_CB_status,
- HPE_CB_chunk_header,
- HPE_CB_chunk_complete,
- HPE_INVALID_EOF_STATE,
- HPE_HEADER_OVERFLOW,
- HPE_CLOSED_CONNECTION,
- HPE_INVALID_VERSION,
- HPE_INVALID_STATUS,
- HPE_INVALID_METHOD,
- HPE_INVALID_URL,
- HPE_INVALID_HOST,
- HPE_INVALID_PORT,
- HPE_INVALID_PATH,
- HPE_INVALID_QUERY_STRING,
- HPE_INVALID_FRAGMENT,
- HPE_LF_EXPECTED,
- HPE_INVALID_HEADER_TOKEN,
- HPE_INVALID_CONTENT_LENGTH,
- HPE_UNEXPECTED_CONTENT_LENGTH,
- HPE_INVALID_CHUNK_SIZE,
- HPE_INVALID_CONSTANT,
- HPE_INVALID_INTERNAL_STATE,
- HPE_STRICT,
- HPE_PAUSED,
- HPE_UNKNOWN
- };
- /* Get an http_errno value from an http_parser */
- #define HTTP_PARSER_ERRNO(p) ((enum http_errno) (p)->http_errno)
- struct http_parser {
- /** PRIVATE **/
- unsigned int type : 2; /* enum http_parser_type */
- unsigned int flags : 8; /* F_xxx values from 'flags' enum;
- * semi-public
- */
- unsigned int state : 7; /* enum state from http_parser.c */
- unsigned int header_state : 7; /* enum header_state from http_parser.c
- */
- unsigned int index : 7; /* index into current matcher */
- unsigned int lenient_http_headers : 1;
- uint32_t nread; /* # bytes read in various scenarios */
- uint64_t content_length; /* # bytes in body (0 if no Content-Length
- * header)
- */
- /** READ-ONLY **/
- unsigned short http_major;
- unsigned short http_minor;
- unsigned int status_code : 16; /* responses only */
- unsigned int method : 8; /* requests only */
- unsigned int http_errno : 7;
- /* 1 = Upgrade header was present and the parser has exited because of
- * that.
- * 0 = No upgrade header present.
- * Should be checked when http_parser_execute() returns in addition to
- * error checking.
- */
- unsigned int upgrade : 1;
- /** PUBLIC **/
- void *data; /* A pointer to get hook to the "connection" or "socket"
- * object
- */
- /* Remote socket address of http connection, where parser can initiate
- * replies if necessary.
- */
- const struct sockaddr *addr;
- };
- struct http_parser_settings {
- http_cb on_message_begin;
- http_data_cb on_url;
- http_data_cb on_status;
- http_data_cb on_header_field;
- http_data_cb on_header_value;
- http_cb on_headers_complete;
- http_data_cb on_body;
- http_cb on_message_complete;
- /* When on_chunk_header is called, the current chunk length is stored
- * in parser->content_length.
- */
- http_cb on_chunk_header;
- http_cb on_chunk_complete;
- };
- /* Returns the library version. Bits 16-23 contain the major version number,
- * bits 8-15 the minor version number and bits 0-7 the patch level.
- * Usage example:
- *
- * unsigned long version = http_parser_version();
- * unsigned major = (version >> 16) & 255;
- * unsigned minor = (version >> 8) & 255;
- * unsigned patch = version & 255;
- * printf("http_parser v%u.%u.%u\n", major, minor, patch);
- */
- unsigned long http_parser_version(void);
- void http_parser_init(struct http_parser *parser, enum http_parser_type type);
- /* Initialize http_parser_settings members to 0
- */
- void http_parser_settings_init(struct http_parser_settings *settings);
- /* Executes the parser. Returns number of parsed bytes. Sets
- * `parser->http_errno` on error.
- */
- size_t http_parser_execute(struct http_parser *parser,
- const struct http_parser_settings *settings,
- const char *data, size_t len);
- /* If http_should_keep_alive() in the on_headers_complete or
- * on_message_complete callback returns 0, then this should be
- * the last message on the connection.
- * If you are the server, respond with the "Connection: close" header.
- * If you are the client, close the connection.
- */
- int http_should_keep_alive(const struct http_parser *parser);
- /* Returns a string version of the HTTP method. */
- const char *http_method_str(enum http_method m);
- /* Return a string name of the given error */
- const char *http_errno_name(enum http_errno err);
- /* Return a string description of the given error */
- const char *http_errno_description(enum http_errno err);
- /* Pause or un-pause the parser; a nonzero value pauses */
- void http_parser_pause(struct http_parser *parser, int paused);
- /* Checks if this is the final chunk of the body. */
- int http_body_is_final(const struct http_parser *parser);
- #ifdef __cplusplus
- }
- #endif
- #endif
|