1 | /* ssl.h
|
---|
2 | *
|
---|
3 | * Copyright (C) 2006-2015 wolfSSL Inc.
|
---|
4 | *
|
---|
5 | * This file is part of wolfSSL. (formerly known as CyaSSL)
|
---|
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 | * a with this program; if not, write to the Free Software
|
---|
19 | * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
---|
20 | */
|
---|
21 |
|
---|
22 |
|
---|
23 | /* ssl.h defines wolfssl_openssl compatibility layer
|
---|
24 | *
|
---|
25 | */
|
---|
26 |
|
---|
27 |
|
---|
28 | #ifndef WOLFSSL_OPENSSL_H_
|
---|
29 | #define WOLFSSL_OPENSSL_H_
|
---|
30 |
|
---|
31 | /* wolfssl_openssl compatibility layer */
|
---|
32 | #include <wolfssl/ssl.h>
|
---|
33 |
|
---|
34 | #ifdef __cplusplus
|
---|
35 | extern "C" {
|
---|
36 | #endif
|
---|
37 |
|
---|
38 | #ifdef _WIN32
|
---|
39 | /* wincrypt.h clashes */
|
---|
40 | #undef X509_NAME
|
---|
41 | #endif
|
---|
42 |
|
---|
43 |
|
---|
44 | typedef WOLFSSL SSL;
|
---|
45 | typedef WOLFSSL_SESSION SSL_SESSION;
|
---|
46 | typedef WOLFSSL_METHOD SSL_METHOD;
|
---|
47 | typedef WOLFSSL_CTX SSL_CTX;
|
---|
48 |
|
---|
49 | typedef WOLFSSL_X509 X509;
|
---|
50 | typedef WOLFSSL_X509_NAME X509_NAME;
|
---|
51 | typedef WOLFSSL_X509_CHAIN X509_CHAIN;
|
---|
52 |
|
---|
53 |
|
---|
54 | /* redeclare guard */
|
---|
55 | #define WOLFSSL_TYPES_DEFINED
|
---|
56 |
|
---|
57 |
|
---|
58 | typedef WOLFSSL_EVP_PKEY EVP_PKEY;
|
---|
59 | typedef WOLFSSL_RSA RSA;
|
---|
60 | typedef WOLFSSL_DSA DSA;
|
---|
61 | typedef WOLFSSL_EC_KEY EC_KEY;
|
---|
62 | typedef WOLFSSL_EC_GROUP EC_GROUP;
|
---|
63 | typedef WOLFSSL_EC_POINT EC_POINT;
|
---|
64 | typedef WOLFSSL_ECDSA_SIG ECDSA_SIG;
|
---|
65 | typedef WOLFSSL_BIO BIO;
|
---|
66 | typedef WOLFSSL_BIO_METHOD BIO_METHOD;
|
---|
67 | typedef WOLFSSL_CIPHER SSL_CIPHER;
|
---|
68 | typedef WOLFSSL_X509_LOOKUP X509_LOOKUP;
|
---|
69 | typedef WOLFSSL_X509_LOOKUP_METHOD X509_LOOKUP_METHOD;
|
---|
70 | typedef WOLFSSL_X509_CRL X509_CRL;
|
---|
71 | typedef WOLFSSL_X509_EXTENSION X509_EXTENSION;
|
---|
72 | typedef WOLFSSL_ASN1_TIME ASN1_TIME;
|
---|
73 | typedef WOLFSSL_ASN1_INTEGER ASN1_INTEGER;
|
---|
74 | typedef WOLFSSL_ASN1_OBJECT ASN1_OBJECT;
|
---|
75 | typedef WOLFSSL_ASN1_STRING ASN1_STRING;
|
---|
76 | typedef WOLFSSL_dynlock_value CRYPTO_dynlock_value;
|
---|
77 |
|
---|
78 | #define ASN1_UTCTIME WOLFSSL_ASN1_TIME
|
---|
79 |
|
---|
80 | typedef WOLFSSL_MD4_CTX MD4_CTX;
|
---|
81 | typedef WOLFSSL_COMP_METHOD COMP_METHOD;
|
---|
82 | typedef WOLFSSL_X509_STORE X509_STORE;
|
---|
83 | typedef WOLFSSL_X509_REVOKED X509_REVOKED;
|
---|
84 | typedef WOLFSSL_X509_OBJECT X509_OBJECT;
|
---|
85 | typedef WOLFSSL_X509_STORE_CTX X509_STORE_CTX;
|
---|
86 |
|
---|
87 | #define SSL_get_cipher_list(ctx,i) wolfSSL_get_cipher_list((i))
|
---|
88 | #define SSL_get_cipher_name(ctx) wolfSSL_get_cipher((ctx))
|
---|
89 | #define SSL_get_shared_ciphers(ctx,buf,len) \
|
---|
90 | strncpy(buf, "Not Implemented, SSLv2 only", len)
|
---|
91 |
|
---|
92 | /* @TODO */
|
---|
93 | #define ERR_print_errors_fp(file)
|
---|
94 |
|
---|
95 | /* at the moment only returns ok */
|
---|
96 | #define SSL_get_verify_result(ctx) X509_V_OK
|
---|
97 | #define SSL_get_verify_mode wolfSSL_SSL_get_mode
|
---|
98 | #define SSL_get_verify_depth wolfSSL_get_verify_depth
|
---|
99 | #define SSL_CTX_get_verify_mode wolfSSL_CTX_get_verify_mode
|
---|
100 | #define SSL_CTX_get_verify_depth wolfSSL_CTX_get_verify_depth
|
---|
101 | #define SSL_get_certificate(ctx) 0 /* used to pass to get_privatekey */
|
---|
102 |
|
---|
103 | #define SSLv3_server_method wolfSSLv3_server_method
|
---|
104 | #define SSLv3_client_method wolfSSLv3_client_method
|
---|
105 | #define TLSv1_server_method wolfTLSv1_server_method
|
---|
106 | #define TLSv1_client_method wolfTLSv1_client_method
|
---|
107 | #define TLSv1_1_server_method wolfTLSv1_1_server_method
|
---|
108 | #define TLSv1_1_client_method wolfTLSv1_1_client_method
|
---|
109 | #define TLSv1_2_server_method wolfTLSv1_2_server_method
|
---|
110 | #define TLSv1_2_client_method wolfTLSv1_2_client_method
|
---|
111 |
|
---|
112 | #ifdef WOLFSSL_DTLS
|
---|
113 | #define DTLSv1_client_method wolfDTLSv1_client_method
|
---|
114 | #define DTLSv1_server_method wolfDTLSv1_server_method
|
---|
115 | #define DTLSv1_2_client_method wolfDTLSv1_2_client_method
|
---|
116 | #define DTLSv1_2_server_method wolfDTLSv1_2_server_method
|
---|
117 | #endif
|
---|
118 |
|
---|
119 |
|
---|
120 | #ifndef NO_FILESYSTEM
|
---|
121 | #define SSL_CTX_use_certificate_file wolfSSL_CTX_use_certificate_file
|
---|
122 | #define SSL_CTX_use_PrivateKey_file wolfSSL_CTX_use_PrivateKey_file
|
---|
123 | #define SSL_CTX_load_verify_locations wolfSSL_CTX_load_verify_locations
|
---|
124 | #define SSL_CTX_use_certificate_chain_file wolfSSL_CTX_use_certificate_chain_file
|
---|
125 | #define SSL_CTX_use_RSAPrivateKey_file wolfSSL_CTX_use_RSAPrivateKey_file
|
---|
126 |
|
---|
127 | #define SSL_use_certificate_file wolfSSL_use_certificate_file
|
---|
128 | #define SSL_use_PrivateKey_file wolfSSL_use_PrivateKey_file
|
---|
129 | #define SSL_use_certificate_chain_file wolfSSL_use_certificate_chain_file
|
---|
130 | #define SSL_use_RSAPrivateKey_file wolfSSL_use_RSAPrivateKey_file
|
---|
131 | #endif
|
---|
132 |
|
---|
133 | #define SSL_CTX_new wolfSSL_CTX_new
|
---|
134 | #define SSL_new wolfSSL_new
|
---|
135 | #define SSL_set_fd wolfSSL_set_fd
|
---|
136 | #define SSL_get_fd wolfSSL_get_fd
|
---|
137 | #define SSL_connect wolfSSL_connect
|
---|
138 | #define SSL_clear wolfSSL_clear
|
---|
139 |
|
---|
140 | #define SSL_write wolfSSL_write
|
---|
141 | #define SSL_read wolfSSL_read
|
---|
142 | #define SSL_peek wolfSSL_peek
|
---|
143 | #define SSL_accept wolfSSL_accept
|
---|
144 | #define SSL_CTX_free wolfSSL_CTX_free
|
---|
145 | #define SSL_free wolfSSL_free
|
---|
146 | #define SSL_shutdown wolfSSL_shutdown
|
---|
147 |
|
---|
148 | #define SSL_CTX_set_quiet_shutdown wolfSSL_CTX_set_quiet_shutdown
|
---|
149 | #define SSL_set_quiet_shutdown wolfSSL_set_quiet_shutdown
|
---|
150 | #define SSL_get_error wolfSSL_get_error
|
---|
151 | #define SSL_set_session wolfSSL_set_session
|
---|
152 | #define SSL_get_session wolfSSL_get_session
|
---|
153 | #define SSL_flush_sessions wolfSSL_flush_sessions
|
---|
154 | /* assume unlimited temporarly */
|
---|
155 | #define SSL_CTX_get_session_cache_mode(ctx) 0
|
---|
156 |
|
---|
157 | #define SSL_CTX_set_verify wolfSSL_CTX_set_verify
|
---|
158 | #define SSL_set_verify wolfSSL_set_verify
|
---|
159 | #define SSL_pending wolfSSL_pending
|
---|
160 | #define SSL_load_error_strings wolfSSL_load_error_strings
|
---|
161 | #define SSL_library_init wolfSSL_library_init
|
---|
162 | #define SSL_CTX_set_session_cache_mode wolfSSL_CTX_set_session_cache_mode
|
---|
163 | #define SSL_CTX_set_cipher_list wolfSSL_CTX_set_cipher_list
|
---|
164 | #define SSL_set_cipher_list wolfSSL_set_cipher_list
|
---|
165 |
|
---|
166 | #define ERR_error_string wolfSSL_ERR_error_string
|
---|
167 | #define ERR_error_string_n wolfSSL_ERR_error_string_n
|
---|
168 | #define ERR_reason_error_string wolfSSL_ERR_reason_error_string
|
---|
169 |
|
---|
170 | #define SSL_set_ex_data wolfSSL_set_ex_data
|
---|
171 | #define SSL_get_shutdown wolfSSL_get_shutdown
|
---|
172 | #define SSL_set_rfd wolfSSL_set_rfd
|
---|
173 | #define SSL_set_wfd wolfSSL_set_wfd
|
---|
174 | #define SSL_set_shutdown wolfSSL_set_shutdown
|
---|
175 | #define SSL_set_session_id_context wolfSSL_set_session_id_context
|
---|
176 | #define SSL_set_connect_state wolfSSL_set_connect_state
|
---|
177 | #define SSL_set_accept_state wolfSSL_set_accept_state
|
---|
178 | #define SSL_session_reused wolfSSL_session_reused
|
---|
179 | #define SSL_SESSION_free wolfSSL_SESSION_free
|
---|
180 | #define SSL_is_init_finished wolfSSL_is_init_finished
|
---|
181 |
|
---|
182 | #define SSL_get_version wolfSSL_get_version
|
---|
183 | #define SSL_get_current_cipher wolfSSL_get_current_cipher
|
---|
184 | #define SSL_get_cipher wolfSSL_get_cipher
|
---|
185 | #define SSL_CIPHER_description wolfSSL_CIPHER_description
|
---|
186 | #define SSL_CIPHER_get_name wolfSSL_CIPHER_get_name
|
---|
187 | #define SSL_get1_session wolfSSL_get1_session
|
---|
188 |
|
---|
189 | #define SSL_get_keyblock_size wolfSSL_get_keyblock_size
|
---|
190 | #define SSL_get_keys wolfSSL_get_keys
|
---|
191 |
|
---|
192 | #define X509_free wolfSSL_X509_free
|
---|
193 | #define OPENSSL_free wolfSSL_OPENSSL_free
|
---|
194 |
|
---|
195 | #define OCSP_parse_url wolfSSL_OCSP_parse_url
|
---|
196 | #define SSLv23_client_method wolfSSLv23_client_method
|
---|
197 | #define SSLv2_client_method wolfSSLv2_client_method
|
---|
198 | #define SSLv2_server_method wolfSSLv2_server_method
|
---|
199 |
|
---|
200 | #define MD4_Init wolfSSL_MD4_Init
|
---|
201 | #define MD4_Update wolfSSL_MD4_Update
|
---|
202 | #define MD4_Final wolfSSL_MD4_Final
|
---|
203 |
|
---|
204 | #define BIO_new wolfSSL_BIO_new
|
---|
205 | #define BIO_free wolfSSL_BIO_free
|
---|
206 | #define BIO_free_all wolfSSL_BIO_free_all
|
---|
207 | #define BIO_read wolfSSL_BIO_read
|
---|
208 | #define BIO_write wolfSSL_BIO_write
|
---|
209 | #define BIO_push wolfSSL_BIO_push
|
---|
210 | #define BIO_pop wolfSSL_BIO_pop
|
---|
211 | #define BIO_flush wolfSSL_BIO_flush
|
---|
212 | #define BIO_pending wolfSSL_BIO_pending
|
---|
213 |
|
---|
214 | #define BIO_get_mem_data wolfSSL_BIO_get_mem_data
|
---|
215 | #define BIO_new_mem_buf wolfSSL_BIO_new_mem_buf
|
---|
216 |
|
---|
217 | #define BIO_f_buffer wolfSSL_BIO_f_buffer
|
---|
218 | #define BIO_set_write_buffer_size wolfSSL_BIO_set_write_buffer_size
|
---|
219 | #define BIO_f_ssl wolfSSL_BIO_f_ssl
|
---|
220 | #define BIO_new_socket wolfSSL_BIO_new_socket
|
---|
221 | #define SSL_set_bio wolfSSL_set_bio
|
---|
222 | #define BIO_eof wolfSSL_BIO_eof
|
---|
223 | #define BIO_set_ss wolfSSL_BIO_set_ss
|
---|
224 |
|
---|
225 | #define BIO_s_mem wolfSSL_BIO_s_mem
|
---|
226 | #define BIO_f_base64 wolfSSL_BIO_f_base64
|
---|
227 | #define BIO_set_flags wolfSSL_BIO_set_flags
|
---|
228 |
|
---|
229 | #define OpenSSL_add_all_algorithms wolfSSL_add_all_algorithms
|
---|
230 | #define SSLeay_add_ssl_algorithms wolfSSL_add_all_algorithms
|
---|
231 | #define SSLeay_add_all_algorithms wolfSSL_add_all_algorithms
|
---|
232 |
|
---|
233 | #define RAND_screen wolfSSL_RAND_screen
|
---|
234 | #define RAND_file_name wolfSSL_RAND_file_name
|
---|
235 | #define RAND_write_file wolfSSL_RAND_write_file
|
---|
236 | #define RAND_load_file wolfSSL_RAND_load_file
|
---|
237 | #define RAND_egd wolfSSL_RAND_egd
|
---|
238 | #define RAND_seed wolfSSL_RAND_seed
|
---|
239 | #define RAND_add wolfSSL_RAND_add
|
---|
240 |
|
---|
241 | #define COMP_zlib wolfSSL_COMP_zlib
|
---|
242 | #define COMP_rle wolfSSL_COMP_rle
|
---|
243 | #define SSL_COMP_add_compression_method wolfSSL_COMP_add_compression_method
|
---|
244 |
|
---|
245 | #define SSL_get_ex_new_index wolfSSL_get_ex_new_index
|
---|
246 |
|
---|
247 | #define CRYPTO_set_id_callback wolfSSL_set_id_callback
|
---|
248 | #define CRYPTO_set_locking_callback wolfSSL_set_locking_callback
|
---|
249 | #define CRYPTO_set_dynlock_create_callback wolfSSL_set_dynlock_create_callback
|
---|
250 | #define CRYPTO_set_dynlock_lock_callback wolfSSL_set_dynlock_lock_callback
|
---|
251 | #define CRYPTO_set_dynlock_destroy_callback wolfSSL_set_dynlock_destroy_callback
|
---|
252 | #define CRYPTO_num_locks wolfSSL_num_locks
|
---|
253 |
|
---|
254 | #define X509_STORE_CTX_get_current_cert wolfSSL_X509_STORE_CTX_get_current_cert
|
---|
255 | #define X509_STORE_CTX_get_error wolfSSL_X509_STORE_CTX_get_error
|
---|
256 | #define X509_STORE_CTX_get_error_depth wolfSSL_X509_STORE_CTX_get_error_depth
|
---|
257 |
|
---|
258 | #define X509_NAME_oneline wolfSSL_X509_NAME_oneline
|
---|
259 | #define X509_get_issuer_name wolfSSL_X509_get_issuer_name
|
---|
260 | #define X509_get_subject_name wolfSSL_X509_get_subject_name
|
---|
261 | #define X509_verify_cert_error_string wolfSSL_X509_verify_cert_error_string
|
---|
262 |
|
---|
263 | #define X509_LOOKUP_add_dir wolfSSL_X509_LOOKUP_add_dir
|
---|
264 | #define X509_LOOKUP_load_file wolfSSL_X509_LOOKUP_load_file
|
---|
265 | #define X509_LOOKUP_hash_dir wolfSSL_X509_LOOKUP_hash_dir
|
---|
266 | #define X509_LOOKUP_file wolfSSL_X509_LOOKUP_file
|
---|
267 |
|
---|
268 | #define X509_STORE_add_lookup wolfSSL_X509_STORE_add_lookup
|
---|
269 | #define X509_STORE_new wolfSSL_X509_STORE_new
|
---|
270 | #define X509_STORE_get_by_subject wolfSSL_X509_STORE_get_by_subject
|
---|
271 | #define X509_STORE_CTX_init wolfSSL_X509_STORE_CTX_init
|
---|
272 | #define X509_STORE_CTX_cleanup wolfSSL_X509_STORE_CTX_cleanup
|
---|
273 |
|
---|
274 | #define X509_CRL_get_lastUpdate wolfSSL_X509_CRL_get_lastUpdate
|
---|
275 | #define X509_CRL_get_nextUpdate wolfSSL_X509_CRL_get_nextUpdate
|
---|
276 |
|
---|
277 | #define X509_get_pubkey wolfSSL_X509_get_pubkey
|
---|
278 | #define X509_CRL_verify wolfSSL_X509_CRL_verify
|
---|
279 | #define X509_STORE_CTX_set_error wolfSSL_X509_STORE_CTX_set_error
|
---|
280 | #define X509_OBJECT_free_contents wolfSSL_X509_OBJECT_free_contents
|
---|
281 | #define EVP_PKEY_free wolfSSL_EVP_PKEY_free
|
---|
282 | #define X509_cmp_current_time wolfSSL_X509_cmp_current_time
|
---|
283 | #define sk_X509_REVOKED_num wolfSSL_sk_X509_REVOKED_num
|
---|
284 | #define X509_CRL_get_REVOKED wolfSSL_X509_CRL_get_REVOKED
|
---|
285 | #define sk_X509_REVOKED_value wolfSSL_sk_X509_REVOKED_value
|
---|
286 | #define X509_get_notBefore(cert) (ASN1_TIME*)wolfSSL_X509_notBefore((cert))
|
---|
287 | #define X509_get_notAfter(cert) (ASN1_TIME*)wolfSSL_X509_notAfter((cert))
|
---|
288 |
|
---|
289 |
|
---|
290 | #define X509_get_serialNumber wolfSSL_X509_get_serialNumber
|
---|
291 |
|
---|
292 | #define ASN1_TIME_print wolfSSL_ASN1_TIME_print
|
---|
293 |
|
---|
294 | #define ASN1_INTEGER_cmp wolfSSL_ASN1_INTEGER_cmp
|
---|
295 | #define ASN1_INTEGER_get wolfSSL_ASN1_INTEGER_get
|
---|
296 |
|
---|
297 | #define SSL_load_client_CA_file wolfSSL_load_client_CA_file
|
---|
298 |
|
---|
299 | #define SSL_CTX_set_client_CA_list wolfSSL_CTX_set_client_CA_list
|
---|
300 | #define X509_STORE_CTX_get_ex_data wolfSSL_X509_STORE_CTX_get_ex_data
|
---|
301 | #define SSL_get_ex_data_X509_STORE_CTX_idx wolfSSL_get_ex_data_X509_STORE_CTX_idx
|
---|
302 | #define SSL_get_ex_data wolfSSL_get_ex_data
|
---|
303 |
|
---|
304 | #define SSL_CTX_set_default_passwd_cb_userdata wolfSSL_CTX_set_default_passwd_cb_userdata
|
---|
305 | #define SSL_CTX_set_default_passwd_cb wolfSSL_CTX_set_default_passwd_cb
|
---|
306 |
|
---|
307 | #define SSL_CTX_set_timeout(ctx, to) wolfSSL_CTX_set_timeout(ctx, (unsigned int) to)
|
---|
308 | #define SSL_CTX_set_info_callback wolfSSL_CTX_set_info_callback
|
---|
309 |
|
---|
310 | #define ERR_peek_error wolfSSL_ERR_peek_error
|
---|
311 | #define ERR_GET_REASON wolfSSL_ERR_GET_REASON
|
---|
312 |
|
---|
313 | #define SSL_alert_type_string wolfSSL_alert_type_string
|
---|
314 | #define SSL_alert_desc_string wolfSSL_alert_desc_string
|
---|
315 | #define SSL_state_string wolfSSL_state_string
|
---|
316 |
|
---|
317 | #define RSA_free wolfSSL_RSA_free
|
---|
318 | #define RSA_generate_key wolfSSL_RSA_generate_key
|
---|
319 | #define SSL_CTX_set_tmp_rsa_callback wolfSSL_CTX_set_tmp_rsa_callback
|
---|
320 |
|
---|
321 | #define PEM_def_callback wolfSSL_PEM_def_callback
|
---|
322 |
|
---|
323 | #define SSL_CTX_sess_accept wolfSSL_CTX_sess_accept
|
---|
324 | #define SSL_CTX_sess_connect wolfSSL_CTX_sess_connect
|
---|
325 | #define SSL_CTX_sess_accept_good wolfSSL_CTX_sess_accept_good
|
---|
326 | #define SSL_CTX_sess_connect_good wolfSSL_CTX_sess_connect_good
|
---|
327 | #define SSL_CTX_sess_accept_renegotiate wolfSSL_CTX_sess_accept_renegotiate
|
---|
328 | #define SSL_CTX_sess_connect_renegotiate wolfSSL_CTX_sess_connect_renegotiate
|
---|
329 | #define SSL_CTX_sess_hits wolfSSL_CTX_sess_hits
|
---|
330 | #define SSL_CTX_sess_cb_hits wolfSSL_CTX_sess_cb_hits
|
---|
331 | #define SSL_CTX_sess_cache_full wolfSSL_CTX_sess_cache_full
|
---|
332 | #define SSL_CTX_sess_misses wolfSSL_CTX_sess_misses
|
---|
333 | #define SSL_CTX_sess_timeouts wolfSSL_CTX_sess_timeouts
|
---|
334 | #define SSL_CTX_sess_number wolfSSL_CTX_sess_number
|
---|
335 | #define SSL_CTX_sess_get_cache_size wolfSSL_CTX_sess_get_cache_size
|
---|
336 |
|
---|
337 |
|
---|
338 | #define SSL_DEFAULT_CIPHER_LIST WOLFSSL_DEFAULT_CIPHER_LIST
|
---|
339 | #define RSA_F4 WOLFSSL_RSA_F4
|
---|
340 |
|
---|
341 | #define SSL_CTX_set_psk_client_callback wolfSSL_CTX_set_psk_client_callback
|
---|
342 | #define SSL_set_psk_client_callback wolfSSL_set_psk_client_callback
|
---|
343 |
|
---|
344 | #define SSL_get_psk_identity_hint wolfSSL_get_psk_identity_hint
|
---|
345 | #define SSL_get_psk_identity wolfSSL_get_psk_identity
|
---|
346 |
|
---|
347 | #define SSL_CTX_use_psk_identity_hint wolfSSL_CTX_use_psk_identity_hint
|
---|
348 | #define SSL_use_psk_identity_hint wolfSSL_use_psk_identity_hint
|
---|
349 |
|
---|
350 | #define SSL_CTX_set_psk_server_callback wolfSSL_CTX_set_psk_server_callback
|
---|
351 | #define SSL_set_psk_server_callback wolfSSL_set_psk_server_callback
|
---|
352 |
|
---|
353 | #define ERR_get_error_line_data wolfSSL_ERR_get_error_line_data
|
---|
354 |
|
---|
355 | #define ERR_get_error wolfSSL_ERR_get_error
|
---|
356 | #define ERR_clear_error wolfSSL_ERR_clear_error
|
---|
357 |
|
---|
358 | #define RAND_status wolfSSL_RAND_status
|
---|
359 | #define RAND_bytes wolfSSL_RAND_bytes
|
---|
360 | #define SSLv23_server_method wolfSSLv23_server_method
|
---|
361 | #define SSL_CTX_set_options wolfSSL_CTX_set_options
|
---|
362 | #define SSL_CTX_check_private_key wolfSSL_CTX_check_private_key
|
---|
363 |
|
---|
364 | #define ERR_free_strings wolfSSL_ERR_free_strings
|
---|
365 | #define ERR_remove_state wolfSSL_ERR_remove_state
|
---|
366 | #define EVP_cleanup wolfSSL_EVP_cleanup
|
---|
367 |
|
---|
368 | #define CRYPTO_cleanup_all_ex_data wolfSSL_cleanup_all_ex_data
|
---|
369 | #define SSL_CTX_set_mode wolfSSL_CTX_set_mode
|
---|
370 | #define SSL_CTX_get_mode wolfSSL_CTX_get_mode
|
---|
371 | #define SSL_CTX_set_default_read_ahead wolfSSL_CTX_set_default_read_ahead
|
---|
372 |
|
---|
373 | #define SSL_CTX_sess_set_cache_size wolfSSL_CTX_sess_set_cache_size
|
---|
374 | #define SSL_CTX_set_default_verify_paths wolfSSL_CTX_set_default_verify_paths
|
---|
375 |
|
---|
376 | #define SSL_CTX_set_session_id_context wolfSSL_CTX_set_session_id_context
|
---|
377 | #define SSL_get_peer_certificate wolfSSL_get_peer_certificate
|
---|
378 |
|
---|
379 | #define SSL_want_read wolfSSL_want_read
|
---|
380 | #define SSL_want_write wolfSSL_want_write
|
---|
381 |
|
---|
382 | #define BIO_prf wolfSSL_BIO_prf
|
---|
383 | #define ASN1_UTCTIME_pr wolfSSL_ASN1_UTCTIME_pr
|
---|
384 |
|
---|
385 | #define sk_num wolfSSL_sk_num
|
---|
386 | #define sk_value wolfSSL_sk_value
|
---|
387 |
|
---|
388 | #define SSL_CTX_get_ex_data wolfSSL_CTX_get_ex_data
|
---|
389 | #define SSL_CTX_set_ex_data wolfSSL_CTX_set_ex_data
|
---|
390 | #define SSL_CTX_sess_set_get_cb wolfSSL_CTX_sess_set_get_cb
|
---|
391 | #define SSL_CTX_sess_set_new_cb wolfSSL_CTX_sess_set_new_cb
|
---|
392 | #define SSL_CTX_sess_set_remove_cb wolfSSL_CTX_sess_set_remove_cb
|
---|
393 |
|
---|
394 | #define i2d_SSL_SESSION wolfSSL_i2d_SSL_SESSION
|
---|
395 | #define d2i_SSL_SESSION wolfSSL_d2i_SSL_SESSION
|
---|
396 | #define SSL_SESSION_set_timeout wolfSSL_SSL_SESSION_set_timeout
|
---|
397 | #define SSL_SESSION_get_timeout wolfSSL_SESSION_get_timeout
|
---|
398 | #define SSL_SESSION_get_time wolfSSL_SESSION_get_time
|
---|
399 | #define SSL_CTX_get_ex_new_index wolfSSL_CTX_get_ex_new_index
|
---|
400 |
|
---|
401 | /* yassl had set the default to be 500 */
|
---|
402 | #define SSL_get_default_timeout(ctx) 500
|
---|
403 |
|
---|
404 | /* Lighthttp compatability */
|
---|
405 |
|
---|
406 | #ifdef HAVE_LIGHTY
|
---|
407 | typedef WOLFSSL_X509_NAME_ENTRY X509_NAME_ENTRY;
|
---|
408 |
|
---|
409 | #define SSL_CB_HANDSHAKE_START 0x10
|
---|
410 | #define X509_NAME_free wolfSSL_X509_NAME_free
|
---|
411 | #define SSL_CTX_use_certificate wolfSSL_CTX_use_certificate
|
---|
412 | #define SSL_CTX_use_PrivateKey wolfSSL_CTX_use_PrivateKey
|
---|
413 | #define BIO_read_filename wolfSSL_BIO_read_filename
|
---|
414 | #define BIO_s_file wolfSSL_BIO_s_file
|
---|
415 | #define OBJ_nid2sn wolf_OBJ_nid2sn
|
---|
416 | #define OBJ_obj2nid wolf_OBJ_obj2nid
|
---|
417 | #define OBJ_sn2nid wolf_OBJ_sn2nid
|
---|
418 | #define PEM_read_bio_X509 PEM_read_bio_WOLFSSL_X509
|
---|
419 | #define SSL_CTX_set_verify_depth wolfSSL_CTX_set_verify_depth
|
---|
420 | #define SSL_get_app_data wolfSSL_get_app_data
|
---|
421 | #define SSL_set_app_data wolfSSL_set_app_data
|
---|
422 | #define X509_NAME_entry_count wolfSSL_X509_NAME_entry_count
|
---|
423 | #define X509_NAME_ENTRY_get_object wolfSSL_X509_NAME_ENTRY_get_object
|
---|
424 | #define X509_NAME_get_entry wolfSSL_X509_NAME_get_entry
|
---|
425 | #define sk_X509_NAME_pop_free wolfSSL_sk_X509_NAME_pop_free
|
---|
426 | #define SHA1 wolfSSL_SHA1
|
---|
427 | #define X509_check_private_key wolfSSL_X509_check_private_key
|
---|
428 | #define SSL_dup_CA_list wolfSSL_dup_CA_list
|
---|
429 |
|
---|
430 | #endif
|
---|
431 |
|
---|
432 | #if defined(HAVE_STUNNEL) || defined(HAVE_LIGHTY)
|
---|
433 |
|
---|
434 | #define PEM_read_bio_DHparams wolfSSL_PEM_read_bio_DHparams
|
---|
435 | #define PEM_write_bio_X509 PEM_write_bio_WOLFSSL_X509
|
---|
436 | #define SSL_CTX_set_tmp_dh wolfSSL_CTX_set_tmp_dh
|
---|
437 | #define BIO_new_file wolfSSL_BIO_new_file
|
---|
438 |
|
---|
439 |
|
---|
440 | #endif /* HAVE_STUNNEL || HAVE_LIGHTY */
|
---|
441 |
|
---|
442 | #ifdef HAVE_STUNNEL
|
---|
443 | #include <wolfssl/openssl/asn1.h>
|
---|
444 |
|
---|
445 | /* defined as: (SSL_ST_ACCEPT|SSL_CB_LOOP), which becomes 0x2001*/
|
---|
446 | #define SSL_CB_ACCEPT_LOOP 0x2001
|
---|
447 | #define SSL2_VERSION 0x0002
|
---|
448 | #define SSL3_VERSION 0x0300
|
---|
449 | #define TLS1_VERSION 0x0301
|
---|
450 | #define DTLS1_VERSION 0xFEFF
|
---|
451 | #define SSL23_ST_SR_CLNT_HELLO_A (0x210|0x2000)
|
---|
452 | #define SSL3_ST_SR_CLNT_HELLO_A (0x110|0x2000)
|
---|
453 | #define ASN1_STRFLGS_ESC_MSB 4
|
---|
454 | #define X509_V_ERR_CERT_REJECTED 28
|
---|
455 |
|
---|
456 | #define SSL_alert_desc_string_long wolfSSL_alert_desc_string_long
|
---|
457 | #define SSL_alert_type_string_long wolfSSL_alert_type_string_long
|
---|
458 | #define SSL_CIPHER_get_bits wolfSSL_CIPHER_get_bits
|
---|
459 | #define sk_X509_NAME_num wolfSSL_sk_X509_NAME_num
|
---|
460 | #define sk_X509_num wolfSSL_sk_X509_num
|
---|
461 | #define X509_NAME_print_ex wolfSSL_X509_NAME_print_ex
|
---|
462 | #define X509_get0_pubkey_bitstr wolfSSL_X509_get0_pubkey_bitstr
|
---|
463 | #define SSL_CTX_get_options wolfSSL_CTX_get_options
|
---|
464 |
|
---|
465 | #define SSL_CTX_flush_sessions wolfSSL_flush_sessions
|
---|
466 | #define SSL_CTX_add_session wolfSSL_CTX_add_session
|
---|
467 | #define SSL_get_SSL_CTX wolfSSL_get_SSL_CTX
|
---|
468 | #define SSL_version wolfSSL_version
|
---|
469 | #define SSL_get_state wolfSSL_get_state
|
---|
470 | #define SSL_state_string_long wolfSSL_state_string_long
|
---|
471 | #define SSL_get_peer_cert_chain wolfSSL_get_peer_cert_chain
|
---|
472 | #define sk_X509_NAME_value wolfSSL_sk_X509_NAME_value
|
---|
473 | #define sk_X509_value wolfSSL_sk_X509_value
|
---|
474 | #define SSL_SESSION_get_ex_data wolfSSL_SESSION_get_ex_data
|
---|
475 | #define SSL_SESSION_set_ex_data wolfSSL_SESSION_set_ex_data
|
---|
476 | #define SSL_SESSION_get_ex_new_index wolfSSL_SESSION_get_ex_new_index
|
---|
477 | #define SSL_SESSION_get_id wolfSSL_SESSION_get_id
|
---|
478 | #define CRYPTO_dynlock_value WOLFSSL_dynlock_value
|
---|
479 | typedef WOLFSSL_ASN1_BIT_STRING ASN1_BIT_STRING;
|
---|
480 |
|
---|
481 | #define SSL_TLSEXT_ERR_OK 0
|
---|
482 | #define SSL_TLSEXT_ERR_ALERT_FATAL alert_fatal
|
---|
483 | #define SSL_TLSEXT_ERR_NOACK alert_warning
|
---|
484 | #define TLSEXT_NAMETYPE_host_name WOLFSSL_SNI_HOST_NAME
|
---|
485 |
|
---|
486 | #define SSL_set_tlsext_host_name wolfSSL_set_tlsext_host_name
|
---|
487 | #define SSL_get_servername wolfSSL_get_servername
|
---|
488 | #define SSL_set_SSL_CTX wolfSSL_set_SSL_CTX
|
---|
489 | #define SSL_CTX_get_verify_callback wolfSSL_CTX_get_verify_callback
|
---|
490 | #define SSL_CTX_set_tlsext_servername_callback wolfSSL_CTX_set_servername_callback
|
---|
491 | #define SSL_CTX_set_tlsext_servername_arg wolfSSL_CTX_set_servername_arg
|
---|
492 |
|
---|
493 | #define PSK_MAX_PSK_LEN 256
|
---|
494 | #define PSK_MAX_IDENTITY_LEN 128
|
---|
495 |
|
---|
496 |
|
---|
497 | #endif /* HAVE_STUNNEL */
|
---|
498 |
|
---|
499 | #ifdef __cplusplus
|
---|
500 | } /* extern "C" */
|
---|
501 | #endif
|
---|
502 |
|
---|
503 |
|
---|
504 | #endif /* wolfSSL_openssl_h__ */
|
---|