HTTP/3: introduced ngx_http_v3_parse_t structure.

The structure is used to parse an HTTP/3 request.  An object of this type is
added to ngx_http_request_t instead of h3_parse generic pointer.

Also, the new field is located outside of the request ephemeral zone to keep it
safe after request headers are parsed.
This commit is contained in:
Roman Arutyunyan 2021-02-17 15:56:34 +03:00
parent c83be09720
commit ffb099bf52
4 changed files with 16 additions and 23 deletions

View File

@ -20,6 +20,7 @@ typedef struct ngx_http_file_cache_s ngx_http_file_cache_t;
typedef struct ngx_http_log_ctx_s ngx_http_log_ctx_t; typedef struct ngx_http_log_ctx_s ngx_http_log_ctx_t;
typedef struct ngx_http_chunked_s ngx_http_chunked_t; typedef struct ngx_http_chunked_s ngx_http_chunked_t;
typedef struct ngx_http_v2_stream_s ngx_http_v2_stream_t; typedef struct ngx_http_v2_stream_s ngx_http_v2_stream_t;
typedef struct ngx_http_v3_parse_s ngx_http_v3_parse_t;
typedef ngx_int_t (*ngx_http_header_handler_pt)(ngx_http_request_t *r, typedef ngx_int_t (*ngx_http_header_handler_pt)(ngx_http_request_t *r,
ngx_table_elt_t *h, ngx_uint_t offset); ngx_table_elt_t *h, ngx_uint_t offset);

View File

@ -447,6 +447,7 @@ struct ngx_http_request_s {
ngx_http_connection_t *http_connection; ngx_http_connection_t *http_connection;
ngx_http_v2_stream_t *stream; ngx_http_v2_stream_t *stream;
ngx_http_v3_parse_t *v3_parse;
ngx_http_log_handler_pt log_handler; ngx_http_log_handler_pt log_handler;
@ -596,10 +597,6 @@ struct ngx_http_request_s {
u_char *port_start; u_char *port_start;
u_char *port_end; u_char *port_end;
#if (NGX_HTTP_V3)
void *h3_parse;
#endif
unsigned http_minor:16; unsigned http_minor:16;
unsigned http_major:16; unsigned http_major:16;
}; };

View File

@ -98,6 +98,12 @@ typedef struct {
} ngx_http_v3_loc_conf_t; } ngx_http_v3_loc_conf_t;
struct ngx_http_v3_parse_s {
ngx_http_v3_parse_headers_t headers;
ngx_http_v3_parse_data_t body;
};
typedef struct { typedef struct {
ngx_str_t name; ngx_str_t name;
ngx_str_t value; ngx_str_t value;

View File

@ -112,6 +112,12 @@ ngx_http_v3_init(ngx_connection_t *c)
r->http_version = NGX_HTTP_VERSION_30; r->http_version = NGX_HTTP_VERSION_30;
r->v3_parse = ngx_pcalloc(r->pool, sizeof(ngx_http_v3_parse_t));
if (r->v3_parse == NULL) {
ngx_http_close_connection(c);
return;
}
c->data = r; c->data = r;
rev = c->read; rev = c->read;
@ -144,17 +150,7 @@ ngx_http_v3_process_request(ngx_event_t *rev)
return; return;
} }
st = r->h3_parse; st = &r->v3_parse->headers;
if (st == NULL) {
st = ngx_pcalloc(c->pool, sizeof(ngx_http_v3_parse_headers_t));
if (st == NULL) {
ngx_http_finalize_request(r, NGX_HTTP_BAD_REQUEST);
return;
}
r->h3_parse = st;
}
b = r->header_in; b = r->header_in;
@ -949,20 +945,13 @@ ngx_http_v3_request_body_filter(ngx_http_request_t *r, ngx_chain_t *in)
ngx_http_v3_parse_data_t *st; ngx_http_v3_parse_data_t *st;
rb = r->request_body; rb = r->request_body;
st = r->h3_parse; st = &r->v3_parse->body;
if (rb->rest == -1) { if (rb->rest == -1) {
ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0, ngx_log_debug0(NGX_LOG_DEBUG_HTTP, r->connection->log, 0,
"http3 request body filter"); "http3 request body filter");
st = ngx_pcalloc(r->pool, sizeof(ngx_http_v3_parse_data_t));
if (st == NULL) {
return NGX_HTTP_INTERNAL_SERVER_ERROR;
}
r->h3_parse = st;
cscf = ngx_http_get_module_srv_conf(r, ngx_http_core_module); cscf = ngx_http_get_module_srv_conf(r, ngx_http_core_module);
rb->rest = cscf->large_client_header_buffers.size; rb->rest = cscf->large_client_header_buffers.size;