src/event/ngx_event_openssl.h - nginx

Data types defined

Macros defined

Source code


  1. /*
  2. * Copyright (C) Igor Sysoev
  3. * Copyright (C) Nginx, Inc.
  4. */


  5. #ifndef _NGX_EVENT_OPENSSL_H_INCLUDED_
  6. #define _NGX_EVENT_OPENSSL_H_INCLUDED_


  7. #include <ngx_config.h>
  8. #include <ngx_core.h>

  9. #define OPENSSL_SUPPRESS_DEPRECATED

  10. #include <openssl/ssl.h>
  11. #include <openssl/err.h>
  12. #include <openssl/bn.h>
  13. #include <openssl/conf.h>
  14. #include <openssl/crypto.h>
  15. #ifndef OPENSSL_NO_DH
  16. #include <openssl/dh.h>
  17. #endif
  18. #ifndef OPENSSL_NO_ENGINE
  19. #include <openssl/engine.h>
  20. #endif
  21. #include <openssl/evp.h>
  22. #include <openssl/hmac.h>
  23. #ifndef OPENSSL_NO_OCSP
  24. #include <openssl/ocsp.h>
  25. #endif
  26. #include <openssl/rand.h>
  27. #include <openssl/x509.h>
  28. #include <openssl/x509v3.h>

  29. #define NGX_SSL_NAME     "OpenSSL"


  30. #if (defined LIBRESSL_VERSION_NUMBER && OPENSSL_VERSION_NUMBER == 0x20000000L)
  31. #undef OPENSSL_VERSION_NUMBER
  32. #if (LIBRESSL_VERSION_NUMBER >= 0x3050000fL)
  33. #define OPENSSL_VERSION_NUMBER  0x1010000fL
  34. #else
  35. #define OPENSSL_VERSION_NUMBER  0x1000107fL
  36. #endif
  37. #endif


  38. #if (OPENSSL_VERSION_NUMBER >= 0x10100001L)

  39. #define ngx_ssl_version()       OpenSSL_version(OPENSSL_VERSION)

  40. #else

  41. #define ngx_ssl_version()       SSLeay_version(SSLEAY_VERSION)

  42. #endif


  43. #define ngx_ssl_session_t       SSL_SESSION
  44. #define ngx_ssl_conn_t          SSL


  45. #if (OPENSSL_VERSION_NUMBER < 0x10002000L)
  46. #define SSL_is_server(s)        (s)->server
  47. #endif


  48. #if (OPENSSL_VERSION_NUMBER < 0x1010000fL)
  49. #define ASN1_STRING_get0_data(x)     (x)->data
  50. #endif


  51. #if (OPENSSL_VERSION_NUMBER >= 0x30000000L && !defined SSL_get_peer_certificate)
  52. #define SSL_get_peer_certificate(s)  SSL_get1_peer_certificate(s)
  53. #endif


  54. #if (OPENSSL_VERSION_NUMBER < 0x30000000L && !defined ERR_peek_error_data)
  55. #define ERR_peek_error_data(d, f)    ERR_peek_error_line_data(NULL, NULL, d, f)
  56. #endif


  57. #ifdef OPENSSL_NO_DEPRECATED_3_4
  58. #define SSL_SESSION_get_time(s)      SSL_SESSION_get_time_ex(s)
  59. #define SSL_SESSION_set_time(s, t)   SSL_SESSION_set_time_ex(s, t)
  60. #endif


  61. #ifdef OPENSSL_NO_DEPRECATED_3_0
  62. #define EVP_CIPHER_CTX_cipher(c)     EVP_CIPHER_CTX_get0_cipher(c)
  63. #endif


  64. #if (OPENSSL_VERSION_NUMBER < 0x30000000L)
  65. #define SSL_group_to_name(s, nid)    NULL
  66. #endif


  67. typedef struct ngx_ssl_ocsp_s   ngx_ssl_ocsp_t;


  68. struct ngx_ssl_s {
  69.     SSL_CTX                    *ctx;
  70.     ngx_log_t                  *log;
  71.     size_t                      buffer_size;

  72.     ngx_array_t                 certs;

  73.     ngx_rbtree_t                staple_rbtree;
  74.     ngx_rbtree_node_t           staple_sentinel;
  75. };


  76. struct ngx_ssl_connection_s {
  77.     ngx_ssl_conn_t             *connection;
  78.     SSL_CTX                    *session_ctx;

  79.     ngx_int_t                   last;
  80.     ngx_buf_t                  *buf;
  81.     size_t                      buffer_size;

  82.     ngx_connection_handler_pt   handler;

  83.     ngx_ssl_session_t          *session;
  84.     ngx_connection_handler_pt   save_session;

  85.     ngx_event_handler_pt        saved_read_handler;
  86.     ngx_event_handler_pt        saved_write_handler;

  87.     ngx_ssl_ocsp_t             *ocsp;

  88.     u_char                      early_buf;

  89.     unsigned                    handshaked:1;
  90.     unsigned                    handshake_rejected:1;
  91.     unsigned                    renegotiation:1;
  92.     unsigned                    buffer:1;
  93.     unsigned                    sendfile:1;
  94.     unsigned                    no_wait_shutdown:1;
  95.     unsigned                    no_send_shutdown:1;
  96.     unsigned                    shutdown_without_free:1;
  97.     unsigned                    handshake_buffer_set:1;
  98.     unsigned                    session_timeout_set:1;
  99.     unsigned                    try_early_data:1;
  100.     unsigned                    in_early:1;
  101.     unsigned                    in_ocsp:1;
  102.     unsigned                    early_preread:1;
  103.     unsigned                    write_blocked:1;
  104.     unsigned                    sni_accepted:1;
  105. };


  106. #define NGX_SSL_NO_SCACHE            -2
  107. #define NGX_SSL_NONE_SCACHE          -3
  108. #define NGX_SSL_NO_BUILTIN_SCACHE    -4
  109. #define NGX_SSL_DFLT_BUILTIN_SCACHE  -5


  110. #define NGX_SSL_MAX_SESSION_SIZE  8192

  111. typedef struct ngx_ssl_sess_id_s  ngx_ssl_sess_id_t;

  112. struct ngx_ssl_sess_id_s {
  113.     ngx_rbtree_node_t           node;
  114.     size_t                      len;
  115.     ngx_queue_t                 queue;
  116.     time_t                      expire;
  117.     u_char                      id[32];
  118. #if (NGX_PTR_SIZE == 8)
  119.     u_char                     *session;
  120. #else
  121.     u_char                      session[1];
  122. #endif
  123. };


  124. typedef struct {
  125.     u_char                      name[16];
  126.     u_char                      hmac_key[32];
  127.     u_char                      aes_key[32];
  128.     time_t                      expire;
  129.     unsigned                    size:8;
  130.     unsigned                    shared:1;
  131. } ngx_ssl_ticket_key_t;


  132. typedef struct {
  133.     ngx_rbtree_t                session_rbtree;
  134.     ngx_rbtree_node_t           sentinel;
  135.     ngx_queue_t                 expire_queue;
  136.     ngx_ssl_ticket_key_t        ticket_keys[3];
  137.     time_t                      fail_time;
  138. } ngx_ssl_session_cache_t;


  139. typedef int (*ngx_ssl_servername_pt)(ngx_ssl_conn_t *, int *, void *);

  140. typedef struct {
  141.     ngx_ssl_servername_pt       servername;
  142. } ngx_ssl_client_hello_arg;


  143. #define NGX_SSL_SSLv2    0x0002
  144. #define NGX_SSL_SSLv3    0x0004
  145. #define NGX_SSL_TLSv1    0x0008
  146. #define NGX_SSL_TLSv1_1  0x0010
  147. #define NGX_SSL_TLSv1_2  0x0020
  148. #define NGX_SSL_TLSv1_3  0x0040


  149. #if (defined SSL_OP_NO_TLSv1_2 || defined SSL_OP_NO_TLSv1_3)
  150. #define NGX_SSL_DEFAULT_PROTOCOLS  (NGX_SSL_TLSv1_2|NGX_SSL_TLSv1_3)
  151. #else
  152. #define NGX_SSL_DEFAULT_PROTOCOLS  (NGX_SSL_TLSv1|NGX_SSL_TLSv1_1)
  153. #endif


  154. #define NGX_SSL_BUFFER   1
  155. #define NGX_SSL_CLIENT   2

  156. #define NGX_SSL_BUFSIZE  16384


  157. #define NGX_SSL_CACHE_CERT  0
  158. #define NGX_SSL_CACHE_PKEY  1
  159. #define NGX_SSL_CACHE_CRL   2
  160. #define NGX_SSL_CACHE_CA    3

  161. #define NGX_SSL_CACHE_INVALIDATE  0x80000000


  162. ngx_int_t ngx_ssl_init(ngx_log_t *log);
  163. ngx_int_t ngx_ssl_create(ngx_ssl_t *ssl, ngx_uint_t protocols, void *data);

  164. ngx_int_t ngx_ssl_certificates(ngx_conf_t *cf, ngx_ssl_t *ssl,
  165.     ngx_array_t *certs, ngx_array_t *keys, ngx_array_t *passwords);
  166. ngx_int_t ngx_ssl_certificate(ngx_conf_t *cf, ngx_ssl_t *ssl,
  167.     ngx_str_t *cert, ngx_str_t *key, ngx_array_t *passwords);
  168. ngx_int_t ngx_ssl_connection_certificate(ngx_connection_t *c, ngx_pool_t *pool,
  169.     ngx_str_t *cert, ngx_str_t *key, ngx_ssl_cache_t *cache,
  170.     ngx_array_t *passwords);
  171. ngx_int_t ngx_ssl_certificate_compression(ngx_conf_t *cf, ngx_ssl_t *ssl,
  172.     ngx_uint_t enable);

  173. ngx_int_t ngx_ssl_ciphers(ngx_conf_t *cf, ngx_ssl_t *ssl, ngx_str_t *ciphers,
  174.     ngx_uint_t prefer_server_ciphers);
  175. ngx_int_t ngx_ssl_client_certificate(ngx_conf_t *cf, ngx_ssl_t *ssl,
  176.     ngx_str_t *cert, ngx_int_t depth);
  177. ngx_int_t ngx_ssl_trusted_certificate(ngx_conf_t *cf, ngx_ssl_t *ssl,
  178.     ngx_str_t *cert, ngx_int_t depth);
  179. ngx_int_t ngx_ssl_crl(ngx_conf_t *cf, ngx_ssl_t *ssl, ngx_str_t *crl);
  180. ngx_int_t ngx_ssl_stapling(ngx_conf_t *cf, ngx_ssl_t *ssl,
  181.     ngx_str_t *file, ngx_str_t *responder, ngx_uint_t verify);
  182. ngx_int_t ngx_ssl_stapling_resolver(ngx_conf_t *cf, ngx_ssl_t *ssl,
  183.     ngx_resolver_t *resolver, ngx_msec_t resolver_timeout);
  184. ngx_int_t ngx_ssl_ocsp(ngx_conf_t *cf, ngx_ssl_t *ssl, ngx_str_t *responder,
  185.     ngx_uint_t depth, ngx_shm_zone_t *shm_zone);
  186. ngx_int_t ngx_ssl_ocsp_resolver(ngx_conf_t *cf, ngx_ssl_t *ssl,
  187.     ngx_resolver_t *resolver, ngx_msec_t resolver_timeout);

  188. ngx_int_t ngx_ssl_ocsp_validate(ngx_connection_t *c);
  189. ngx_int_t ngx_ssl_ocsp_get_status(ngx_connection_t *c, const char **s);
  190. void ngx_ssl_ocsp_cleanup(ngx_connection_t *c);
  191. ngx_int_t ngx_ssl_ocsp_cache_init(ngx_shm_zone_t *shm_zone, void *data);

  192. ngx_ssl_cache_t *ngx_ssl_cache_init(ngx_pool_t *pool, ngx_uint_t max,
  193.     time_t valid, time_t inactive);
  194. void *ngx_ssl_cache_fetch(ngx_conf_t *cf, ngx_uint_t index, char **err,
  195.     ngx_str_t *path, void *data);
  196. void *ngx_ssl_cache_connection_fetch(ngx_ssl_cache_t *cache, ngx_pool_t *pool,
  197.     ngx_uint_t index, char **err, ngx_str_t *path, void *data);

  198. ngx_array_t *ngx_ssl_read_password_file(ngx_conf_t *cf, ngx_str_t *file);
  199. ngx_array_t *ngx_ssl_preserve_passwords(ngx_conf_t *cf,
  200.     ngx_array_t *passwords);
  201. ngx_int_t ngx_ssl_dhparam(ngx_conf_t *cf, ngx_ssl_t *ssl, ngx_str_t *file);
  202. ngx_int_t ngx_ssl_ech_files(ngx_conf_t *cf, ngx_ssl_t *ssl,
  203.     ngx_array_t *filename);
  204. ngx_int_t ngx_ssl_ecdh_curve(ngx_conf_t *cf, ngx_ssl_t *ssl, ngx_str_t *name);
  205. ngx_int_t ngx_ssl_early_data(ngx_conf_t *cf, ngx_ssl_t *ssl,
  206.     ngx_uint_t enable);
  207. ngx_int_t ngx_ssl_conf_commands(ngx_conf_t *cf, ngx_ssl_t *ssl,
  208.     ngx_array_t *commands);

  209. ngx_int_t ngx_ssl_client_session_cache(ngx_conf_t *cf, ngx_ssl_t *ssl,
  210.     ngx_uint_t enable);
  211. ngx_int_t ngx_ssl_session_cache(ngx_ssl_t *ssl, ngx_str_t *sess_ctx,
  212.     ngx_array_t *certificates, ssize_t builtin_session_cache,
  213.     ngx_shm_zone_t *shm_zone, time_t timeout);
  214. ngx_int_t ngx_ssl_session_ticket_keys(ngx_conf_t *cf, ngx_ssl_t *ssl,
  215.     ngx_array_t *paths);
  216. ngx_int_t ngx_ssl_session_cache_init(ngx_shm_zone_t *shm_zone, void *data);

  217. ngx_int_t ngx_ssl_set_client_hello_callback(ngx_ssl_t *ssl,
  218.     ngx_ssl_client_hello_arg *cb);
  219. #ifdef SSL_CLIENT_HELLO_SUCCESS
  220. int ngx_ssl_client_hello_callback(ngx_ssl_conn_t *ssl_conn, int *ad, void *arg);
  221. #elif defined OPENSSL_IS_BORINGSSL
  222. enum ssl_select_cert_result_t ngx_ssl_select_certificate(
  223.     const SSL_CLIENT_HELLO *client_hello);
  224. #endif

  225. ngx_int_t ngx_ssl_create_connection(ngx_ssl_t *ssl, ngx_connection_t *c,
  226.     ngx_uint_t flags);

  227. void ngx_ssl_remove_cached_session(SSL_CTX *ssl, ngx_ssl_session_t *sess);
  228. ngx_int_t ngx_ssl_set_session(ngx_connection_t *c, ngx_ssl_session_t *session);
  229. ngx_ssl_session_t *ngx_ssl_get_session(ngx_connection_t *c);
  230. ngx_ssl_session_t *ngx_ssl_get0_session(ngx_connection_t *c);
  231. #define ngx_ssl_free_session        SSL_SESSION_free
  232. #define ngx_ssl_get_connection(ssl_conn)                                      \
  233.     SSL_get_ex_data(ssl_conn, ngx_ssl_connection_index)
  234. #define ngx_ssl_get_server_conf(ssl_ctx)                                      \
  235.     SSL_CTX_get_ex_data(ssl_ctx, ngx_ssl_server_conf_index)

  236. #define ngx_ssl_verify_error_optional(n)                                      \
  237.     (n == X509_V_ERR_DEPTH_ZERO_SELF_SIGNED_CERT                              \
  238.      || n == X509_V_ERR_SELF_SIGNED_CERT_IN_CHAIN                             \
  239.      || n == X509_V_ERR_UNABLE_TO_GET_ISSUER_CERT_LOCALLY                     \
  240.      || n == X509_V_ERR_CERT_UNTRUSTED                                        \
  241.      || n == X509_V_ERR_UNABLE_TO_VERIFY_LEAF_SIGNATURE)

  242. ngx_int_t ngx_ssl_check_host(ngx_connection_t *c, ngx_str_t *name);


  243. ngx_int_t ngx_ssl_get_protocol(ngx_connection_t *c, ngx_pool_t *pool,
  244.     ngx_str_t *s);
  245. ngx_int_t ngx_ssl_get_cipher_name(ngx_connection_t *c, ngx_pool_t *pool,
  246.     ngx_str_t *s);
  247. ngx_int_t ngx_ssl_get_ciphers(ngx_connection_t *c, ngx_pool_t *pool,
  248.     ngx_str_t *s);
  249. ngx_int_t ngx_ssl_get_curve(ngx_connection_t *c, ngx_pool_t *pool,
  250.     ngx_str_t *s);
  251. ngx_int_t ngx_ssl_get_curves(ngx_connection_t *c, ngx_pool_t *pool,
  252.     ngx_str_t *s);
  253. ngx_int_t ngx_ssl_get_sigalg(ngx_connection_t *c, ngx_pool_t *pool,
  254.     ngx_str_t *s);
  255. ngx_int_t ngx_ssl_get_session_id(ngx_connection_t *c, ngx_pool_t *pool,
  256.     ngx_str_t *s);
  257. ngx_int_t ngx_ssl_get_session_reused(ngx_connection_t *c, ngx_pool_t *pool,
  258.     ngx_str_t *s);
  259. ngx_int_t ngx_ssl_get_early_data(ngx_connection_t *c, ngx_pool_t *pool,
  260.     ngx_str_t *s);
  261. ngx_int_t ngx_ssl_get_server_name(ngx_connection_t *c, ngx_pool_t *pool,
  262.     ngx_str_t *s);
  263. ngx_int_t ngx_ssl_get_ech_status(ngx_connection_t *c, ngx_pool_t *pool,
  264.     ngx_str_t *s);
  265. ngx_int_t ngx_ssl_get_ech_outer_server_name(ngx_connection_t *c,
  266.     ngx_pool_t *pool, ngx_str_t *s);
  267. ngx_int_t ngx_ssl_get_alpn_protocol(ngx_connection_t *c, ngx_pool_t *pool,
  268.     ngx_str_t *s);
  269. ngx_int_t ngx_ssl_get_raw_certificate(ngx_connection_t *c, ngx_pool_t *pool,
  270.     ngx_str_t *s);
  271. ngx_int_t ngx_ssl_get_certificate(ngx_connection_t *c, ngx_pool_t *pool,
  272.     ngx_str_t *s);
  273. ngx_int_t ngx_ssl_get_escaped_certificate(ngx_connection_t *c, ngx_pool_t *pool,
  274.     ngx_str_t *s);
  275. ngx_int_t ngx_ssl_get_subject_dn(ngx_connection_t *c, ngx_pool_t *pool,
  276.     ngx_str_t *s);
  277. ngx_int_t ngx_ssl_get_issuer_dn(ngx_connection_t *c, ngx_pool_t *pool,
  278.     ngx_str_t *s);
  279. ngx_int_t ngx_ssl_get_subject_dn_legacy(ngx_connection_t *c, ngx_pool_t *pool,
  280.     ngx_str_t *s);
  281. ngx_int_t ngx_ssl_get_issuer_dn_legacy(ngx_connection_t *c, ngx_pool_t *pool,
  282.     ngx_str_t *s);
  283. ngx_int_t ngx_ssl_get_serial_number(ngx_connection_t *c, ngx_pool_t *pool,
  284.     ngx_str_t *s);
  285. ngx_int_t ngx_ssl_get_fingerprint(ngx_connection_t *c, ngx_pool_t *pool,
  286.     ngx_str_t *s);
  287. ngx_int_t ngx_ssl_get_client_verify(ngx_connection_t *c, ngx_pool_t *pool,
  288.     ngx_str_t *s);
  289. ngx_int_t ngx_ssl_get_client_v_start(ngx_connection_t *c, ngx_pool_t *pool,
  290.     ngx_str_t *s);
  291. ngx_int_t ngx_ssl_get_client_v_end(ngx_connection_t *c, ngx_pool_t *pool,
  292.     ngx_str_t *s);
  293. ngx_int_t ngx_ssl_get_client_v_remain(ngx_connection_t *c, ngx_pool_t *pool,
  294.     ngx_str_t *s);
  295. ngx_int_t ngx_ssl_get_client_sigalg(ngx_connection_t *c, ngx_pool_t *pool,
  296.     ngx_str_t *s);


  297. ngx_int_t ngx_ssl_handshake(ngx_connection_t *c);
  298. #if (NGX_DEBUG)
  299. void ngx_ssl_handshake_log(ngx_connection_t *c);
  300. #endif
  301. ssize_t ngx_ssl_recv(ngx_connection_t *c, u_char *buf, size_t size);
  302. ssize_t ngx_ssl_write(ngx_connection_t *c, u_char *data, size_t size);
  303. ssize_t ngx_ssl_recv_chain(ngx_connection_t *c, ngx_chain_t *cl, off_t limit);
  304. ngx_chain_t *ngx_ssl_send_chain(ngx_connection_t *c, ngx_chain_t *in,
  305.     off_t limit);
  306. void ngx_ssl_free_buffer(ngx_connection_t *c);
  307. ngx_int_t ngx_ssl_shutdown(ngx_connection_t *c);
  308. void ngx_ssl_connection_error(ngx_connection_t *c, int sslerr, ngx_err_t err,
  309.     char *text);
  310. void ngx_cdecl ngx_ssl_error(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
  311.     char *fmt, ...);
  312. void ngx_ssl_cleanup_ctx(void *data);


  313. extern int  ngx_ssl_connection_index;
  314. extern int  ngx_ssl_server_conf_index;
  315. extern int  ngx_ssl_session_cache_index;
  316. extern int  ngx_ssl_ticket_keys_index;
  317. extern int  ngx_ssl_ocsp_index;
  318. extern int  ngx_ssl_index;
  319. extern int  ngx_ssl_certificate_name_index;
  320. extern int  ngx_ssl_certificate_comp_index;
  321. extern int  ngx_ssl_client_hello_arg_index;


  322. extern u_char  ngx_ssl_session_buffer[NGX_SSL_MAX_SESSION_SIZE];


  323. #endif /* _NGX_EVENT_OPENSSL_H_INCLUDED_ */