blob: f12335a7444db503b93b5be4389453a9b94ac70d (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
/*
* Copyright (C) Igor Sysoev
* Copyright (C) NGINX, Inc.
*/
#ifndef _NXT_SSLTLS_H_INCLUDED_
#define _NXT_SSLTLS_H_INCLUDED_
/*
* The SSL/TLS libraries lack vector I/O interface yet add noticeable
* overhead to each SSL/TLS record so buffering allows to decrease the
* overhead. The typical overhead size is about 30 bytes, however, TLS
* supports also random padding up to 255 bytes. The maximum SSLv3/TLS
* record size is 16K. However, large records increase decryption latency.
* 4K is good compromise between 1-6% of SSL/TLS overhead and the latency.
* 4K buffer allows to send one SSL/TLS record (4096-bytes data and up to
* 224-bytes overhead) in three 1440-bytes TCP/IPv4 packets with timestamps
* and compatible with tunnels.
*/
#define NXT_SSLTLS_BUFFER_SIZE 4096
typedef struct nxt_ssltls_conf_s nxt_ssltls_conf_t;
typedef struct {
nxt_int_t (*server_init)(nxt_ssltls_conf_t *conf);
nxt_int_t (*set_versions)(nxt_ssltls_conf_t *conf);
} nxt_ssltls_lib_t;
struct nxt_ssltls_conf_s {
void *ctx;
void (*conn_init)(nxt_task_t *task,
nxt_ssltls_conf_t *conf, nxt_conn_t *c);
const nxt_ssltls_lib_t *lib;
char *certificate;
char *certificate_key;
char *ciphers;
char *ca_certificate;
size_t buffer_size;
};
#if (NXT_HAVE_OPENSSL)
extern const nxt_ssltls_lib_t nxt_openssl_lib;
#endif
#if (NXT_HAVE_GNUTLS)
extern const nxt_ssltls_lib_t nxt_gnutls_lib;
#endif
#if (NXT_HAVE_CYASSL)
extern const nxt_ssltls_lib_t nxt_cyassl_lib;
#endif
#if (NXT_HAVE_POLARSSL)
extern const nxt_ssltls_lib_t nxt_polar_lib;
#endif
#endif /* _NXT_SSLTLS_H_INCLUDED_ */
|