blob: 09bf6cacd95552bfae7a0f0d74ae4cd09a143233 [file] [log] [blame]
yuezonghe824eb0c2024-06-27 02:32:26 -07001/* ssl.h
2 *
3 * Copyright (C) 2006-2021 wolfSSL Inc.
4 *
5 * This file is part of wolfSSL.
6 *
7 * wolfSSL is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
11 *
12 * wolfSSL is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1335, USA
20 */
21
22
23
24/* ssl.h defines wolfssl_openssl compatibility layer
25 *
26 */
27
28
29#ifndef WOLFSSL_OPENSSL_H_
30#define WOLFSSL_OPENSSL_H_
31
32/* wolfssl_openssl compatibility layer */
33#ifndef OPENSSL_EXTRA_SSL_GUARD
34#define OPENSSL_EXTRA_SSL_GUARD
35#include <wolfssl/ssl.h>
36#endif /* OPENSSL_EXTRA_SSL_GUARD */
37
38#include <wolfssl/openssl/tls1.h>
39#include <wolfssl/openssl/evp.h>
40#include <wolfssl/openssl/bio.h>
41#ifdef OPENSSL_EXTRA
42#include <wolfssl/openssl/crypto.h>
43#endif
44
45#if defined(WOLFSSL_QT) || defined(OPENSSL_ALL)
46#include <wolfssl/openssl/dh.h>
47#include <wolfssl/openssl/objects.h>
48#endif
49
50/* need MIN_CODE_E to determine wolfSSL error range */
51#include <wolfssl/wolfcrypt/error-crypt.h>
52
53/* all NID_* values are in asn.h */
54#include <wolfssl/wolfcrypt/asn.h>
55
56#include <wolfssl/openssl/x509.h>
57
58#ifdef __cplusplus
59 extern "C" {
60#endif
61
62#ifdef _WIN32
63 /* wincrypt.h clashes */
64 #undef X509_NAME
65#endif
66
67#ifdef WOLFSSL_UTASKER
68 /* tcpip.h clashes */
69 #undef ASN1_INTEGER
70#endif
71
72#ifdef OPENSSL_EXTRA
73WOLFSSL_API int wolfSSL_OPENSSL_init_ssl(word64 opts, const OPENSSL_INIT_SETTINGS *settings);
74#endif
75
76typedef WOLFSSL SSL;
77typedef WOLFSSL_SESSION SSL_SESSION;
78typedef WOLFSSL_METHOD SSL_METHOD;
79typedef WOLFSSL_CTX SSL_CTX;
80
81typedef WOLFSSL_X509 X509;
82typedef WOLFSSL_X509 X509_REQ;
83typedef WOLFSSL_X509_NAME X509_NAME;
84typedef WOLFSSL_X509_INFO X509_INFO;
85typedef WOLFSSL_X509_CHAIN X509_CHAIN;
86
87/* STACK_OF(ASN1_OBJECT) */
88typedef WOLFSSL_STACK EXTENDED_KEY_USAGE;
89
90
91/* redeclare guard */
92#define WOLFSSL_TYPES_DEFINED
93
94typedef WOLFSSL_BIO BIO;
95typedef WOLFSSL_BIO_METHOD BIO_METHOD;
96typedef WOLFSSL_CIPHER SSL_CIPHER;
97typedef WOLFSSL_X509_LOOKUP X509_LOOKUP;
98typedef WOLFSSL_X509_LOOKUP_METHOD X509_LOOKUP_METHOD;
99typedef WOLFSSL_X509_CRL X509_CRL;
100typedef WOLFSSL_X509_EXTENSION X509_EXTENSION;
101typedef WOLFSSL_X509_PUBKEY X509_PUBKEY;
102typedef WOLFSSL_X509_ALGOR X509_ALGOR;
103typedef WOLFSSL_ASN1_TIME ASN1_TIME;
104typedef WOLFSSL_ASN1_INTEGER ASN1_INTEGER;
105typedef WOLFSSL_ASN1_OBJECT ASN1_OBJECT;
106typedef WOLFSSL_ASN1_STRING ASN1_STRING;
107typedef WOLFSSL_ASN1_TYPE ASN1_TYPE;
108typedef WOLFSSL_X509_ATTRIBUTE X509_ATTRIBUTE;
109typedef WOLFSSL_ASN1_BIT_STRING ASN1_BIT_STRING;
110typedef WOLFSSL_dynlock_value CRYPTO_dynlock_value;
111typedef WOLFSSL_BUF_MEM BUF_MEM;
112typedef WOLFSSL_GENERAL_NAMES GENERAL_NAMES;
113typedef WOLFSSL_GENERAL_NAME GENERAL_NAME;
114
115#define X509_L_FILE_LOAD WOLFSSL_X509_L_FILE_LOAD
116#define X509_L_ADD_DIR WOLFSSL_X509_L_ADD_DIR
117#define X509_L_ADD_STORE WOLFSSL_X509_L_ADD_STORE
118#define X509_L_LOAD_STORE WOLFSSL_X509_L_LOAD_STORE
119
120#define ASN1_UTCTIME WOLFSSL_ASN1_TIME
121#define ASN1_GENERALIZEDTIME WOLFSSL_ASN1_TIME
122
123typedef WOLFSSL_COMP_METHOD COMP_METHOD;
124typedef WOLFSSL_COMP SSL_COMP;
125typedef WOLFSSL_X509_REVOKED X509_REVOKED;
126typedef WOLFSSL_X509_OBJECT X509_OBJECT;
127typedef WOLFSSL_X509_STORE X509_STORE;
128typedef WOLFSSL_X509_STORE_CTX X509_STORE_CTX;
129typedef WOLFSSL_X509_VERIFY_PARAM X509_VERIFY_PARAM;
130
131#define EVP_CIPHER_INFO EncryptedInfo
132
133#define STACK_OF(x) WOLFSSL_STACK
134#define OPENSSL_STACK WOLFSSL_STACK
135#define _STACK OPENSSL_STACK
136
137#define CONF_get1_default_config_file wolfSSL_CONF_get1_default_config_file
138typedef STACK_OF(ACCESS_DESCRIPTION) AUTHORITY_INFO_ACCESS;
139
140#define CRYPTO_free wolfSSL_CRYPTO_free
141#define CRYPTO_malloc wolfSSL_CRYPTO_malloc
142#define CRYPTO_EX_new WOLFSSL_CRYPTO_EX_new
143#define CRYPTO_EX_dup WOLFSSL_CRYPTO_EX_dup
144#define CRYPTO_EX_free WOLFSSL_CRYPTO_EX_free
145#define CRYPTO_EX_DATA WOLFSSL_CRYPTO_EX_DATA
146
147/* depreciated */
148#define CRYPTO_thread_id wolfSSL_thread_id
149#define CRYPTO_set_id_callback wolfSSL_set_id_callback
150
151#define CRYPTO_LOCK 0x01
152#define CRYPTO_UNLOCK 0x02
153#define CRYPTO_READ 0x04
154#define CRYPTO_WRITE 0x08
155
156#define CRYPTO_set_locking_callback wolfSSL_set_locking_callback
157#define CRYPTO_set_dynlock_create_callback wolfSSL_set_dynlock_create_callback
158#define CRYPTO_set_dynlock_lock_callback wolfSSL_set_dynlock_lock_callback
159#define CRYPTO_set_dynlock_destroy_callback wolfSSL_set_dynlock_destroy_callback
160#define CRYPTO_num_locks wolfSSL_num_locks
161#define CRYPTO_dynlock_value WOLFSSL_dynlock_value
162
163#define CRYPTO_cleanup_all_ex_data wolfSSL_cleanup_all_ex_data
164#define set_ex_data wolfSSL_CRYPTO_set_ex_data
165#define get_ex_data wolfSSL_CRYPTO_get_ex_data
166#define CRYPTO_memcmp wolfSSL_CRYPTO_memcmp
167#define CRYPTO_get_ex_new_index wolfSSL_CRYPTO_get_ex_new_index
168
169#define CRYPTO_get_ex_new_index wolfSSL_CRYPTO_get_ex_new_index
170
171/* this function was used to set the default malloc, free, and realloc */
172#define CRYPTO_malloc_init() 0 /* CRYPTO_malloc_init is not needed */
173#define OPENSSL_malloc_init() 0 /* OPENSSL_malloc_init is not needed */
174
175#define SSL_get_client_random(ssl,out,outSz) \
176 wolfSSL_get_client_random((ssl),(out),(outSz))
177#define SSL_get_cipher_list(ctx,i) wolfSSL_get_cipher_list_ex((ctx),(i))
178#define SSL_get_cipher_name(ctx) wolfSSL_get_cipher((ctx))
179#define SSL_get_shared_ciphers(ctx,buf,len) \
180 wolfSSL_get_shared_ciphers((ctx),(buf),(len))
181
182/* at the moment only returns ok */
183#define SSL_get_verify_result wolfSSL_get_verify_result
184#define SSL_get_verify_mode wolfSSL_get_verify_mode
185#define SSL_get_verify_depth wolfSSL_get_verify_depth
186#define SSL_CTX_get_verify_mode wolfSSL_CTX_get_verify_mode
187#define SSL_CTX_get_verify_depth wolfSSL_CTX_get_verify_depth
188#define SSL_get_certificate wolfSSL_get_certificate
189#define SSL_CTX_get0_certificate wolfSSL_CTX_get0_certificate
190#define SSL_use_certificate wolfSSL_use_certificate
191#define SSL_use_certificate_ASN1 wolfSSL_use_certificate_ASN1
192#define d2i_PKCS8_PRIV_KEY_INFO_bio wolfSSL_d2i_PKCS8_PKEY_bio
193#define d2i_PKCS8PrivateKey_bio wolfSSL_d2i_PKCS8PrivateKey_bio
194#define i2d_PKCS8PrivateKey_bio wolfSSL_PEM_write_bio_PKCS8PrivateKey
195#define PKCS8_PRIV_KEY_INFO_free wolfSSL_EVP_PKEY_free
196#define d2i_PKCS12_fp wolfSSL_d2i_PKCS12_fp
197#define SSL_CTX_set_ecdh_auto wolfSSL_CTX_set_ecdh_auto
198
199#define i2d_PUBKEY wolfSSL_i2d_PUBKEY
200#define d2i_PUBKEY wolfSSL_d2i_PUBKEY
201#define d2i_PUBKEY_bio wolfSSL_d2i_PUBKEY_bio
202#define d2i_PrivateKey wolfSSL_d2i_PrivateKey
203#define d2i_AutoPrivateKey wolfSSL_d2i_AutoPrivateKey
204#define SSL_use_PrivateKey wolfSSL_use_PrivateKey
205#define SSL_use_PrivateKey_ASN1 wolfSSL_use_PrivateKey_ASN1
206#define SSL_use_RSAPrivateKey_ASN1 wolfSSL_use_RSAPrivateKey_ASN1
207#define SSL_get_privatekey wolfSSL_get_privatekey
208#define SSL_CTX_use_PrivateKey_ASN1 wolfSSL_CTX_use_PrivateKey_ASN1
209
210#define SSLv23_method wolfSSLv23_method
211#define SSLv23_client_method wolfSSLv23_client_method
212#define SSLv2_client_method wolfSSLv2_client_method
213#define SSLv2_server_method wolfSSLv2_server_method
214#define SSLv3_server_method wolfSSLv3_server_method
215#define SSLv3_client_method wolfSSLv3_client_method
216#define TLS_client_method wolfTLS_client_method
217#define TLS_server_method wolfTLS_server_method
218#define TLSv1_method wolfTLSv1_method
219#define TLSv1_server_method wolfTLSv1_server_method
220#define TLSv1_client_method wolfTLSv1_client_method
221#define TLSv1_1_method wolfTLSv1_1_method
222#define TLSv1_1_server_method wolfTLSv1_1_server_method
223#define TLSv1_1_client_method wolfTLSv1_1_client_method
224#define TLSv1_2_method wolfTLSv1_2_method
225#define TLSv1_2_server_method wolfTLSv1_2_server_method
226#define TLSv1_2_client_method wolfTLSv1_2_client_method
227#define TLSv1_3_method wolfTLSv1_3_method
228#define TLSv1_3_server_method wolfTLSv1_3_server_method
229#define TLSv1_3_client_method wolfTLSv1_3_client_method
230#define TLS_method wolfSSLv23_method
231
232#define X509_FILETYPE_ASN1 SSL_FILETYPE_ASN1
233
234#define X509_F_X509_CHECK_PRIVATE_KEY 128
235
236#ifdef WOLFSSL_DTLS
237 #define DTLSv1_client_method wolfDTLSv1_client_method
238 #define DTLSv1_server_method wolfDTLSv1_server_method
239 #define DTLSv1_2_client_method wolfDTLSv1_2_client_method
240 #define DTLSv1_2_server_method wolfDTLSv1_2_server_method
241 #define DTLS_method wolfDTLS_method
242#endif
243
244
245#ifndef NO_FILESYSTEM
246 #define SSL_CTX_use_certificate_file wolfSSL_CTX_use_certificate_file
247 #define SSL_CTX_use_PrivateKey_file wolfSSL_CTX_use_PrivateKey_file
248#ifdef WOLFSSL_APACHE_HTTPD
249 #define SSL_CTX_load_verify_locations(ctx,file,path) \
250 wolfSSL_CTX_load_verify_locations_ex(ctx,file,path,\
251 WOLFSSL_LOAD_FLAG_IGNORE_ERR)
252#else
253 #define SSL_CTX_load_verify_locations wolfSSL_CTX_load_verify_locations
254#endif
255 #define SSL_CTX_use_certificate_chain_file wolfSSL_CTX_use_certificate_chain_file
256 #define SSL_CTX_use_RSAPrivateKey_file wolfSSL_CTX_use_RSAPrivateKey_file
257
258 #define SSL_use_certificate_file wolfSSL_use_certificate_file
259 #define SSL_use_PrivateKey_file wolfSSL_use_PrivateKey_file
260 #define SSL_use_certificate_chain_file wolfSSL_use_certificate_chain_file
261 #define SSL_use_RSAPrivateKey_file wolfSSL_use_RSAPrivateKey_file
262#endif
263
264#define SSL_CTX_new(method) wolfSSL_CTX_new((WOLFSSL_METHOD*)(method))
265#ifdef OPENSSL_EXTRA
266#define SSL_CTX_up_ref wolfSSL_CTX_up_ref
267#endif
268#define SSL_new wolfSSL_new
269#define SSL_set_fd wolfSSL_set_fd
270#define SSL_get_fd wolfSSL_get_fd
271#define SSL_connect wolfSSL_connect
272#define SSL_clear wolfSSL_clear
273#define SSL_state wolfSSL_state
274
275#define SSL_write wolfSSL_write
276#define SSL_read wolfSSL_read
277#define SSL_peek wolfSSL_peek
278#define SSL_accept wolfSSL_accept
279#define SSL_CTX_free wolfSSL_CTX_free
280#define SSL_free wolfSSL_free
281#define SSL_shutdown wolfSSL_shutdown
282#define SSL_set_timeout wolfSSL_set_timeout
283
284#define SSL_CTX_set_quiet_shutdown wolfSSL_CTX_set_quiet_shutdown
285#define SSL_set_quiet_shutdown wolfSSL_set_quiet_shutdown
286#define SSL_get_error wolfSSL_get_error
287#define SSL_set_session wolfSSL_set_session
288#define SSL_get_session(x) wolfSSL_get_session((WOLFSSL*) (x))
289#define SSL_SESSION_get0_peer wolfSSL_SESSION_get0_peer
290#define SSL_flush_sessions wolfSSL_flush_sessions
291/* assume unlimited temporarily */
292#define SSL_CTX_get_session_cache_mode(ctx) 0
293
294#define SSL_CTX_set_verify wolfSSL_CTX_set_verify
295#define SSL_CTX_set_cert_verify_callback wolfSSL_CTX_set_cert_verify_callback
296#define SSL_set_verify wolfSSL_set_verify
297#define SSL_set_verify_result wolfSSL_set_verify_result
298#define SSL_verify_client_post_handshake wolfSSL_verify_client_post_handshake
299#define SSL_set_post_handshake_auth wolfSSL_set_post_handshake_auth
300#define SSL_CTX_set_post_handshake_auth wolfSSL_CTX_set_post_handshake_auth
301#define SSL_pending wolfSSL_pending
302#define SSL_load_error_strings wolfSSL_load_error_strings
303#define SSL_library_init wolfSSL_library_init
304#define OPENSSL_init_ssl wolfSSL_OPENSSL_init_ssl
305#define OpenSSL_add_ssl_algorithms wolfSSL_library_init
306#define SSL_CTX_set_session_cache_mode wolfSSL_CTX_set_session_cache_mode
307#define SSL_CTX_set_cipher_list wolfSSL_CTX_set_cipher_list
308#define SSL_CTX_set_ciphersuites wolfSSL_CTX_set_cipher_list
309#define SSL_set_cipher_list wolfSSL_set_cipher_list
310/* wolfSSL does not support security levels */
311#define SSL_CTX_set_security_level wolfSSL_CTX_set_security_level
312#define SSL_CTX_get_security_level wolfSSL_CTX_get_security_level
313/* wolfSSL does not support exporting keying material */
314#define SSL_export_keying_material wolfSSL_export_keying_material
315
316#define SSL_CTX_set1_sigalgs_list wolfSSL_CTX_set1_sigalgs_list
317#define SSL_set1_sigalgs_list wolfSSL_set1_sigalgs_list
318#define SSL_get_signature_nid wolfSSL_get_signature_nid
319
320#define SSL_CTX_set1_groups wolfSSL_CTX_set1_groups
321#define SSL_set1_groups wolfSSL_set1_groups
322
323#define SSL_CTX_set1_groups_list wolfSSL_CTX_set1_groups_list
324#define SSL_set1_groups_list wolfSSL_set1_groups_list
325
326#define SSL_set_ex_data wolfSSL_set_ex_data
327#define SSL_get_shutdown wolfSSL_get_shutdown
328#define SSL_get_finished wolfSSL_get_finished
329#define SSL_get_peer_finished wolfSSL_get_peer_finished
330#define SSL_set_rfd wolfSSL_set_rfd
331#define SSL_set_wfd wolfSSL_set_wfd
332#define SSL_set_shutdown wolfSSL_set_shutdown
333#define SSL_set_session_id_context wolfSSL_set_session_id_context
334#define SSL_set_connect_state wolfSSL_set_connect_state
335#define SSL_set_accept_state wolfSSL_set_accept_state
336#define SSL_session_reused wolfSSL_session_reused
337#define SSL_SESSION_up_ref wolfSSL_SESSION_up_ref
338#define SSL_SESSION_dup wolfSSL_SESSION_dup
339#define SSL_SESSION_free wolfSSL_SESSION_free
340#define SSL_SESSION_set_cipher wolfSSL_SESSION_set_cipher
341#define SSL_is_init_finished wolfSSL_is_init_finished
342
343#define SSL_get_version wolfSSL_get_version
344#define SSL_get_current_cipher wolfSSL_get_current_cipher
345
346/* use wolfSSL_get_cipher_name for its return format */
347#define SSL_get_cipher wolfSSL_get_cipher_name
348#define SSL_CIPHER_description wolfSSL_CIPHER_description
349#define SSL_CIPHER_get_name wolfSSL_CIPHER_get_name
350#define SSL_CIPHER_get_version wolfSSL_CIPHER_get_version
351#define SSL_CIPHER_get_id wolfSSL_CIPHER_get_id
352#define SSL_CIPHER_get_rfc_name wolfSSL_CIPHER_get_name
353#define SSL_CIPHER_standard_name wolfSSL_CIPHER_get_name
354#define SSL_get_cipher_by_value wolfSSL_get_cipher_by_value
355
356#define SSL_get1_session wolfSSL_get1_session
357
358#define SSL_get_keyblock_size wolfSSL_get_keyblock_size
359#define SSL_get_keys wolfSSL_get_keys
360#define SSL_SESSION_get_master_key wolfSSL_SESSION_get_master_key
361#define SSL_SESSION_get_master_key_length wolfSSL_SESSION_get_master_key_length
362
363#if defined(WOLFSSL_QT) || defined(OPENSSL_ALL)
364 #define SSL_MODE_RELEASE_BUFFERS 0x00000010U
365 #define ASN1_BOOLEAN WOLFSSL_ASN1_BOOLEAN
366 #define X509_get_ext wolfSSL_X509_get_ext
367 #define X509_get_ext_by_OBJ wolfSSL_X509_get_ext_by_OBJ
368 #define X509_cmp wolfSSL_X509_cmp
369 #define X509_EXTENSION_get_object wolfSSL_X509_EXTENSION_get_object
370 #define X509_EXTENSION_get_critical wolfSSL_X509_EXTENSION_get_critical
371 #define X509_EXTENSION_get_data wolfSSL_X509_EXTENSION_get_data
372 #define X509_EXTENSION_new wolfSSL_X509_EXTENSION_new
373 #define X509_EXTENSION_free wolfSSL_X509_EXTENSION_free
374 #define X509_gmtime_adj wolfSSL_X509_gmtime_adj
375#endif
376
377#define DSA_dup_DH wolfSSL_DSA_dup_DH
378/* wolfSSL does not support DSA as the cert public key */
379#define EVP_PKEY_get0_DSA wolfSSL_EVP_PKEY_get0_DSA
380#define EVP_PKEY_param_check wolfSSL_EVP_PKEY_param_check
381#define EVP_PKEY_CTX_free wolfSSL_EVP_PKEY_CTX_free
382#define DSA_bits wolfSSL_DSA_bits
383
384#define i2d_X509_bio wolfSSL_i2d_X509_bio
385#define i2d_X509_REQ_bio wolfSSL_i2d_X509_REQ_bio
386#define d2i_X509_bio wolfSSL_d2i_X509_bio
387#define d2i_X509_REQ_bio wolfSSL_d2i_X509_REQ_bio
388#define d2i_X509_fp wolfSSL_d2i_X509_fp
389#define i2d_X509 wolfSSL_i2d_X509
390#define d2i_X509 wolfSSL_d2i_X509
391#define PEM_read_bio_X509 wolfSSL_PEM_read_bio_X509
392#define PEM_read_bio_X509_REQ wolfSSL_PEM_read_bio_X509_REQ
393#define PEM_read_bio_X509_CRL wolfSSL_PEM_read_bio_X509_CRL
394#define PEM_read_bio_X509_AUX wolfSSL_PEM_read_bio_X509_AUX
395#define PEM_read_X509 wolfSSL_PEM_read_X509
396#define PEM_X509_INFO_read_bio wolfSSL_PEM_X509_INFO_read_bio
397#define PEM_write_bio_X509 wolfSSL_PEM_write_bio_X509
398#define PEM_write_bio_X509_AUX wolfSSL_PEM_write_bio_X509_AUX
399#define PEM_X509_INFO_read_bio wolfSSL_PEM_X509_INFO_read_bio
400#define i2d_PrivateKey wolfSSL_i2d_PrivateKey
401
402#define i2d_X509_REQ wolfSSL_i2d_X509_REQ
403#define d2i_X509_REQ wolfSSL_d2i_X509_REQ
404#define X509_REQ_new wolfSSL_X509_REQ_new
405#define X509_REQ_free wolfSSL_X509_REQ_free
406#define X509_REQ_sign wolfSSL_X509_REQ_sign
407#define X509_REQ_sign_ctx wolfSSL_X509_REQ_sign_ctx
408#define X509_REQ_add_extensions wolfSSL_X509_REQ_add_extensions
409#define X509_REQ_add1_attr_by_NID wolfSSL_X509_REQ_add1_attr_by_NID
410#define X509_REQ_add1_attr_by_txt wolfSSL_X509_REQ_add1_attr_by_txt
411#define X509_REQ_get_attr_by_NID wolfSSL_X509_REQ_get_attr_by_NID
412#define X509_REQ_get_attr wolfSSL_X509_REQ_get_attr
413#define X509_ATTRIBUTE_get0_type wolfSSL_X509_ATTRIBUTE_get0_type
414#define X509_to_X509_REQ wolfSSL_X509_to_X509_REQ
415#define X509_REQ_set_subject_name wolfSSL_X509_REQ_set_subject_name
416#define X509_REQ_set_pubkey wolfSSL_X509_REQ_set_pubkey
417#define PEM_write_bio_X509_REQ wolfSSL_PEM_write_bio_X509_REQ
418
419#define X509_new wolfSSL_X509_new
420#define X509_up_ref wolfSSL_X509_up_ref
421#define X509_free wolfSSL_X509_free
422#define X509_load_certificate_file wolfSSL_X509_load_certificate_file
423#define X509_digest wolfSSL_X509_digest
424#define X509_pubkey_digest wolfSSL_X509_pubkey_digest
425#define X509_get_ext_count wolfSSL_X509_get_ext_count
426#define X509_get_ext_d2i wolfSSL_X509_get_ext_d2i
427#define X509V3_EXT_i2d wolfSSL_X509V3_EXT_i2d
428#define X509_get0_extensions wolfSSL_X509_get0_extensions
429#define X509_get_extensions wolfSSL_X509_get0_extensions
430#define X509_REQ_get_extensions wolfSSL_X509_REQ_get_extensions
431#define X509_get_ext wolfSSL_X509_get_ext
432#define X509_get_ext_by_NID wolfSSL_X509_get_ext_by_NID
433#define X509_get_issuer_name wolfSSL_X509_get_issuer_name
434#define X509_issuer_name_hash wolfSSL_X509_issuer_name_hash
435#define X509_subject_name_hash wolfSSL_X509_subject_name_hash
436#define X509_get_subject_name wolfSSL_X509_get_subject_name
437#define X509_REQ_get_subject_name wolfSSL_X509_get_subject_name
438#define X509_get_pubkey wolfSSL_X509_get_pubkey
439#define X509_get0_pubkey wolfSSL_X509_get_pubkey
440#define X509_REQ_get_pubkey wolfSSL_X509_get_pubkey
441#define X509_get_notBefore wolfSSL_X509_get_notBefore
442#define X509_get0_notBefore wolfSSL_X509_get_notBefore
443#define X509_getm_notBefore wolfSSL_X509_get_notBefore
444#define X509_get_notAfter wolfSSL_X509_get_notAfter
445#define X509_get0_notAfter wolfSSL_X509_get_notAfter
446#define X509_getm_notAfter wolfSSL_X509_get_notAfter
447#define X509_get_serialNumber wolfSSL_X509_get_serialNumber
448#define X509_get0_pubkey_bitstr wolfSSL_X509_get0_pubkey_bitstr
449#define X509_get_ex_new_index wolfSSL_X509_get_ex_new_index
450#define X509_get_ex_data wolfSSL_X509_get_ex_data
451#define X509_set_ex_data wolfSSL_X509_set_ex_data
452#define X509_get1_ocsp wolfSSL_X509_get1_ocsp
453#ifndef WOLFSSL_HAPROXY
454#define X509_get_version wolfSSL_X509_get_version
455#endif
456#define X509_get_signature_nid wolfSSL_X509_get_signature_nid
457#define X509_set_subject_name wolfSSL_X509_set_subject_name
458#define X509_set_issuer_name wolfSSL_X509_set_issuer_name
459#define X509_set_pubkey wolfSSL_X509_set_pubkey
460#define X509_set_notAfter wolfSSL_X509_set_notAfter
461#define X509_set_notBefore wolfSSL_X509_set_notBefore
462#define X509_set_serialNumber wolfSSL_X509_set_serialNumber
463#define X509_set_version wolfSSL_X509_set_version
464#define X509_REQ_set_version wolfSSL_X509_set_version
465#define X509_sign wolfSSL_X509_sign
466#define X509_sign_ctx wolfSSL_X509_sign_ctx
467#define X509_print wolfSSL_X509_print
468#define X509_REQ_print wolfSSL_X509_print
469#define X509_print_ex wolfSSL_X509_print_ex
470#define X509_print_fp wolfSSL_X509_print_fp
471#define X509_REQ_print_fp wolfSSL_X509_print_fp
472#define X509_signature_print wolfSSL_X509_signature_print
473#define X509_get0_signature wolfSSL_X509_get0_signature
474#define X509_verify_cert_error_string wolfSSL_X509_verify_cert_error_string
475#define X509_verify_cert wolfSSL_X509_verify_cert
476#define X509_verify wolfSSL_X509_verify
477#define X509_REQ_verify wolfSSL_X509_REQ_verify
478#define X509_check_private_key wolfSSL_X509_check_private_key
479#define X509_REQ_check_private_key wolfSSL_X509_check_private_key
480#define X509_check_ca wolfSSL_X509_check_ca
481#define X509_check_host wolfSSL_X509_check_host
482#define X509_check_email wolfSSL_X509_check_email
483#define X509_check_ip_asc wolfSSL_X509_check_ip_asc
484#define X509_email_free wolfSSL_X509_email_free
485#define X509_check_issued wolfSSL_X509_check_issued
486#define X509_dup wolfSSL_X509_dup
487#define X509_add_ext wolfSSL_X509_add_ext
488#define X509_delete_ext wolfSSL_X509_delete_ext
489
490#define X509_EXTENSION_get_object wolfSSL_X509_EXTENSION_get_object
491#define X509_EXTENSION_get_data wolfSSL_X509_EXTENSION_get_data
492
493#define sk_X509_new wolfSSL_sk_X509_new
494#define sk_X509_new_null wolfSSL_sk_X509_new
495#define sk_X509_num wolfSSL_sk_X509_num
496#define sk_X509_value wolfSSL_sk_X509_value
497#define sk_X509_shift wolfSSL_sk_X509_shift
498#define sk_X509_push wolfSSL_sk_X509_push
499#define sk_X509_pop wolfSSL_sk_X509_pop
500#define sk_X509_pop_free wolfSSL_sk_X509_pop_free
501#define sk_X509_dup wolfSSL_sk_dup
502#define sk_X509_free wolfSSL_sk_X509_free
503
504#define sk_X509_EXTENSION_num wolfSSL_sk_X509_EXTENSION_num
505#define sk_X509_EXTENSION_value wolfSSL_sk_X509_EXTENSION_value
506#define sk_X509_EXTENSION_new_null wolfSSL_sk_X509_EXTENSION_new_null
507#define sk_X509_EXTENSION_pop_free wolfSSL_sk_X509_EXTENSION_pop_free
508#define sk_X509_EXTENSION_push wolfSSL_sk_X509_EXTENSION_push
509
510#define X509_INFO_new wolfSSL_X509_INFO_new
511#define X509_INFO_free wolfSSL_X509_INFO_free
512
513#define sk_X509_INFO_new_null wolfSSL_sk_X509_INFO_new_null
514#define sk_X509_INFO_num wolfSSL_sk_X509_INFO_num
515#define sk_X509_INFO_value wolfSSL_sk_X509_INFO_value
516#define sk_X509_INFO_push wolfSSL_sk_X509_INFO_push
517#define sk_X509_INFO_pop wolfSSL_sk_X509_INFO_pop
518#define sk_X509_INFO_pop_free wolfSSL_sk_X509_INFO_pop_free
519#define sk_X509_INFO_free wolfSSL_sk_X509_INFO_free
520#define sk_X509_INFO_shift wolfSSL_sk_X509_INFO_pop
521
522#define i2d_X509_NAME wolfSSL_i2d_X509_NAME
523#define d2i_X509_NAME wolfSSL_d2i_X509_NAME
524#define X509_NAME_new wolfSSL_X509_NAME_new
525#define X509_NAME_free wolfSSL_X509_NAME_free
526#define X509_NAME_dup wolfSSL_X509_NAME_dup
527#define X509_NAME_get_text_by_NID wolfSSL_X509_NAME_get_text_by_NID
528#define X509_NAME_get_index_by_OBJ wolfSSL_X509_NAME_get_index_by_OBJ
529#define X509_NAME_cmp wolfSSL_X509_NAME_cmp
530#define X509_NAME_ENTRY_new wolfSSL_X509_NAME_ENTRY_new
531#define X509_NAME_ENTRY_free wolfSSL_X509_NAME_ENTRY_free
532#define X509_NAME_ENTRY_create_by_NID wolfSSL_X509_NAME_ENTRY_create_by_NID
533#define X509_NAME_ENTRY_create_by_txt wolfSSL_X509_NAME_ENTRY_create_by_txt
534#define X509_NAME_add_entry wolfSSL_X509_NAME_add_entry
535#define X509_NAME_add_entry_by_txt wolfSSL_X509_NAME_add_entry_by_txt
536#define X509_NAME_add_entry_by_NID wolfSSL_X509_NAME_add_entry_by_NID
537#define X509_NAME_delete_entry wolfSSL_X509_NAME_delete_entry
538#define X509_NAME_oneline wolfSSL_X509_NAME_oneline
539#define X509_NAME_get_index_by_NID wolfSSL_X509_NAME_get_index_by_NID
540#define X509_NAME_print_ex wolfSSL_X509_NAME_print_ex
541#define X509_NAME_print_ex_fp wolfSSL_X509_NAME_print_ex_fp
542#define X509_NAME_digest wolfSSL_X509_NAME_digest
543#define X509_cmp_current_time wolfSSL_X509_cmp_current_time
544#define X509_cmp_time wolfSSL_X509_cmp_time
545#define X509_time_adj wolfSSL_X509_time_adj
546#define X509_time_adj_ex wolfSSL_X509_time_adj_ex
547
548#define sk_ACCESS_DESCRIPTION_num wolfSSL_sk_ACCESS_DESCRIPTION_num
549#define sk_ACCESS_DESCRIPTION_value wolfSSL_sk_ACCESS_DESCRIPTION_value
550
551#define sk_X509_NAME_new wolfSSL_sk_X509_NAME_new
552#define sk_X509_NAME_push wolfSSL_sk_X509_NAME_push
553#define sk_X509_NAME_find wolfSSL_sk_X509_NAME_find
554#define sk_X509_NAME_set_cmp_func wolfSSL_sk_X509_NAME_set_cmp_func
555#define sk_X509_NAME_num wolfSSL_sk_X509_NAME_num
556#define sk_X509_NAME_value wolfSSL_sk_X509_NAME_value
557#define sk_X509_NAME_pop wolfSSL_sk_X509_NAME_pop
558#define sk_X509_NAME_pop_free wolfSSL_sk_X509_NAME_pop_free
559#define sk_X509_NAME_free wolfSSL_sk_X509_NAME_free
560
561typedef WOLFSSL_X509_NAME_ENTRY X509_NAME_ENTRY;
562
563#define X509_NAME_entry_count wolfSSL_X509_NAME_entry_count
564#define X509_NAME_ENTRY_get_object wolfSSL_X509_NAME_ENTRY_get_object
565#define X509_NAME_get_entry wolfSSL_X509_NAME_get_entry
566#define X509_NAME_ENTRY_get_data wolfSSL_X509_NAME_ENTRY_get_data
567#define X509_NAME_ENTRY_get_object wolfSSL_X509_NAME_ENTRY_get_object
568
569#define X509_V_FLAG_CRL_CHECK WOLFSSL_CRL_CHECK
570#define X509_V_FLAG_CRL_CHECK_ALL WOLFSSL_CRL_CHECKALL
571
572#define X509_V_FLAG_USE_CHECK_TIME WOLFSSL_USE_CHECK_TIME
573#define X509_V_FLAG_NO_CHECK_TIME WOLFSSL_NO_CHECK_TIME
574#define X509_CHECK_FLAG_NO_WILDCARDS WOLFSSL_NO_WILDCARDS
575
576#define X509_VP_FLAG_DEFAULT WOLFSSL_VPARAM_DEFAULT
577#define X509_VP_FLAG_OVERWRITE WOLFSSL_VPARAM_OVERWRITE
578#define X509_VP_FLAG_RESET_FLAGS WOLFSSL_VPARAM_RESET_FLAGS
579#define X509_VP_FLAG_LOCKED WOLFSSL_VPARAM_LOCKED
580#define X509_VP_FLAG_ONCE WOLFSSL_VPARAM_ONCE
581
582#define X509_STORE_CTX_get_current_cert wolfSSL_X509_STORE_CTX_get_current_cert
583#define X509_STORE_CTX_set_verify_cb wolfSSL_X509_STORE_CTX_set_verify_cb
584#define X509_STORE_CTX_new wolfSSL_X509_STORE_CTX_new
585#define X509_STORE_CTX_free wolfSSL_X509_STORE_CTX_free
586#define X509_STORE_CTX_get_chain wolfSSL_X509_STORE_CTX_get_chain
587#define X509_STORE_CTX_get0_chain wolfSSL_X509_STORE_CTX_get_chain
588#define X509_STORE_CTX_get1_chain wolfSSL_X509_STORE_CTX_get1_chain
589#define X509_STORE_CTX_get0_parent_ctx wolfSSL_X509_STORE_CTX_get0_parent_ctx
590#define X509_STORE_CTX_get_error wolfSSL_X509_STORE_CTX_get_error
591#define X509_STORE_CTX_get_error_depth wolfSSL_X509_STORE_CTX_get_error_depth
592#define X509_STORE_CTX_init wolfSSL_X509_STORE_CTX_init
593#define X509_STORE_CTX_cleanup wolfSSL_X509_STORE_CTX_cleanup
594#define X509_STORE_CTX_set_error wolfSSL_X509_STORE_CTX_set_error
595#define X509_STORE_CTX_set_error_depth wolfSSL_X509_STORE_CTX_set_error_depth
596#define X509_STORE_CTX_get_ex_data wolfSSL_X509_STORE_CTX_get_ex_data
597#define X509_STORE_CTX_set_ex_data wolfSSL_X509_STORE_CTX_set_ex_data
598#define X509_STORE_CTX_set_depth wolfSSL_X509_STORE_CTX_set_depth
599#define X509_STORE_CTX_verify_cb WOLFSSL_X509_STORE_CTX_verify_cb
600#define X509_STORE_CTX_get0_current_issuer \
601 wolfSSL_X509_STORE_CTX_get0_current_issuer
602#define X509_STORE_CTX_get0_store wolfSSL_X509_STORE_CTX_get0_store
603#define X509_STORE_CTX_get0_cert wolfSSL_X509_STORE_CTX_get0_cert
604#define X509_STORE_CTX_trusted_stack wolfSSL_X509_STORE_CTX_trusted_stack
605
606#define X509_STORE_set_verify_cb(s, c) \
607wolfSSL_X509_STORE_set_verify_cb((WOLFSSL_X509_STORE *)(s), (WOLFSSL_X509_STORE_CTX_verify_cb)(c))
608#define X509_STORE_set_verify_cb_func(s, c) \
609wolfSSL_X509_STORE_set_verify_cb((WOLFSSL_X509_STORE *)(s), (WOLFSSL_X509_STORE_CTX_verify_cb)(c))
610
611
612#define X509_STORE_new wolfSSL_X509_STORE_new
613#define X509_STORE_free wolfSSL_X509_STORE_free
614#define X509_STORE_add_lookup wolfSSL_X509_STORE_add_lookup
615#define X509_STORE_add_cert wolfSSL_X509_STORE_add_cert
616#define X509_STORE_add_crl wolfSSL_X509_STORE_add_crl
617#define X509_STORE_set_flags wolfSSL_X509_STORE_set_flags
618#define X509_STORE_get1_certs wolfSSL_X509_STORE_get1_certs
619#define X509_STORE_get_by_subject wolfSSL_X509_STORE_get_by_subject
620#define X509_STORE_set_ex_data wolfSSL_X509_STORE_set_ex_data
621#define X509_STORE_get_ex_data wolfSSL_X509_STORE_get_ex_data
622#define X509_STORE_CTX_get1_issuer wolfSSL_X509_STORE_CTX_get1_issuer
623#define X509_STORE_CTX_set_time wolfSSL_X509_STORE_CTX_set_time
624#define X509_VERIFY_PARAM_new wolfSSL_X509_VERIFY_PARAM_new
625#define X509_VERIFY_PARAM_free wolfSSL_X509_VERIFY_PARAM_free
626#define X509_VERIFY_PARAM_set_flags wolfSSL_X509_VERIFY_PARAM_set_flags
627#define X509_VERIFY_PARAM_get_flags wolfSSL_X509_VERIFY_PARAM_get_flags
628#define X509_VERIFY_PARAM_clear_flags wolfSSL_X509_VERIFY_PARAM_clear_flags
629#define X509_VERIFY_PARAM_set_hostflags wolfSSL_X509_VERIFY_PARAM_set_hostflags
630#define X509_VERIFY_PARAM_set1_host wolfSSL_X509_VERIFY_PARAM_set1_host
631#define X509_VERIFY_PARAM_set1_ip_asc wolfSSL_X509_VERIFY_PARAM_set1_ip_asc
632#define X509_VERIFY_PARAM_set1 wolfSSL_X509_VERIFY_PARAM_set1
633#define X509_STORE_load_locations wolfSSL_X509_STORE_load_locations
634
635#define X509_LOOKUP_add_dir wolfSSL_X509_LOOKUP_add_dir
636#define X509_LOOKUP_load_file wolfSSL_X509_LOOKUP_load_file
637#define X509_LOOKUP_hash_dir wolfSSL_X509_LOOKUP_hash_dir
638#define X509_LOOKUP_file wolfSSL_X509_LOOKUP_file
639#define X509_LOOKUP_ctrl wolfSSL_X509_LOOKUP_ctrl
640
641#define d2i_X509_CRL wolfSSL_d2i_X509_CRL
642#define d2i_X509_CRL_fp wolfSSL_d2i_X509_CRL_fp
643#define PEM_read_X509_CRL wolfSSL_PEM_read_X509_CRL
644
645#define X509_CRL_free wolfSSL_X509_CRL_free
646#define X509_CRL_get_lastUpdate wolfSSL_X509_CRL_get_lastUpdate
647#define X509_CRL_get_nextUpdate wolfSSL_X509_CRL_get_nextUpdate
648#define X509_CRL_verify wolfSSL_X509_CRL_verify
649#define X509_CRL_get_REVOKED wolfSSL_X509_CRL_get_REVOKED
650#define X509_load_crl_file wolfSSL_X509_load_crl_file
651
652#define X509_get_X509_PUBKEY wolfSSL_X509_get_X509_PUBKEY
653#define X509_REQ_get_X509_PUBKEY wolfSSL_X509_get_X509_PUBKEY
654#define X509_get0_tbs_sigalg wolfSSL_X509_get0_tbs_sigalg
655#define X509_PUBKEY_get0_param wolfSSL_X509_PUBKEY_get0_param
656#define X509_PUBKEY_get wolfSSL_X509_PUBKEY_get
657#define X509_PUBKEY_set wolfSSL_X509_PUBKEY_set
658#define X509_ALGOR_get0 wolfSSL_X509_ALGOR_get0
659#define X509_ALGOR_set0 wolfSSL_X509_ALGOR_set0
660
661#define X509_ALGOR_new wolfSSL_X509_ALGOR_new
662#define X509_ALGOR_free wolfSSL_X509_ALGOR_free
663#define X509_PUBKEY_new wolfSSL_X509_PUBKEY_new
664#define X509_PUBKEY_free wolfSSL_X509_PUBKEY_free
665
666#define sk_X509_REVOKED_num wolfSSL_sk_X509_REVOKED_num
667#define sk_X509_REVOKED_value wolfSSL_sk_X509_REVOKED_value
668
669#define X509_OBJECT_free_contents wolfSSL_X509_OBJECT_free_contents
670
671#define X509_check_purpose(...) 0
672
673#define OCSP_parse_url wolfSSL_OCSP_parse_url
674
675#define MD4_Init wolfSSL_MD4_Init
676#define MD4_Update wolfSSL_MD4_Update
677#define MD4_Final wolfSSL_MD4_Final
678
679#define BIO_new wolfSSL_BIO_new
680#define BIO_free wolfSSL_BIO_free
681#define BIO_vfree wolfSSL_BIO_vfree
682#define BIO_free_all wolfSSL_BIO_free_all
683#define BIO_nread0 wolfSSL_BIO_nread0
684#define BIO_nread wolfSSL_BIO_nread
685#define BIO_read wolfSSL_BIO_read
686#define BIO_nwrite0 wolfSSL_BIO_nwrite0
687#define BIO_nwrite wolfSSL_BIO_nwrite
688#define BIO_write wolfSSL_BIO_write
689#define BIO_push wolfSSL_BIO_push
690#define BIO_pop wolfSSL_BIO_pop
691#define BIO_flush wolfSSL_BIO_flush
692#define BIO_pending wolfSSL_BIO_pending
693
694#define BIO_get_mem_data wolfSSL_BIO_get_mem_data
695#define BIO_new_mem_buf wolfSSL_BIO_new_mem_buf
696
697#define BIO_f_buffer wolfSSL_BIO_f_buffer
698#define BIO_set_write_buffer_size wolfSSL_BIO_set_write_buffer_size
699#define BIO_f_ssl wolfSSL_BIO_f_ssl
700#define BIO_new_socket wolfSSL_BIO_new_socket
701#define BIO_new_connect wolfSSL_BIO_new_connect
702#define BIO_set_conn_port wolfSSL_BIO_set_conn_port
703#define BIO_do_connect wolfSSL_BIO_do_connect
704#define BIO_do_handshake wolfSSL_BIO_do_handshake
705#define SSL_set_bio wolfSSL_set_bio
706#define BIO_set_ssl wolfSSL_BIO_set_ssl
707#define BIO_eof wolfSSL_BIO_eof
708#define BIO_set_ss wolfSSL_BIO_set_ss
709
710#define BIO_f_md wolfSSL_BIO_f_md
711#define BIO_get_md_ctx wolfSSL_BIO_get_md_ctx
712#define BIO_s_mem wolfSSL_BIO_s_mem
713#define BIO_f_base64 wolfSSL_BIO_f_base64
714#define BIO_set_flags wolfSSL_BIO_set_flags
715#define BIO_set_nbio wolfSSL_BIO_set_nbio
716
717#define SSLeay_add_ssl_algorithms wolfSSL_add_all_algorithms
718#define SSLeay_add_all_algorithms wolfSSL_add_all_algorithms
719
720#define RAND_screen wolfSSL_RAND_screen
721#define RAND_file_name wolfSSL_RAND_file_name
722#define RAND_write_file wolfSSL_RAND_write_file
723#define RAND_load_file wolfSSL_RAND_load_file
724#define RAND_egd wolfSSL_RAND_egd
725#define RAND_seed wolfSSL_RAND_seed
726#define RAND_cleanup wolfSSL_RAND_Cleanup
727#define RAND_add wolfSSL_RAND_add
728#define RAND_poll wolfSSL_RAND_poll
729#define RAND_status wolfSSL_RAND_status
730#define RAND_bytes wolfSSL_RAND_bytes
731#define RAND_pseudo_bytes wolfSSL_RAND_pseudo_bytes
732
733#define COMP_zlib wolfSSL_COMP_zlib
734#define COMP_rle wolfSSL_COMP_rle
735#define SSL_COMP_add_compression_method wolfSSL_COMP_add_compression_method
736
737#define SSL_get_ex_new_index wolfSSL_get_ex_new_index
738#define RSA_get_ex_new_index wolfSSL_get_ex_new_index
739
740#define ASN1_BIT_STRING_new wolfSSL_ASN1_BIT_STRING_new
741#define ASN1_BIT_STRING_free wolfSSL_ASN1_BIT_STRING_free
742#define ASN1_BIT_STRING_get_bit wolfSSL_ASN1_BIT_STRING_get_bit
743#define ASN1_BIT_STRING_set_bit wolfSSL_ASN1_BIT_STRING_set_bit
744
745#define sk_ASN1_OBJECT_free wolfSSL_sk_ASN1_OBJECT_free
746
747#define ASN1_TIME_new wolfSSL_ASN1_TIME_new
748#define ASN1_UTCTIME_new wolfSSL_ASN1_TIME_new
749#define ASN1_TIME_free wolfSSL_ASN1_TIME_free
750#define ASN1_UTCTIME_free wolfSSL_ASN1_TIME_free
751#define ASN1_TIME_adj wolfSSL_ASN1_TIME_adj
752#define ASN1_TIME_print wolfSSL_ASN1_TIME_print
753#define ASN1_TIME_to_generalizedtime wolfSSL_ASN1_TIME_to_generalizedtime
754#define ASN1_TIME_set wolfSSL_ASN1_TIME_set
755#define ASN1_TIME_set_string wolfSSL_ASN1_TIME_set_string
756#define ASN1_TIME_to_string wolfSSL_ASN1_TIME_to_string
757#define ASN1_GENERALIZEDTIME_print wolfSSL_ASN1_GENERALIZEDTIME_print
758#define ASN1_GENERALIZEDTIME_free wolfSSL_ASN1_GENERALIZEDTIME_free
759
760#define ASN1_tag2str wolfSSL_ASN1_tag2str
761
762#define a2i_ASN1_INTEGER wolfSSL_a2i_ASN1_INTEGER
763#define i2a_ASN1_INTEGER wolfSSL_i2a_ASN1_INTEGER
764#define i2c_ASN1_INTEGER wolfSSL_i2c_ASN1_INTEGER
765#define ASN1_INTEGER_new wolfSSL_ASN1_INTEGER_new
766#define ASN1_INTEGER_free wolfSSL_ASN1_INTEGER_free
767#define ASN1_INTEGER_cmp wolfSSL_ASN1_INTEGER_cmp
768#define ASN1_INTEGER_get wolfSSL_ASN1_INTEGER_get
769#define ASN1_INTEGER_set wolfSSL_ASN1_INTEGER_set
770#define ASN1_INTEGER_to_BN wolfSSL_ASN1_INTEGER_to_BN
771
772#define i2a_ASN1_OBJECT wolfSSL_i2a_ASN1_OBJECT
773#define i2d_ASN1_OBJECT wolfSSL_i2d_ASN1_OBJECT
774
775#define ASN1_STRING_new wolfSSL_ASN1_STRING_new
776#define ASN1_STRING_free wolfSSL_ASN1_STRING_free
777#define ASN1_STRING_cmp wolfSSL_ASN1_STRING_cmp
778#define ASN1_STRING_data wolfSSL_ASN1_STRING_data
779#define ASN1_STRING_get0_data wolfSSL_ASN1_STRING_get0_data
780#define ASN1_STRING_length wolfSSL_ASN1_STRING_length
781#define ASN1_STRING_to_UTF8 wolfSSL_ASN1_STRING_to_UTF8
782#define ASN1_UNIVERSALSTRING_to_string wolfSSL_ASN1_UNIVERSALSTRING_to_string
783#define ASN1_STRING_print_ex wolfSSL_ASN1_STRING_print_ex
784#define ASN1_STRING_print(x, y) wolfSSL_ASN1_STRING_print ((WOLFSSL_BIO*)(x), (WOLFSSL_ASN1_STRING*)(y))
785#define d2i_DISPLAYTEXT wolfSSL_d2i_DISPLAYTEXT
786#ifndef NO_WOLFSSL_STUB
787#define ASN1_STRING_set_default_mask_asc(...) 1
788#endif
789
790#define ASN1_PRINTABLE_type(...) V_ASN1_PRINTABLESTRING
791
792#define ASN1_UTCTIME_pr wolfSSL_ASN1_UTCTIME_pr
793
794#define ASN1_IA5STRING WOLFSSL_ASN1_STRING
795
796#define ASN1_OCTET_STRING WOLFSSL_ASN1_STRING
797#define ASN1_BOOLEAN WOLFSSL_ASN1_BOOLEAN
798
799#define SSL_load_client_CA_file wolfSSL_load_client_CA_file
800
801#define SSL_CTX_get_client_CA_list wolfSSL_CTX_get_client_CA_list
802#define SSL_CTX_set_client_CA_list wolfSSL_CTX_set_client_CA_list
803#define SSL_CTX_set_client_cert_cb wolfSSL_CTX_set_client_cert_cb
804#define SSL_CTX_set_cert_store wolfSSL_CTX_set_cert_store
805#define SSL_CTX_get_cert_store(x) wolfSSL_CTX_get_cert_store ((WOLFSSL_CTX*) (x))
806#define SSL_get_client_CA_list wolfSSL_get_client_CA_list
807#define SSL_get_ex_data_X509_STORE_CTX_idx wolfSSL_get_ex_data_X509_STORE_CTX_idx
808#define SSL_get_ex_data wolfSSL_get_ex_data
809
810#define SSL_CTX_set_default_passwd_cb_userdata wolfSSL_CTX_set_default_passwd_cb_userdata
811#define SSL_CTX_set_default_passwd_cb wolfSSL_CTX_set_default_passwd_cb
812
813#define SSL_CTX_set_timeout(ctx, to) \
814 wolfSSL_CTX_set_timeout(ctx, (unsigned int) to)
815#define SSL_CTX_set_info_callback wolfSSL_CTX_set_info_callback
816#define SSL_CTX_set_alpn_protos wolfSSL_CTX_set_alpn_protos
817
818#define SSL_CTX_keylog_cb_func wolfSSL_CTX_keylog_cb_func
819#define SSL_CTX_set_keylog_callback wolfSSL_CTX_set_keylog_callback
820#define SSL_CTX_get_keylog_callback wolfSSL_CTX_get_keylog_callback
821
822#define SSL_alert_type_string wolfSSL_alert_type_string
823#define SSL_alert_desc_string wolfSSL_alert_desc_string
824#define SSL_state_string wolfSSL_state_string
825
826#define RSA_free wolfSSL_RSA_free
827#define RSA_generate_key wolfSSL_RSA_generate_key
828#define SSL_CTX_set_tmp_rsa_callback wolfSSL_CTX_set_tmp_rsa_callback
829#define RSA_print wolfSSL_RSA_print
830#define RSA_bits wolfSSL_RSA_bits
831#define RSA_up_ref wolfSSL_RSA_up_ref
832#define RSA_padding_add_PKCS1_PSS wolfSSL_RSA_padding_add_PKCS1_PSS
833#define RSA_verify_PKCS1_PSS wolfSSL_RSA_verify_PKCS1_PSS
834
835#define PEM_def_callback wolfSSL_PEM_def_callback
836
837#define SSL_CTX_sess_accept wolfSSL_CTX_sess_accept
838#define SSL_CTX_sess_connect wolfSSL_CTX_sess_connect
839#define SSL_CTX_sess_accept_good wolfSSL_CTX_sess_accept_good
840#define SSL_CTX_sess_connect_good wolfSSL_CTX_sess_connect_good
841#define SSL_CTX_sess_accept_renegotiate wolfSSL_CTX_sess_accept_renegotiate
842#define SSL_CTX_sess_connect_renegotiate wolfSSL_CTX_sess_connect_renegotiate
843#define SSL_CTX_sess_hits wolfSSL_CTX_sess_hits
844#define SSL_CTX_sess_cb_hits wolfSSL_CTX_sess_cb_hits
845#define SSL_CTX_sess_cache_full wolfSSL_CTX_sess_cache_full
846#define SSL_CTX_sess_misses wolfSSL_CTX_sess_misses
847#define SSL_CTX_sess_timeouts wolfSSL_CTX_sess_timeouts
848#define SSL_CTX_sess_number wolfSSL_CTX_sess_number
849#define SSL_CTX_sess_get_cache_size wolfSSL_CTX_sess_get_cache_size
850
851
852#define SSL_DEFAULT_CIPHER_LIST WOLFSSL_DEFAULT_CIPHER_LIST
853
854#define SSL_CTX_set_psk_client_callback wolfSSL_CTX_set_psk_client_callback
855#define SSL_set_psk_client_callback wolfSSL_set_psk_client_callback
856
857#define SSL_get_psk_identity_hint wolfSSL_get_psk_identity_hint
858#define SSL_get_psk_identity wolfSSL_get_psk_identity
859
860#define SSL_CTX_use_psk_identity_hint wolfSSL_CTX_use_psk_identity_hint
861#define SSL_use_psk_identity_hint wolfSSL_use_psk_identity_hint
862
863#define SSL_CTX_set_psk_server_callback wolfSSL_CTX_set_psk_server_callback
864#define SSL_set_psk_server_callback wolfSSL_set_psk_server_callback
865
866/* system file ints for ERR_put_error */
867#define SYS_F_ACCEPT WOLFSSL_SYS_ACCEPT
868#define SYS_F_BIND WOLFSSL_SYS_BIND
869#define SYS_F_CONNECT WOLFSSL_SYS_CONNECT
870#define SYS_F_FOPEN WOLFSSL_SYS_FOPEN
871#define SYS_F_FREAD WOLFSSL_SYS_FREAD
872#define SYS_F_GETADDRINFO WOLFSSL_SYS_GETADDRINFO
873#define SYS_F_GETSOCKOPT WOLFSSL_SYS_GETSOCKOPT
874#define SYS_F_GETSOCKNAME WOLFSSL_SYS_GETSOCKNAME
875#define SYS_F_OPENDIR WOLFSSL_SYS_OPENDIR
876#define SYS_F_SETSOCKOPT WOLFSSL_SYS_SETSOCKOPT
877#define SYS_F_SOCKET WOLFSSL_SYS_SOCKET
878#define SYS_F_GETHOSTBYNAME WOLFSSL_SYS_GETHOSTBYNAME
879#define SYS_F_GETNAMEINFO WOLFSSL_SYS_GETNAMEINFO
880#define SYS_F_GETSERVBYNAME WOLFSSL_SYS_GETSERVBYNAME
881#define SYS_F_IOCTLSOCKET WOLFSSL_SYS_IOCTLSOCKET
882#define SYS_F_LISTEN WOLFSSL_SYS_LISTEN
883
884#define ERR_GET_LIB wolfSSL_ERR_GET_LIB
885#define ERR_GET_REASON wolfSSL_ERR_GET_REASON
886
887#define ERR_put_error wolfSSL_ERR_put_error
888#define ERR_peek_error wolfSSL_ERR_peek_error
889#define ERR_peek_errors_fp wolfSSL_ERR_peek_errors_fp
890#define ERR_peek_error_line_data wolfSSL_ERR_peek_error_line_data
891#define ERR_peek_last_error wolfSSL_ERR_peek_last_error
892#define ERR_peek_last_error_line wolfSSL_ERR_peek_last_error_line
893#define ERR_get_error_line wolfSSL_ERR_get_error_line
894#define ERR_get_error_line_data wolfSSL_ERR_get_error_line_data
895#define ERR_get_error wolfSSL_ERR_get_error
896#define ERR_print_errors_fp(file) wolfSSL_ERR_dump_errors_fp((file))
897#define ERR_print_errors_cb wolfSSL_ERR_print_errors_cb
898#define ERR_print_errors wolfSSL_ERR_print_errors
899#define ERR_clear_error wolfSSL_ERR_clear_error
900#define ERR_free_strings wolfSSL_ERR_free_strings
901#define ERR_remove_state wolfSSL_ERR_remove_state
902#define ERR_remove_thread_state wolfSSL_ERR_remove_thread_state
903#define ERR_error_string wolfSSL_ERR_error_string
904#define ERR_error_string_n wolfSSL_ERR_error_string_n
905#define ERR_reason_error_string wolfSSL_ERR_reason_error_string
906#define ERR_load_BIO_strings wolfSSL_ERR_load_BIO_strings
907
908#ifndef WOLFCRYPT_ONLY
909#define PEMerr(func, reason) wolfSSL_ERR_put_error(ERR_LIB_PEM, \
910 (func), (reason), __FILE__, __LINE__)
911#else
912#define PEMerr(func, reason) WOLFSSL_ERROR_LINE((reason), \
913 NULL, __LINE__, __FILE__, NULL)
914#endif
915#ifndef WOLFCRYPT_ONLY
916#define EVPerr(func, reason) wolfSSL_ERR_put_error(ERR_LIB_EVP, \
917 (func), (reason), __FILE__, __LINE__)
918#else
919#define EVPerr(func, reason) WOLFSSL_ERROR_LINE((reason), \
920 NULL, __LINE__, __FILE__, NULL)
921#endif
922
923#define SSLv23_server_method wolfSSLv23_server_method
924#define SSL_CTX_set_options wolfSSL_CTX_set_options
925#define SSL_CTX_get_options wolfSSL_CTX_get_options
926#define SSL_CTX_clear_options wolfSSL_CTX_clear_options
927
928#define SSL_CTX_check_private_key wolfSSL_CTX_check_private_key
929#define SSL_check_private_key wolfSSL_check_private_key
930
931#define SSL_CTX_set_mode wolfSSL_CTX_set_mode
932#define SSL_CTX_get_mode wolfSSL_CTX_get_mode
933#define SSL_CTX_set_default_read_ahead wolfSSL_CTX_set_default_read_ahead
934
935#define SSL_CTX_sess_set_cache_size wolfSSL_CTX_sess_set_cache_size
936#define SSL_CTX_set_default_verify_paths wolfSSL_CTX_set_default_verify_paths
937
938#define SSL_CTX_set_session_id_context wolfSSL_CTX_set_session_id_context
939#define SSL_get_peer_certificate wolfSSL_get_peer_certificate
940#define SSL_get_peer_cert_chain wolfSSL_get_peer_cert_chain
941
942#define SSL_want wolfSSL_want
943#define SSL_want_read wolfSSL_want_read
944#define SSL_want_write wolfSSL_want_write
945
946#define BIO_prf wolfSSL_BIO_prf
947
948#define sk_num wolfSSL_sk_num
949#define sk_ASN1_OBJECT_num wolfSSL_sk_num
950#define OPENSSL_sk_num wolfSSL_sk_num
951#define sk_value wolfSSL_sk_value
952#define sk_ASN1_OBJECT_value wolfSSL_sk_value
953#define OPENSSL_sk_value wolfSSL_sk_value
954
955#define d2i_PKCS12_bio wolfSSL_d2i_PKCS12_bio
956#define d2i_PKCS12_fp wolfSSL_d2i_PKCS12_fp
957#define i2d_PKCS12_bio wolfSSL_i2d_PKCS12_bio
958
959#define d2i_RSAPublicKey wolfSSL_d2i_RSAPublicKey
960#define d2i_RSAPrivateKey wolfSSL_d2i_RSAPrivateKey
961#define i2d_RSAPrivateKey wolfSSL_i2d_RSAPrivateKey
962#define i2d_RSAPublicKey wolfSSL_i2d_RSAPublicKey
963
964#define SSL_CTX_get_ex_data wolfSSL_CTX_get_ex_data
965#define SSL_CTX_set_ex_data wolfSSL_CTX_set_ex_data
966#define SSL_CTX_sess_set_get_cb wolfSSL_CTX_sess_set_get_cb
967#define SSL_CTX_sess_set_new_cb wolfSSL_CTX_sess_set_new_cb
968#define SSL_CTX_sess_set_remove_cb wolfSSL_CTX_sess_set_remove_cb
969
970#define i2d_SSL_SESSION wolfSSL_i2d_SSL_SESSION
971#define d2i_SSL_SESSION wolfSSL_d2i_SSL_SESSION
972#define SSL_SESSION_set_timeout wolfSSL_SSL_SESSION_set_timeout
973#define SSL_SESSION_get_timeout wolfSSL_SESSION_get_timeout
974#define SSL_SESSION_get_time wolfSSL_SESSION_get_time
975
976#define SSL_CTX_get_ex_new_index wolfSSL_CTX_get_ex_new_index
977#define PEM_read wolfSSL_PEM_read
978#define PEM_write wolfSSL_PEM_write
979#define PEM_get_EVP_CIPHER_INFO wolfSSL_PEM_get_EVP_CIPHER_INFO
980#define PEM_do_header wolfSSL_PEM_do_header
981
982/*#if OPENSSL_API_COMPAT < 0x10100000L*/
983#define CONF_modules_free()
984#define ENGINE_cleanup()
985#define SSL_CTX_need_tmp_RSA(ctx) 0
986#define SSL_CTX_set_tmp_rsa(ctx,rsa) 1
987#define SSL_need_tmp_RSA(ssl) 0
988#define SSL_set_tmp_rsa(ssl,rsa) 1
989/*#endif*/
990
991#define CONF_modules_unload(a)
992#define CONF_get1_default_config_file wolfSSL_CONF_get1_default_config_file
993
994#define SSL_get_hit wolfSSL_session_reused
995
996/* yassl had set the default to be 500 */
997#define SSL_get_default_timeout(ctx) 500
998
999#define DTLSv1_get_timeout(ssl, timeleft) wolfSSL_DTLSv1_get_timeout((ssl), (WOLFSSL_TIMEVAL*)(timeleft))
1000#define DTLSv1_handle_timeout wolfSSL_DTLSv1_handle_timeout
1001#define DTLSv1_set_initial_timeout_duration wolfSSL_DTLSv1_set_initial_timeout_duration
1002
1003#ifndef NO_WOLFSSL_STUB
1004#define SSL_CTX_set_current_time_cb(ssl, cb) ({ (void)ssl; (void)cb; })
1005#endif
1006
1007#define SSL_CTX_use_certificate wolfSSL_CTX_use_certificate
1008#define SSL_CTX_add1_chain_cert wolfSSL_CTX_add1_chain_cert
1009#define SSL_CTX_use_PrivateKey wolfSSL_CTX_use_PrivateKey
1010#define BIO_read_filename wolfSSL_BIO_read_filename
1011#define SSL_CTX_set_verify_depth wolfSSL_CTX_set_verify_depth
1012#define SSL_set_verify_depth wolfSSL_set_verify_depth
1013#define SSL_get_app_data wolfSSL_get_app_data
1014#define SSL_set_app_data wolfSSL_set_app_data
1015#define SHA1 wolfSSL_SHA1
1016
1017#define SSL_dup_CA_list wolfSSL_dup_CA_list
1018
1019#define sk_X509_NAME_find wolfSSL_sk_X509_NAME_find
1020
1021#define DHparams_dup wolfSSL_DH_dup
1022#define PEM_read_bio_DHparams wolfSSL_PEM_read_bio_DHparams
1023#define PEM_read_bio_DSAparams wolfSSL_PEM_read_bio_DSAparams
1024
1025#if defined(OPENSSL_ALL) || defined(WOLFSSL_HAPROXY)
1026#define SSL_get_rbio wolfSSL_SSL_get_rbio
1027#define SSL_get_wbio wolfSSL_SSL_get_wbio
1028#define SSL_do_handshake wolfSSL_SSL_do_handshake
1029#define SSL_get_ciphers(x) wolfSSL_get_ciphers_compat(x)
1030#define SSL_SESSION_get_id wolfSSL_SESSION_get_id
1031#define SSL_get_cipher_bits(s,np) \
1032 wolfSSL_CIPHER_get_bits(SSL_get_current_cipher(s),np)
1033#define sk_SSL_CIPHER_num wolfSSL_sk_SSL_CIPHER_num
1034#define sk_SSL_COMP_zero wolfSSL_sk_SSL_COMP_zero
1035#define sk_SSL_CIPHER_value wolfSSL_sk_SSL_CIPHER_value
1036#endif /* OPENSSL_ALL || WOLFSSL_HAPROXY */
1037#define sk_SSL_CIPHER_dup wolfSSL_sk_dup
1038#define sk_SSL_CIPHER_free wolfSSL_sk_SSL_CIPHER_free
1039#define sk_SSL_CIPHER_find wolfSSL_sk_SSL_CIPHER_find
1040
1041#if defined(OPENSSL_ALL) || defined(WOLFSSL_ASIO) || defined(WOLFSSL_HAPROXY) \
1042 || defined(WOLFSSL_NGINX)
1043#include <wolfssl/openssl/pem.h>
1044
1045#define SSL_CTRL_CHAIN 88
1046#define ERR_LIB_SSL 20
1047#define SSL_R_SHORT_READ 10
1048#define ERR_R_PEM_LIB 9
1049#define SSL_CTRL_MODE 33
1050
1051#define SSL_CTRL_CLEAR_EXTRA_CHAIN_CERTS 83
1052
1053#define SSL_CTX_clear_chain_certs(ctx) SSL_CTX_set0_chain(ctx,NULL)
1054#define d2i_RSAPrivateKey_bio wolfSSL_d2i_RSAPrivateKey_bio
1055#define SSL_CTX_use_RSAPrivateKey wolfSSL_CTX_use_RSAPrivateKey
1056#define d2i_PrivateKey_bio wolfSSL_d2i_PrivateKey_bio
1057#define BIO_new_bio_pair wolfSSL_BIO_new_bio_pair
1058#define SSL_get_verify_callback wolfSSL_get_verify_callback
1059
1060#define SSL_set_mode(ssl,op) wolfSSL_ctrl((ssl),SSL_CTRL_MODE,(op),NULL)
1061
1062#define SSL_CTX_use_certificate_ASN1 wolfSSL_CTX_use_certificate_ASN1
1063#define SSL_CTX_set0_chain(ctx,sk) \
1064 wolfSSL_CTX_ctrl(ctx,SSL_CTRL_CHAIN,0,(char *)(sk))
1065#define SSL_CTX_get_app_data(ctx) wolfSSL_CTX_get_ex_data(ctx,0)
1066#define SSL_CTX_set_app_data(ctx,arg) wolfSSL_CTX_set_ex_data(ctx,0, \
1067 (char *)(arg))
1068#endif /* OPENSSL_ALL || WOLFSSL_ASIO || WOLFSSL_HAPROXY */
1069
1070#define SSL_CTX_set_tmp_dh wolfSSL_CTX_set_tmp_dh
1071
1072#define TLSEXT_STATUSTYPE_ocsp 1
1073
1074#define SSL_set_options wolfSSL_set_options
1075#define SSL_get_options wolfSSL_get_options
1076#define SSL_clear_options wolfSSL_clear_options
1077#define SSL_set_tmp_dh wolfSSL_set_tmp_dh
1078#define SSL_clear_num_renegotiations wolfSSL_clear_num_renegotiations
1079#define SSL_total_renegotiations wolfSSL_total_renegotiations
1080#define SSL_num_renegotiations wolfSSL_num_renegotiations
1081#define SSL_renegotiate wolfSSL_Rehandshake
1082#define SSL_get_secure_renegotiation_support wolfSSL_SSL_get_secure_renegotiation_support
1083#define SSL_renegotiate_pending wolfSSL_SSL_renegotiate_pending
1084#define SSL_set_tlsext_debug_arg wolfSSL_set_tlsext_debug_arg
1085#define SSL_set_tlsext_status_type wolfSSL_set_tlsext_status_type
1086#define SSL_set_tlsext_status_exts wolfSSL_set_tlsext_status_exts
1087#define SSL_get_tlsext_status_ids wolfSSL_get_tlsext_status_ids
1088#define SSL_set_tlsext_status_ids wolfSSL_set_tlsext_status_ids
1089#define SSL_get_tlsext_status_ocsp_res wolfSSL_get_tlsext_status_ocsp_resp
1090#define SSL_set_tlsext_status_ocsp_res wolfSSL_set_tlsext_status_ocsp_resp
1091#define SSL_set_tlsext_status_ocsp_resp wolfSSL_set_tlsext_status_ocsp_resp
1092#define SSL_get_tlsext_status_ocsp_resp wolfSSL_get_tlsext_status_ocsp_resp
1093
1094#define SSL_CTX_add_extra_chain_cert wolfSSL_CTX_add_extra_chain_cert
1095#define SSL_CTX_get_read_ahead wolfSSL_CTX_get_read_ahead
1096#define SSL_CTX_set_read_ahead wolfSSL_CTX_set_read_ahead
1097#define SSL_CTX_set_tlsext_status_arg wolfSSL_CTX_set_tlsext_status_arg
1098#define SSL_CTX_set_tlsext_opaque_prf_input_callback_arg \
1099 wolfSSL_CTX_set_tlsext_opaque_prf_input_callback_arg
1100#define SSL_get_server_random wolfSSL_get_server_random
1101#define SSL_get_server_tmp_key wolfSSL_get_server_tmp_key
1102
1103#define SSL_CTX_set_min_proto_version wolfSSL_CTX_set_min_proto_version
1104#define SSL_CTX_set_max_proto_version wolfSSL_CTX_set_max_proto_version
1105#define SSL_CTX_get_min_proto_version wolfSSL_CTX_get_min_proto_version
1106
1107#define SSL_get_tlsext_status_exts wolfSSL_get_tlsext_status_exts
1108
1109#define SSL_CTX_get_tlsext_ticket_keys wolfSSL_CTX_get_tlsext_ticket_keys
1110#define SSL_CTX_set_tlsext_ticket_keys wolfSSL_CTX_set_tlsext_ticket_keys
1111
1112#define SSL_CTRL_CLEAR_NUM_RENEGOTIATIONS 11
1113#define SSL_CTRL_GET_TOTAL_RENEGOTIATIONS 12
1114#define SSL_CTRL_SET_TMP_DH 3
1115#define SSL_CTRL_SET_TMP_ECDH 4
1116#define SSL_CTRL_SET_SESS_CACHE_MODE 44
1117#define SSL_CTRL_SET_TLSEXT_DEBUG_ARG 57
1118#define SSL_CTRL_SET_TLSEXT_STATUS_REQ_TYPE 65
1119#define SSL_CTRL_GET_TLSEXT_STATUS_REQ_EXTS 66
1120#define SSL_CTRL_SET_TLSEXT_STATUS_REQ_EXTS 67
1121#define SSL_CTRL_GET_TLSEXT_STATUS_REQ_IDS 68
1122#define SSL_CTRL_SET_TLSEXT_STATUS_REQ_IDS 69
1123#define SSL_CTRL_GET_TLSEXT_STATUS_REQ_OCSP_RESP 70
1124#define SSL_CTRL_SET_TLSEXT_STATUS_REQ_OCSP_RESP 71
1125#define SSL_CTRL_SET_GROUPS 91
1126#define SSL_CTRL_GET_PEER_TMP_KEY 109
1127#define SSL_CTRL_GET_SERVER_TMP_KEY SSL_CTRL_GET_PEER_TMP_KEY
1128#define SSL_CTRL_SET_MIN_PROTO_VERSION 123
1129#define SSL_CTRL_SET_MAX_PROTO_VERSION 124
1130#define SSL_CTRL_SET_CURVES SSL_CTRL_SET_GROUPS
1131
1132#define SSL_CTRL_EXTRA_CHAIN_CERT 14
1133#define SSL_CTRL_OPTIONS 32
1134
1135#define SSL_CTRL_SET_SESS_CACHE_SIZE 42
1136#define SSL_CTRL_GET_READ_AHEAD 40
1137#define SSL_CTRL_SET_READ_AHEAD 41
1138
1139#define SSL_CTRL_SET_TLSEXT_STATUS_REQ_CB 63
1140#define SSL_CTRL_SET_TLSEXT_STATUS_REQ_CB_ARG 64
1141
1142#define SSL_CTRL_GET_EXTRA_CHAIN_CERTS 82
1143#define SSL_CTRL_GET_SESSION_REUSED 0
1144
1145#define SSL_ctrl wolfSSL_ctrl
1146#define SSL_CTX_ctrl wolfSSL_CTX_ctrl
1147#define SSL_CTX_callback_ctrl wolfSSL_CTX_callback_ctrl
1148
1149#define SSL3_RANDOM_SIZE 32 /* same as RAN_LEN in internal.h */
1150
1151#define SSL2_VERSION 0x0002
1152#define SSL3_VERSION 0x0300
1153#define TLS1_VERSION 0x0301
1154#define TLS1_1_VERSION 0x0302
1155#define TLS1_2_VERSION 0x0303
1156#define TLS1_3_VERSION 0x0304
1157#define DTLS1_VERSION 0xFEFF
1158#define DTLS1_2_VERSION 0xFEFD
1159
1160#define OPENSSL_INIT_LOAD_SSL_STRINGS 0x00200000L
1161#define OPENSSL_INIT_LOAD_CRYPTO_STRINGS 0x00000002L
1162
1163#define CRYPTO_EX_INDEX_SSL 0
1164#define TLS_ANY_VERSION 0x10000
1165#define DTLS1_2_VERSION 0xFEFD
1166#define DTLS_MAX_VERSION DTLS1_2_VERSION
1167
1168/* apache and lighty use SSL_CONF_FLAG_FILE to enable conf support */
1169#if !defined(WOLFSSL_APACHE_HTTPD) && !defined(HAVE_LIGHTY)
1170#define SSL_CONF_FLAG_CMDLINE WOLFSSL_CONF_FLAG_CMDLINE
1171#define SSL_CONF_FLAG_FILE WOLFSSL_CONF_FLAG_FILE
1172#define SSL_CONF_FLAG_CERTIFICATE WOLFSSL_CONF_FLAG_CERTIFICATE
1173#define SSL_CONF_TYPE_STRING WOLFSSL_CONF_TYPE_STRING
1174#define SSL_CONF_TYPE_FILE WOLFSSL_CONF_TYPE_FILE
1175#endif
1176
1177#if defined(HAVE_STUNNEL) || defined(WOLFSSL_NGINX) || defined(OPENSSL_EXTRA) \
1178 || defined(OPENSSL_ALL)
1179#include <wolfssl/openssl/asn1.h>
1180
1181#define SSL23_ST_SR_CLNT_HELLO_A (0x210|0x2000)
1182#define SSL3_ST_SR_CLNT_HELLO_A (0x110|0x2000)
1183
1184#define SSL3_AD_BAD_CERTIFICATE bad_certificate
1185#define SSL_AD_BAD_CERTIFICATE SSL3_AD_BAD_CERTIFICATE
1186#define SSL_AD_UNRECOGNIZED_NAME unrecognized_name
1187#define SSL_AD_NO_RENEGOTIATION no_renegotiation
1188#define SSL_AD_INTERNAL_ERROR 80
1189
1190#define ASN1_STRFLGS_ESC_MSB 4
1191
1192#define SSL_MAX_MASTER_KEY_LENGTH WOLFSSL_MAX_MASTER_KEY_LENGTH
1193
1194#define SSL_alert_desc_string_long wolfSSL_alert_desc_string_long
1195#define SSL_alert_type_string_long wolfSSL_alert_type_string_long
1196#define SSL_CIPHER_get_bits wolfSSL_CIPHER_get_bits
1197#define sk_GENERAL_NAME_num wolfSSL_sk_GENERAL_NAME_num
1198#define SSL_CTX_get_options wolfSSL_CTX_get_options
1199
1200#define SSL_CTX_flush_sessions wolfSSL_flush_sessions
1201#define SSL_CTX_add_session wolfSSL_CTX_add_session
1202#define SSL_version(x) wolfSSL_version ((WOLFSSL*) (x))
1203#define SSL_get_state wolfSSL_get_state
1204#define SSL_state_string_long wolfSSL_state_string_long
1205
1206#define GENERAL_NAME_new wolfSSL_GENERAL_NAME_new
1207#define GENERAL_NAME_free wolfSSL_GENERAL_NAME_free
1208#define sk_GENERAL_NAME_push wolfSSL_sk_GENERAL_NAME_push
1209#define sk_GENERAL_NAME_value wolfSSL_sk_GENERAL_NAME_value
1210#define SSL_SESSION_get_ex_data wolfSSL_SESSION_get_ex_data
1211#define SSL_SESSION_set_ex_data wolfSSL_SESSION_set_ex_data
1212#define SSL_SESSION_get_ex_new_index wolfSSL_SESSION_get_ex_new_index
1213#define SSL_SESSION_get_id wolfSSL_SESSION_get_id
1214#define SSL_SESSION_print wolfSSL_SESSION_print
1215#define sk_GENERAL_NAME_pop_free wolfSSL_sk_GENERAL_NAME_pop_free
1216#define sk_GENERAL_NAME_free wolfSSL_sk_GENERAL_NAME_free
1217#define sk_ASN1_OBJECT_pop_free wolfSSL_sk_ASN1_OBJECT_pop_free
1218#define GENERAL_NAME_free wolfSSL_GENERAL_NAME_free
1219#define GENERAL_NAMES_free wolfSSL_GENERAL_NAMES_free
1220
1221#define AUTHORITY_INFO_ACCESS_free wolfSSL_AUTHORITY_INFO_ACCESS_free
1222#define sk_ACCESS_DESCRIPTION_pop_free wolfSSL_sk_ACCESS_DESCRIPTION_pop_free
1223#define sk_ACCESS_DESCRIPTION_free wolfSSL_sk_ACCESS_DESCRIPTION_free
1224#define ACCESS_DESCRIPTION_free wolfSSL_ACCESS_DESCRIPTION_free
1225
1226#define SSL3_AL_FATAL 2
1227#define SSL_TLSEXT_ERR_OK 0
1228#define SSL_TLSEXT_ERR_ALERT_FATAL alert_fatal
1229#define SSL_TLSEXT_ERR_ALERT_WARNING alert_warning
1230#define SSL_TLSEXT_ERR_NOACK alert_warning
1231#define TLSEXT_NAMETYPE_host_name WOLFSSL_SNI_HOST_NAME
1232
1233#define SSL_set_tlsext_host_name wolfSSL_set_tlsext_host_name
1234#define SSL_get_servername wolfSSL_get_servername
1235#define SSL_set_SSL_CTX wolfSSL_set_SSL_CTX
1236#define SSL_CTX_get_verify_callback wolfSSL_CTX_get_verify_callback
1237#define SSL_CTX_set_tlsext_servername_callback wolfSSL_CTX_set_tlsext_servername_callback
1238#define SSL_CTX_set_tlsext_servername_arg wolfSSL_CTX_set_servername_arg
1239
1240#define PSK_MAX_PSK_LEN 256
1241#define PSK_MAX_IDENTITY_LEN 128
1242#define SSL_CTX_clear_options wolfSSL_CTX_clear_options
1243
1244
1245#endif /* HAVE_STUNNEL || WOLFSSL_NGINX */
1246
1247#ifndef NO_WOLFSSL_STUB
1248#define b2i_PrivateKey_bio(...) NULL
1249#define b2i_PVK_bio(...) NULL
1250#endif
1251
1252#define SSL_CTX_get_default_passwd_cb wolfSSL_CTX_get_default_passwd_cb
1253#define SSL_CTX_get_default_passwd_cb_userdata wolfSSL_CTX_get_default_passwd_cb_userdata
1254
1255#define SSL_CTX_set_msg_callback wolfSSL_CTX_set_msg_callback
1256#define SSL_set_msg_callback wolfSSL_set_msg_callback
1257#define SSL_CTX_set_msg_callback_arg wolfSSL_CTX_set_msg_callback_arg
1258#define SSL_set_msg_callback_arg wolfSSL_set_msg_callback_arg
1259
1260#define SSL_CTX_clear_extra_chain_certs wolfSSL_CTX_clear_extra_chain_certs
1261
1262
1263/* Nginx uses this to determine if reached end of certs in file.
1264 * PEM_read_bio_X509 is called and the return error is lost.
1265 * The error that needs to be detected is: SSL_NO_PEM_HEADER.
1266 */
1267#define ERR_GET_FUNC(l) (int)((((unsigned long)l) >> 12L) & 0xfffL)
1268
1269#define PEM_F_PEM_DEF_CALLBACK 100
1270
1271/* Avoid wolfSSL error code range */
1272#define PEM_R_NO_START_LINE (-MIN_CODE_E + 1)
1273#define PEM_R_PROBLEMS_GETTING_PASSWORD (-MIN_CODE_E + 2)
1274#define PEM_R_BAD_PASSWORD_READ (-MIN_CODE_E + 3)
1275#define PEM_R_BAD_DECRYPT (-MIN_CODE_E + 4)
1276
1277#define ERR_LIB_PEM 9
1278#define ERR_LIB_X509 10
1279#define ERR_LIB_EVP 11
1280#define ERR_LIB_ASN1 12
1281
1282#if defined(WOLFSSL_NGINX) || defined(WOLFSSL_HAPROXY) || \
1283 defined(WOLFSSL_MYSQL_COMPATIBLE) || defined(OPENSSL_ALL) || \
1284 defined(HAVE_LIGHTY) || defined(HAVE_STUNNEL)
1285
1286#include <wolfssl/error-ssl.h>
1287
1288#define OPENSSL_STRING WOLFSSL_STRING
1289#define OPENSSL_CSTRING WOLFSSL_STRING
1290
1291#define TLSEXT_TYPE_application_layer_protocol_negotiation 16
1292
1293#define OPENSSL_NPN_UNSUPPORTED 0
1294#define OPENSSL_NPN_NEGOTIATED 1
1295#define OPENSSL_NPN_NO_OVERLAP 2
1296
1297/* Nginx checks these to see if the error was a handshake error. */
1298#define SSL_R_BAD_CHANGE_CIPHER_SPEC LENGTH_ERROR
1299#define SSL_R_BLOCK_CIPHER_PAD_IS_WRONG BUFFER_E
1300#define SSL_R_DIGEST_CHECK_FAILED VERIFY_MAC_ERROR
1301#define SSL_R_ERROR_IN_RECEIVED_CIPHER_LIST SUITES_ERROR
1302#define SSL_R_EXCESSIVE_MESSAGE_SIZE BUFFER_ERROR
1303#define SSL_R_LENGTH_MISMATCH LENGTH_ERROR
1304#define SSL_R_NO_CIPHERS_SPECIFIED SUITES_ERROR
1305#define SSL_R_NO_COMPRESSION_SPECIFIED COMPRESSION_ERROR
1306#define SSL_R_NO_SHARED_CIPHER MATCH_SUITE_ERROR
1307#define SSL_R_RECORD_LENGTH_MISMATCH HANDSHAKE_SIZE_ERROR
1308#define SSL_R_UNEXPECTED_MESSAGE OUT_OF_ORDER_E
1309#define SSL_R_UNEXPECTED_RECORD SANITY_MSG_E
1310#define SSL_R_UNKNOWN_ALERT_TYPE BUFFER_ERROR
1311#define SSL_R_UNKNOWN_PROTOCOL VERSION_ERROR
1312#define SSL_R_WRONG_VERSION_NUMBER VERSION_ERROR
1313#define SSL_R_DECRYPTION_FAILED_OR_BAD_RECORD_MAC ENCRYPT_ERROR
1314#define SSL_R_HTTPS_PROXY_REQUEST PARSE_ERROR
1315#define SSL_R_HTTP_REQUEST PARSE_ERROR
1316#define SSL_R_UNSUPPORTED_PROTOCOL VERSION_ERROR
1317#define SSL_R_CERTIFICATE_VERIFY_FAILED VERIFY_CERT_ERROR
1318
1319
1320#ifdef HAVE_SESSION_TICKET
1321#define SSL_OP_NO_TICKET SSL_OP_NO_TICKET
1322#define SSL_CTRL_SET_TLSEXT_TICKET_KEY_CB 72
1323#endif
1324
1325#define OPENSSL_config wolfSSL_OPENSSL_config
1326#define OPENSSL_memdup wolfSSL_OPENSSL_memdup
1327#define OPENSSL_cleanse wolfSSL_OPENSSL_cleanse
1328#define SSL_CTX_get_timeout wolfSSL_SSL_CTX_get_timeout
1329#define SSL_CTX_set_tmp_ecdh wolfSSL_SSL_CTX_set_tmp_ecdh
1330#define SSL_CTX_remove_session wolfSSL_SSL_CTX_remove_session
1331#define SSL_get_rbio wolfSSL_SSL_get_rbio
1332#define SSL_get_wbio wolfSSL_SSL_get_wbio
1333#define SSL_do_handshake wolfSSL_SSL_do_handshake
1334#define SSL_in_init wolfSSL_SSL_in_init
1335#define SSL_in_connect_init wolfSSL_SSL_in_connect_init
1336#define SSL_get0_session wolfSSL_SSL_get0_session
1337#define SSL_CTX_set_tlsext_ticket_key_cb wolfSSL_CTX_set_tlsext_ticket_key_cb
1338#define SSL_CTX_set_tlsext_status_cb wolfSSL_CTX_set_tlsext_status_cb
1339#define SSL_CTX_get_extra_chain_certs wolfSSL_CTX_get_extra_chain_certs
1340#define sk_OPENSSL_STRING_num wolfSSL_sk_WOLFSSL_STRING_num
1341#define sk_OPENSSL_STRING_value wolfSSL_sk_WOLFSSL_STRING_value
1342#define sk_OPENSSL_PSTRING_num wolfSSL_sk_WOLFSSL_STRING_num
1343#define sk_OPENSSL_PSTRING_value (WOLFSSL_STRING*)wolfSSL_sk_WOLFSSL_STRING_value
1344#define sk_OPENSSL_STRING_free wolfSSL_sk_free
1345#define SSL_get0_alpn_selected wolfSSL_get0_alpn_selected
1346#define SSL_select_next_proto wolfSSL_select_next_proto
1347#define SSL_CTX_set_alpn_select_cb wolfSSL_CTX_set_alpn_select_cb
1348#define SSL_CTX_set_next_protos_advertised_cb wolfSSL_CTX_set_next_protos_advertised_cb
1349#define SSL_CTX_set_next_proto_select_cb wolfSSL_CTX_set_next_proto_select_cb
1350#define SSL_set_alpn_protos wolfSSL_set_alpn_protos
1351#define SSL_get0_next_proto_negotiated wolfSSL_get0_next_proto_negotiated
1352#define SSL_is_server wolfSSL_is_server
1353
1354#endif /* WOLFSSL_NGINX || WOLFSSL_HAPROXY || WOLFSSL_MYSQL_COMPATIBLE ||
1355 OPENSSL_ALL || HAVE_LIGHTY */
1356
1357#if defined(OPENSSL_EXTRA) && defined(HAVE_ECC)
1358#define SSL_CTX_set1_curves_list wolfSSL_CTX_set1_curves_list
1359#define SSL_set1_curves_list wolfSSL_set1_curves_list
1360#endif
1361
1362#ifdef OPENSSL_EXTRA
1363#define SSL_CTX_add_client_CA wolfSSL_CTX_add_client_CA
1364#define SSL_CTX_set_srp_password wolfSSL_CTX_set_srp_password
1365#define SSL_CTX_set_srp_username wolfSSL_CTX_set_srp_username
1366#define SSL_CTX_set_srp_strength wolfSSL_CTX_set_srp_strength
1367#define SSL_get_SSL_CTX wolfSSL_get_SSL_CTX
1368#define SSL_get0_param wolfSSL_get0_param
1369#define SSL_CTX_get0_param wolfSSL_CTX_get0_param
1370#define SSL_CTX_set1_param wolfSSL_CTX_set1_param
1371#define SSL_get_srp_username wolfSSL_get_srp_username
1372
1373#define ERR_NUM_ERRORS 16
1374#define SN_pkcs9_emailAddress "Email"
1375#define LN_pkcs9_emailAddress "emailAddress"
1376#define NID_pkcs9_emailAddress 48
1377#define OBJ_pkcs9_emailAddress 1L,2L,840L,113539L,1L,9L,1L
1378
1379#define SSL_get_rbio wolfSSL_SSL_get_rbio
1380#define SSL_get_wbio wolfSSL_SSL_get_wbio
1381#define SSL_do_handshake wolfSSL_SSL_do_handshake
1382
1383#if defined(WOLFSSL_EARLY_DATA)
1384#define SSL_get_early_data_status wolfSSL_get_early_data_status
1385#endif
1386
1387#endif /* OPENSSL_EXTRA */
1388
1389/* cipher suites for compatibility */
1390#define TLS1_CK_ECDHE_RSA_WITH_AES_128_CBC_SHA (0xc013)
1391#define TLS1_CK_ECDHE_RSA_WITH_AES_256_CBC_SHA (0xc014)
1392#define TLS1_CK_ECDHE_RSA_WITH_AES_128_GCM_SHA256 (0xc02f)
1393#define TLS1_CK_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256 (0xcca8)
1394#define TLS1_CK_ECDHE_ECDSA_WITH_AES_128_CBC_SHA (0xc009)
1395#define TLS1_CK_ECDHE_ECDSA_WITH_AES_256_CBC_SHA (0xc00a)
1396#define TLS1_CK_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256 (0xc02b)
1397#define TLS1_CK_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256 (0xcca9)
1398
1399#define X509_STORE_get0_objects wolfSSL_X509_STORE_get0_objects
1400#define sk_X509_OBJECT_num wolfSSL_sk_X509_OBJECT_num
1401#define sk_X509_OBJECT_value wolfSSL_sk_X509_OBJECT_value
1402#define sk_X509_OBJECT_delete wolfSSL_sk_X509_OBJECT_delete
1403#define X509_OBJECT_free wolfSSL_X509_OBJECT_free
1404#define X509_OBJECT_get_type(x) 0
1405#if defined(OPENSSL_VERSION_NUMBER) && OPENSSL_VERSION_NUMBER >= 0x10100000L
1406#define OpenSSL_version(x) wolfSSL_OpenSSL_version(x)
1407#else
1408#define OpenSSL_version(x) wolfSSL_OpenSSL_version()
1409#endif
1410
1411#ifndef NO_WOLFSSL_STUB
1412#define OBJ_create_objects(...)
1413#endif
1414
1415#define SSL_set_psk_use_session_callback wolfSSL_set_psk_use_session_callback
1416#define SSL_SESSION_is_resumable wolfSSL_SESSION_is_resumable
1417typedef WOLFSSL_CONF_CTX SSL_CONF_CTX;
1418
1419#define SSL_CONF_CTX_new wolfSSL_CONF_CTX_new
1420#define SSL_CONF_CTX_free wolfSSL_CONF_CTX_free
1421#define SSL_CONF_CTX_set_ssl_ctx wolfSSL_CONF_CTX_set_ssl_ctx
1422#define SSL_CONF_CTX_set_flags wolfSSL_CONF_CTX_set_flags
1423#define SSL_CONF_CTX_finish wolfSSL_CONF_CTX_finish
1424#define SSL_CONF_cmd wolfSSL_CONF_cmd
1425
1426#ifdef __cplusplus
1427 } /* extern "C" */
1428#endif
1429
1430#endif /* wolfSSL_openssl_h__ */