comparison src/event/quic/ngx_event_quic_tokens.h @ 9026:3550b00d9dc8 quic

QUIC: avoided pool usage in token calculation.
author Vladimir Homutov <vl@nginx.com>
date Tue, 31 May 2022 11:05:22 +0400
parents 4117aa7fa38e
children 77c1418916f7
comparison
equal deleted inserted replaced
9025:e50f77a2d0b0 9026:3550b00d9dc8
10 10
11 #include <ngx_config.h> 11 #include <ngx_config.h>
12 #include <ngx_core.h> 12 #include <ngx_core.h>
13 13
14 14
15 #define NGX_QUIC_MAX_TOKEN_SIZE 64
16 /* SHA-1(addr)=20 + sizeof(time_t) + retry(1) + odcid.len(1) + odcid */
17
18 /* RFC 3602, 2.1 and 2.4 for AES-CBC block size and IV length */
19 #define NGX_QUIC_AES_256_CBC_IV_LEN 16
20 #define NGX_QUIC_AES_256_CBC_BLOCK_SIZE 16
21
22 #define NGX_QUIC_TOKEN_BUF_SIZE (NGX_QUIC_AES_256_CBC_IV_LEN \
23 + NGX_QUIC_MAX_TOKEN_SIZE \
24 + NGX_QUIC_AES_256_CBC_BLOCK_SIZE)
25
26
15 ngx_int_t ngx_quic_new_sr_token(ngx_connection_t *c, ngx_str_t *cid, 27 ngx_int_t ngx_quic_new_sr_token(ngx_connection_t *c, ngx_str_t *cid,
16 u_char *secret, u_char *token); 28 u_char *secret, u_char *token);
17 ngx_int_t ngx_quic_new_token(ngx_connection_t *c, struct sockaddr *sockaddr, 29 ngx_int_t ngx_quic_new_token(ngx_log_t *log, struct sockaddr *sockaddr,
18 socklen_t socklen, u_char *key, ngx_str_t *token, ngx_str_t *odcid, 30 socklen_t socklen, u_char *key, ngx_str_t *token, ngx_str_t *odcid,
19 time_t expires, ngx_uint_t is_retry); 31 time_t expires, ngx_uint_t is_retry);
20 ngx_int_t ngx_quic_validate_token(ngx_connection_t *c, 32 ngx_int_t ngx_quic_validate_token(ngx_connection_t *c,
21 u_char *key, ngx_quic_header_t *pkt); 33 u_char *key, ngx_quic_header_t *pkt);
22 34