Mercurial > hg > nginx-quic
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_ */ |