aboutsummaryrefslogtreecommitdiff
path: root/src/http/v3/ngx_http_v3_streams.c
diff options
context:
space:
mode:
authorRoman Arutyunyan <arut@nginx.com>2021-07-29 10:03:36 +0300
committerRoman Arutyunyan <arut@nginx.com>2021-07-29 10:03:36 +0300
commit5bb45c98a73044ce2b7f389c7764cc10cc869bed (patch)
treed65d773cea42bb56c7ac730c02ebc990657d0bf1 /src/http/v3/ngx_http_v3_streams.c
parentb7a5224bd8b2976c2978b0be2569a44de730c000 (diff)
downloadnginx-5bb45c98a73044ce2b7f389c7764cc10cc869bed.tar.gz
nginx-5bb45c98a73044ce2b7f389c7764cc10cc869bed.zip
HTTP/3: require mandatory uni streams before additional ones.
As per quic-http-34: Endpoints SHOULD create the HTTP control stream as well as the unidirectional streams required by mandatory extensions (such as the QPACK encoder and decoder streams) first, and then create additional streams as allowed by their peer. Previously, client could create and destroy additional uni streams unlimited number of times before creating mandatory streams.
Diffstat (limited to 'src/http/v3/ngx_http_v3_streams.c')
-rw-r--r--src/http/v3/ngx_http_v3_streams.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/src/http/v3/ngx_http_v3_streams.c b/src/http/v3/ngx_http_v3_streams.c
index fa39be78a..693225b89 100644
--- a/src/http/v3/ngx_http_v3_streams.c
+++ b/src/http/v3/ngx_http_v3_streams.c
@@ -91,6 +91,8 @@ ngx_http_v3_register_uni_stream(ngx_connection_t *c, uint64_t type)
ngx_http_v3_session_t *h3c;
ngx_http_v3_uni_stream_t *us;
+ h3c = ngx_http_v3_get_session(c);
+
switch (type) {
case NGX_HTTP_V3_STREAM_ENCODER:
@@ -119,12 +121,19 @@ ngx_http_v3_register_uni_stream(ngx_connection_t *c, uint64_t type)
ngx_log_debug1(NGX_LOG_DEBUG_HTTP, c->log, 0,
"http3 stream 0x%02xL", type);
+
+ if (h3c->known_streams[NGX_HTTP_V3_STREAM_CLIENT_ENCODER] == NULL
+ || h3c->known_streams[NGX_HTTP_V3_STREAM_CLIENT_DECODER] == NULL
+ || h3c->known_streams[NGX_HTTP_V3_STREAM_CLIENT_CONTROL] == NULL)
+ {
+ ngx_log_error(NGX_LOG_INFO, c->log, 0, "missing mandatory stream");
+ return NGX_HTTP_V3_ERR_STREAM_CREATION_ERROR;
+ }
+
index = -1;
}
if (index >= 0) {
- h3c = ngx_http_v3_get_session(c);
-
if (h3c->known_streams[index]) {
ngx_log_error(NGX_LOG_INFO, c->log, 0, "stream exists");
return NGX_HTTP_V3_ERR_STREAM_CREATION_ERROR;