diff options
| author | Vladimir Homutov <vl@nginx.com> | 2020-03-24 11:59:14 +0300 |
|---|---|---|
| committer | Vladimir Homutov <vl@nginx.com> | 2020-03-24 11:59:14 +0300 |
| commit | 57544f758953a968d5c02c84d59fea33a7d48ea5 (patch) | |
| tree | de95f757447ba9c0c3fe50e32dcf545a36f3d100 /src/event/ngx_event_quic.c | |
| parent | f20af3dabca75b1f57f5c72a0e45e7251762b43c (diff) | |
| download | nginx-57544f758953a968d5c02c84d59fea33a7d48ea5.tar.gz nginx-57544f758953a968d5c02c84d59fea33a7d48ea5.tar.bz2 | |
Implemented sending HANDSHAKE_DONE frame after handshake.
This makes it possible to switch to draft 27 by default.
Diffstat (limited to 'src/event/ngx_event_quic.c')
| -rw-r--r-- | src/event/ngx_event_quic.c | 18 |
1 files changed, 15 insertions, 3 deletions
diff --git a/src/event/ngx_event_quic.c b/src/event/ngx_event_quic.c index a466ac184..d913f4f43 100644 --- a/src/event/ngx_event_quic.c +++ b/src/event/ngx_event_quic.c @@ -964,9 +964,10 @@ static ngx_int_t ngx_quic_handle_crypto_frame(ngx_connection_t *c, ngx_quic_header_t *pkt, ngx_quic_crypto_frame_t *f) { - int sslerr; - ssize_t n; - ngx_ssl_conn_t *ssl_conn; + int sslerr; + ssize_t n; + ngx_ssl_conn_t *ssl_conn; + ngx_quic_frame_t *frame; if (f->offset != 0x0) { ngx_log_error(NGX_LOG_INFO, c->log, 0, @@ -1012,6 +1013,17 @@ ngx_quic_handle_crypto_frame(ngx_connection_t *c, ngx_quic_header_t *pkt, ngx_log_debug0(NGX_LOG_DEBUG_EVENT, c->log, 0, "handshake completed successfully"); + + frame = ngx_pcalloc(c->pool, sizeof(ngx_quic_frame_t)); + if (frame == NULL) { + return NGX_ERROR; + } + + /* 12.4 Frames and frame types, figure 8 */ + frame->level = ssl_encryption_application; + frame->type = NGX_QUIC_FT_HANDSHAKE_DONE; + ngx_sprintf(frame->info, "HANDSHAKE DONE on handshake completed"); + ngx_quic_queue_frame(c->quic, frame); } ngx_log_debug2(NGX_LOG_DEBUG_EVENT, c->log, 0, |
