ssl.h 83 KB

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