comparison src/event/ngx_event_quic.h @ 7643:76e29ff31cd3 quic

AEAD routines, introduced ngx_quic_tls_open()/ngx_quic_tls_seal().
author Sergey Kandaurov <pluknet@nginx.com>
date Fri, 28 Feb 2020 13:09:52 +0300
parents 72f632f90a17
children a9ff4392ecde
comparison
equal deleted inserted replaced
7642:8964cc6ecc4a 7643:76e29ff31cd3
7 #ifndef _NGX_EVENT_QUIC_H_INCLUDED_ 7 #ifndef _NGX_EVENT_QUIC_H_INCLUDED_
8 #define _NGX_EVENT_QUIC_H_INCLUDED_ 8 #define _NGX_EVENT_QUIC_H_INCLUDED_
9 9
10 10
11 #include <ngx_event_openssl.h> 11 #include <ngx_event_openssl.h>
12
13
14 #ifdef OPENSSL_IS_BORINGSSL
15 #define ngx_aead_cipher_t EVP_AEAD
16 #define NGX_QUIC_INITIAL_CIPHER EVP_aead_aes_128_gcm()
17 #else
18 #define ngx_aead_cipher_t EVP_CIPHER
19 #define NGX_QUIC_INITIAL_CIPHER EVP_aes_128_gcm()
20 #endif
12 21
13 22
14 typedef struct { 23 typedef struct {
15 ngx_str_t secret; 24 ngx_str_t secret;
16 ngx_str_t key; 25 ngx_str_t key;
42 const u_char *salt, size_t salt_len); 51 const u_char *salt, size_t salt_len);
43 ngx_int_t ngx_hkdf_expand(u_char *out_key, size_t out_len, 52 ngx_int_t ngx_hkdf_expand(u_char *out_key, size_t out_len,
44 const EVP_MD *digest, const u_char *prk, size_t prk_len, 53 const EVP_MD *digest, const u_char *prk, size_t prk_len,
45 const u_char *info, size_t info_len); 54 const u_char *info, size_t info_len);
46 55
56 ngx_int_t ngx_quic_tls_open(ngx_connection_t *c,
57 const ngx_aead_cipher_t *cipher, ngx_quic_secret_t *s, ngx_str_t *out,
58 u_char *nonce, ngx_str_t *in, ngx_str_t *ad);
59 ngx_int_t ngx_quic_tls_seal(ngx_connection_t *c,
60 const ngx_aead_cipher_t *cipher, ngx_quic_secret_t *s, ngx_str_t *out,
61 u_char *nonce, ngx_str_t *in, ngx_str_t *ad);
62
47 63
48 #endif /* _NGX_EVENT_QUIC_H_INCLUDED_ */ 64 #endif /* _NGX_EVENT_QUIC_H_INCLUDED_ */