wolfssl/cyassl/ssl.h

313 lines
13 KiB
C
Raw Normal View History

2014-12-17 20:00:17 +03:00
/* cyassl.h
*
2014-04-12 01:58:58 +04:00
* Copyright (C) 2006-2014 wolfSSL Inc.
*
* This file is part of CyaSSL.
*
* CyaSSL is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* CyaSSL is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
2014-12-17 20:00:17 +03:00
* a with this program; if not, write to the Free Software
2014-04-12 01:58:58 +04:00
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*/
2014-12-17 20:00:17 +03:00
/*
* cyassl.h defines cyassl compatibility layer
*/
2012-05-22 01:13:11 +04:00
2014-12-17 20:00:17 +03:00
#ifndef WOLFSSL_CYASSL_H_
#define WOLFSSL_CYASSL_H_
2014-12-17 20:00:17 +03:00
/*
* Name change
* include the new ssl.h
*/
#include <wolfssl/ssl.h>
#ifdef __cplusplus
extern "C" {
#endif
2014-12-17 20:00:17 +03:00
#ifdef _WIN32
/* wincrypt.h clashes */
#undef X509_NAME
#endif
// typedef CYASSL WOLFSSL;
// typedef CYASSL_SESSION WOLFSSL_SESSION;
// typedef CYASSL_METHOD WOLFSSL_METHOD;
// typedef CYASSL_CTX WOLFSSL_CTX;
// typedef CYASSL_X509 WOLFSSL_X509;
// typedef CYASSL_X509_NAME WOLFSSL_X509_NAME;
// typedef CYASSL_X509_CHAIN WOLFSSL_X509_CHAIN;
2014-12-17 20:29:35 +03:00
/* redeclare guard */
2014-12-17 20:00:17 +03:00
// #define CYASSL_TYPES_DEFINED
// typedef CYASSL_EVP_PKEY WOLFSSL_EVP_PKEY;
// typedef CYASSL_RSA WOLFSSL_RSA;
// typedef CYASSL_DSA WOLFSSL_DSA;
// typedef CYASSL_BIO WOLFSSL_BIO;
// typedef CYASSL_BIO_METHOD WOLFSSL_BIO_METHOD;
// typedef CYASSL_CIPHER WOLFSSL_SSL_CIPHER;
// typedef CYASSL_X509_LOOKUP WOLFSSL_X509_LOOKUP;
// typedef CYASSL_X509_CRL WOLFSSL_X509_CRL;
// typedef CYASSL_X509_EXTENSION WOLFSSL_X509_EXTENSION;
// typedef CYASSL_ASN1_TIME WOLFSSL_ASN1_TIME;
// typedef CYASSL_ASN1_INTEGER WOLFSSL_ASN1_INTEGER;
// typedef CYASSL_ASN1_OBJECT WOLFSSL_ASN1_OBJECT;
// typedef CYASSL_ASN1_STRING WOLFSSL_ASN1_STRING;
// typedef CYASSL_dynlock_value WOLFSSL_dynlock_value;
// typedef CYASSL_X509_LOOKUP_METHOD WOLFSSL_X509_LOOKUP_METHOD;
// #define ASN1_UTCTIME CYASSL_ASN1_TIME
// typedef CYASSL_MD4_CTX WOLFSSL_MD4_CTX;
// typedef CYASSL_COMP_METHOD WOLFSSL_COMP_METHOD;
// typedef CYASSL_X509_STORE WOLFSSL_X509_STORE;
// typedef CYASSL_X509_REVOKED WOLFSSL_X509_REVOKED;
// typedef CYASSL_X509_OBJECT WOLFSSL_X509_OBJECT;
// typedef CYASSL_X509_STORE_CTX WOLFSSL_X509_STORE_CTX;
/* Initialization and Shutdown */
// #define CyaSSL_Init wolfSSL_Init
// #define CyaSSL_library_init wolfSSL_library_init
// #define CyaSSL_Cleanup wolfSSL_Cleanup
// #define CyaSSL_shutdown wolfSSL_shutdown
2014-12-17 20:29:35 +03:00
/* Certs and keys */
2014-12-17 20:00:17 +03:00
// #define CyaSSL_CTX_load_verify_buffer wolfSSL_CTX_load_verify_buffer
// #define CyaSSL_CTX_use_PrivateKey_buffer wolfSSL_CTX_use_PrivateKey_buffer
// #define CyaSSL_CTX_use_PrivateKey_buffer wolfSSL_CTX_use_PrivateKey_buffer
// #define CyaSSL_CTX_use_PrivateKey_file wolfSSL_CTX_use_PrivateKey_file
// #define CyaSSL_CTX_use_certificate_buffer wolfSSL_CTX_use_certificate_buffer
// #define CyaSSL_CTX_use_certificate_chain_buffer wolfSSL_CTX_use_certificate_chain_buffer
// #define CyaSSL_CTX_use_certificate_chain_file wolfSSL_CTX_use_certificate_chain_file
// #define CyaSSL_CTX_use_certificate_file wolfSSL_CTX_use_certificate_file
// #define CyaSSL_SetTmpDH wolfSSL_SetTmpDH
// #define CyaSSL_use_PrivateKey_buffer wolfSSL_use_PrivateKey_buffer
// #define CyaSSL_use_certificate_buffer wolfSSL_use_certificate_buffer
// #define CyaSSL_use_certificate_chain_buffer wolfSSL_use_certificate_chain_buffer
// #define CyaSSL_CTX_der_load_verify_locations wolfSSL_CTX_der_load_verify_locations
// #define CyaSSL_CTX_use_NTRUPrivateKey_file wolfSSL_CTX_use_NTRUPrivateKey_file
// #define CyaSSL_KeepArrays wolfSSL_KeepArrays
// #define CyaSSL_FreeArrays wolfSSL_FreeArrays
/* Context and Session Setup*/
#define CyaSSLv3_client_method wolfSSLv3_client_method
#define CyaSSLv3_server_method wolfSSLv3_server_method
// #define CyaSSLv23_client_method wolfSSLv23_client_method
// #define CyaSSLv23_server_method wolfSSLv23_server_method
#define CyaTLSv1_client_method wolfTLSv1_client_method
#define CyaTLSv1_server_method wolfTLSv1_server_method
#define CyaTLSv1_1_client_method wolfTLSv1_1_client_method
#define CyaTLSv1_1_server_method wolfTLSv1_1_server_method
#define CyaTLSv1_2_client_method wolfTLSv1_2_client_method
#define CyaTLSv1_2_server_method wolfTLSv1_2_server_method
#define CyaDTLSv1_client_method wolfDTLSv1_client_method
#define CyaDTLSv1_server_method wolfDTLSv1_server_method
#define CyaDTLSv1_2_client_method wolfDTLSv1_2_client_method
#define CyaDTLSv1_2_server_method wolfDTLSv1_2_server_method
// #define CyaSSL_new wolfSSL_new
// #define CyaSSL_free wolfSSL_free
// #define CyaSSL_CTX_new wolfSSL_CTX_new
// #define CyaSSL_CTX_free wolfSSL_CTX_free
// #define CyaSSL_SetVersion wolfSSL_SetVersion
// #define CyaSSL_check_domain_name wolfSSL_check_domain_name
// #define CyaSSL_set_cipher_list wolfSSL_set_cipher_list
// #define CyaSSL_CTX_set_cipher_list wolfSSL_CTX_set_cipher_list
// #define CyaSSL_set_compression wolfSSL_set_compression
// #define CyaSSL_set_fd wolfSSL_set_fd
// #define CyaSSL_set_group_messages wolfSSL_set_group_messages
// #define CyaSSL_CTX_set_group_messages wolfSSL_CTX_set_group_messages
// #define CyaSSL_set_session wolfSSL_set_session
// #define CyaSSL_CTX_set_session_cache_mode wolfSSL_CTX_set_session_cache_mode
// #define CyaSSL_set_timeout wolfSSL_set_timeout
// #define CyaSSL_CTX_set_timeout wolfSSL_CTX_set_timeout
// #define CyaSSL_set_using_nonblock wolfSSL_set_using_nonblock
// #define CyaSSL_set_verify wolfSSL_set_verify
// #define CyaSSL_CTX_set_verify wolfSSL_CTX_set_verify
2014-12-17 20:29:35 +03:00
/* Callbacks */
2014-12-17 20:00:17 +03:00
// #define CyaSSL_SetIOReadCtx wolfSSL_SetIOReadCtx
// #define CyaSSL_SetIOWriteCtx wolfSSL_SetIOWriteCtx
// #define CyaSSL_SetIOReadFlags wolfSSL_SetIOReadFlags
// #define CyaSSL_SetIOWriteFlags wolfSSL_SetIOWriteFlags
// #define CyaSSL_SetIORecv wolfSSL_SetIORecv
// #define CyaSSL_SetIOSend wolfSSL_SetIOSend
// #define CyaSSL_CTX_SetCACb wolfSSL_CTX_SetCACb
// #define CyaSSL_connect_ex wolfSSL_connect_ex
// #define CyaSSL_accept_ex wolfSSL_accept_ex
// #define CyaSSL_SetLoggingCb wolfSSL_SetLoggingCb
// #define CyaSSL_SetTlsHmacInner wolfSSL_SetTlsHmacInner
// #define CyaSSL_CTX_SetMacEncryptCb wolfSSL_CTX_SetMacEncryptCb
// #define CyaSSL_SetMacEncryptCtx wolfSSL_SetMacEncryptCtx
// #define CyaSSL_GetMacEncryptCtx wolfSSL_GetMacEncryptCtx
// #define CyaSSL_CTX_SetDecryptVerifyCb wolfSSL_CTX_SetDecryptVerifyCb
// #define CyaSSL_SetDecryptVerifyCtx wolfSSL_SetDecryptVerifyCtx
// #define CyaSSL_GetDecryptVerifyCtx wolfSSL_GetDecryptVerifyCtx
// #define CyaSSL_CTX_SetEccSignCb wolfSSL_CTX_SetEccSignCb
// #define CyaSSL_SetEccSignCtx wolfSSL_SetEccSignCtx
// #define CyaSSL_GetEccSignCtx wolfSSL_GetEccSignCtx
// #define CyaSSL_CTX_SetEccVerifyCb wolfSSL_CTX_SetEccVerifyCb
// #define CyaSSL_SetEccVerifyCtx wolfSSL_SetEccVerifyCtx
// #define CyaSSL_GetEccVerifyCtx wolfSSL_GetEccVerifyCtx
// #define CyaSSL_CTX_SetRsaSignCb wolfSSL_CTX_SetRsaSignCb
// #define CyaSSL_SetRsaSignCtx wolfSSL_SetRsaSignCtx
// #define CyaSSL_GetRsaSignCtx wolfSSL_GetRsaSignCtx
// #define CyaSSL_CTX_SetRsaVerifyCb wolfSSL_CTX_SetRsaVerifyCb
// #define CyaSSL_SetRsaVerifyCtx wolfSSL_SetRsaVerifyCtx
// #define CyaSSL_GetRsaVerifyCtx wolfSSL_GetRsaVerifyCtx
// #define CyaSSL_CTX_SetRsaEncCb wolfSSL_CTX_SetRsaEncCb
// #define CyaSSL_SetRsaEncCtx wolfSSL_SetRsaEncCtx
// #define CyaSSL_GetRsaEncCtx wolfSSL_GetRsaEncCtx
// #define CyaSSL_CTX_SetRsaDecCb wolfSSL_CTX_SetRsaDecCb
// #define CyaSSL_SetRsaDecCtx wolfSSL_SetRsaDecCtx
// #define CyaSSL_GetRsaDecCtx wolfSSL_GetRsaDecCtx
2014-12-17 20:29:35 +03:00
/* Error Handling and Debugging*/
2014-12-17 20:00:17 +03:00
// #define CyaSSL_ERR_error_string wolfSSL_ERR_error_string
// #define CyaSSL_ERR_error_string_n wolfSSL_ERR_error_string_n
// #define CyaSSL_ERR_print_errors_fp wolfSSL_ERR_print_errors_fp
// #define CyaSSL_get_error wolfSSL_get_error
// #define CyaSSL_load_error_strings wolfSSL_load_error_strings
// #define CyaSSL_want_read wolfSSL_want_read
// #define CyaSSL_want_write wolfSSL_want_write
// #define CyaSSL_Debugging_ON wolfSSL_Debugging_ON
// #define CyaSSL_Debugging_OFF wolfSSL_Debugging_OFF
2014-12-17 20:29:35 +03:00
/* OCSP and CRL */
2014-12-17 20:00:17 +03:00
// #define CyaSSL_CTX_OCSP_set_options wolfSSL_CTX_OCSP_set_options
// #define CyaSSL_CTX_OCSP_set_override_url wolfSSL_CTX_OCSP_set_override_url
2014-12-17 20:29:35 +03:00
/* Informational */
2014-12-17 20:00:17 +03:00
// #define CyaSSL_GetObjectSize wolfSSL_GetObjectSize
// #define CyaSSL_GetMacSecret wolfSSL_GetMacSecret
// #define CyaSSL_GetClientWriteKey wolfSSL_GetClientWriteKey
// #define CyaSSL_GetClientWriteIV wolfSSL_GetClientWriteIV
// #define CyaSSL_GetServerWriteKey wolfSSL_GetServerWriteKey
// #define CyaSSL_GetServerWriteIV wolfSSL_GetServerWriteIV
// #define CyaSSL_GetKeySize wolfSSL_GetKeySize
// #define CyaSSL_GetSide wolfSSL_GetSide
// #define CyaSSL_IsTLSv1_1 wolfSSL_IsTLSv1_1
// #define CyaSSL_GetBulkCipher wolfSSL_GetBulkCipher
// #define CyaSSL_GetCipherBlockSize wolfSSL_GetCipherBlockSize
// #define CyaSSL_GetAeadMacSize wolfSSL_GetAeadMacSize
// #define CyaSSL_GetHmacSize wolfSSL_GetHmacSize
// #define CyaSSL_GetHmacType wolfSSL_GetHmacType
// #define CyaSSL_GetCipherType wolfSSL_GetCipherType
2014-12-17 20:29:35 +03:00
/* Connection, Session, and I/O */
2014-12-17 20:00:17 +03:00
// #define CyaSSL_accept wolfSSL_accept
// #define CyaSSL_connect wolfSSL_connect
// #define CyaSSL_connect_cert wolfSSL_connect_cert
// #define CyaSSL_get_fd wolfSSL_get_fd
// #define CyaSSL_get_session wolfSSL_get_session
// #define CyaSSL_get_using_nonblock wolfSSL_get_using_nonblock
// #define CyaSSL_flush_sessions wolfSSL_flush_sessions
// #define CyaSSL_negotiate wolfSSL_negotiate
// #define CyaSSL_peek wolfSSL_peek
// #define CyaSSL_pending wolfSSL_pending
// #define CyaSSL_read wolfSSL_read
// #define CyaSSL_recv wolfSSL_recv
// #define CyaSSL_send wolfSSL_send
// #define CyaSSL_write wolfSSL_write
// #define CyaSSL_writev wolfSSL_writev
2014-12-17 20:29:35 +03:00
/* DTLS Specific */
2014-12-17 20:00:17 +03:00
// #define CyaSSL_dtls wolfSSL_dtls
// #define CyaSSL_dtls_get_current_timeout wolfSSL_dtls_get_current_timeout
// #define CyaSSL_dtls_get_peer wolfSSL_dtls_get_peer
// #define CyaSSL_dtls_got_timeout wolfSSL_dtls_got_timeout
// #define CyaSSL_dtls_set_peer wolfSSL_dtls_set_peer
2014-12-17 20:29:35 +03:00
/* Memory Abstraction Layer */
2014-12-17 20:00:17 +03:00
// #define CyaSSL_Malloc wolfSSL_Malloc
// #define CyaSSL_Realloc wolfSSL_Realloc
// #define CyaSSL_Free wolfSSL_Free
// #define CyaSSL_SetAllocators wolfSSL_SetAllocators
2014-12-17 20:29:35 +03:00
/* Certificate Manager */
2014-12-17 20:00:17 +03:00
// #define CyaSSL_CertManagerDisableCRL wolfSSL_CertManagerDisableCRL
// #define CyaSSL_CertManagerEnableCRL wolfSSL_CertManagerEnableCRL
// #define CyaSSL_CertManagerFree wolfSSL_CertManagerFree
// #define CyaSSL_CertManagerLoadCA wolfSSL_CertManagerLoadCA
// #define CyaSSL_CertManagerNew wolfSSL_CertManagerNew
// #define CyaSSL_CertManagerVerify wolfSSL_CertManagerVerify
// #define CyaSSL_CertManagerVerifyBuffer wolfSSL_CertManagerVerifyBuffer
2014-12-17 20:29:35 +03:00
/* OpenSSL Compatibility Layer */
2014-12-17 20:00:17 +03:00
// #define CyaSSL_X509_get_serial_number wolfSSL_X509_get_serial_number
// #define CyaSSL_get_sessionID wolfSSL_get_sessionID
// #define CyaSSL_get_peer_chain wolfSSL_get_peer_chain
// #define CyaSSL_get_peer_count wolfSSL_get_peer_count
// #define CyaSSL_get_peer_length wolfSSL_get_peer_length
// #define CyaSSL_get_chain_cert wolfSSL_get_chain_cert
// #define CyaSSL_get_chain_cert_pem wolfSSL_get_chain_cert_pem
// #define CyaSSL_PemCertToDer wolfSSL_PemCertToDer
// #define CyaSSL_CTX_use_RSAPrivateKey_file wolfSSL_CTX_use_RSAPrivateKey_file
// #define CyaSSL_use_certificate_file wolfSSL_use_certificate_file
// #define CyaSSL_use_PrivateKey_file wolfSSL_use_PrivateKey_file
// #define CyaSSL_use_certificate_chain_file wolfSSL_use_certificate_chain_file
// #define CyaSSL_use_RSAPrivateKey_file wolfSSL_use_RSAPrivateKey_file
2014-12-17 20:29:35 +03:00
/* TLS Extensions */
2014-12-17 20:00:17 +03:00
// #define CyaSSL_CTX_UseSNI wolfSSL_CTX_UseSNI
// #define CyaSSL_UseSNI wolfSSL_UseSNI
// #define CyaSSL_CTX_SNI_SetOptions wolfSSL_CTX_SNI_SetOptions
// #define CyaSSL_SNI_SetOptions wolfSSL_SNI_SetOptions
// #define CyaSSL_SNI_GetRequest wolfSSL_SNI_GetRequest
// #define CyaSSL_SNI_GetFromBuffer wolfSSL_SNI_GetFromBuffer
// #define CyaSSL_CTX_UseMaxFragment wolfSSL_CTX_UseMaxFragment
// #define CyaSSL_UseMaxFragment wolfSSL_UseMaxFragment
// #define CyaSSL_CTX_UseTruncatedHMAC wolfSSL_CTX_UseTruncatedHMAC
// #define CyaSSL_UseTruncatedHMAC wolfSSL_UseTruncatedHMAC
// #define CyaSSL_CTX_UseSupportedCurve wolfSSL_CTX_UseSupportedCurve
// #define CyaSSL_UseSupportedCurve wolfSSL_UseSupportedCurve
/* Carried over from openssl compatibilty layer */
/* End wolfssl -> cyassl -> openssl compatibility */
/* JRB macro redefinitions and api calls for cryptography for reverse compat. */
#ifdef WOLFSSL_SMALL_STACK
#define CYASSL_SMALL_STACK
#endif
/* wrapper around macros until they are changed in cyassl code
* needs investigation in regards to macros in fips */
#define WOLFSSL_MAX_16BIT CYASSL_MAX_16BIT
#define WOLFSSL_MSG(x) CYASSL_MSG(x)
/* for arc4 reverse compatibility */
#ifndef NO_RC4
#define CYASSL_ARC4_CAVIUM_MAGIC WOLFSSL_ARC4_CAVIUM_MAGIC
#define Arc4Process wc_Arc4Process
#define Arc4SetKey wc_Arc4SetKey
#define Arc4InitCavium wc_Arc4InitCavium
#define Arc4FreeCavium wc_Arc4FreeCavium
#endif
#ifdef __cplusplus
2014-12-17 20:00:17 +03:00
} /* extern "C" */
#endif
2014-12-17 20:00:17 +03:00
#endif /* CyaSSL_openssl_h__ */