ssl.h 88 KB

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