123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683 |
- #ifndef POLARSSL_SSL_H
- #define POLARSSL_SSL_H
- #include <time.h>
- #include "polarssl/net.h"
- #include "polarssl/dhm.h"
- #include "polarssl/rsa.h"
- #include "polarssl/md5.h"
- #include "polarssl/sha1.h"
- #include "polarssl/x509.h"
- #include "config.h"
- #if defined(POLARSSL_PKCS11_C)
- #include "polarssl/pkcs11.h"
- #endif
- #if defined(_MSC_VER) && !defined(inline)
- #define inline _inline
- #else
- #if defined(__ARMCC_VERSION) && !defined(inline)
- #define inline __inline
- #endif
- #endif
- #define POLARSSL_ERR_SSL_FEATURE_UNAVAILABLE -0x7080
- #define POLARSSL_ERR_SSL_BAD_INPUT_DATA -0x7100
- #define POLARSSL_ERR_SSL_INVALID_MAC -0x7180
- #define POLARSSL_ERR_SSL_INVALID_RECORD -0x7200
- #define POLARSSL_ERR_SSL_CONN_EOF -0x7280
- #define POLARSSL_ERR_SSL_UNKNOWN_CIPHER -0x7300
- #define POLARSSL_ERR_SSL_NO_CIPHER_CHOSEN -0x7380
- #define POLARSSL_ERR_SSL_NO_SESSION_FOUND -0x7400
- #define POLARSSL_ERR_SSL_NO_CLIENT_CERTIFICATE -0x7480
- #define POLARSSL_ERR_SSL_CERTIFICATE_TOO_LARGE -0x7500
- #define POLARSSL_ERR_SSL_CERTIFICATE_REQUIRED -0x7580
- #define POLARSSL_ERR_SSL_PRIVATE_KEY_REQUIRED -0x7600
- #define POLARSSL_ERR_SSL_CA_CHAIN_REQUIRED -0x7680
- #define POLARSSL_ERR_SSL_UNEXPECTED_MESSAGE -0x7700
- #define POLARSSL_ERR_SSL_FATAL_ALERT_MESSAGE -0x7780
- #define POLARSSL_ERR_SSL_PEER_VERIFY_FAILED -0x7800
- #define POLARSSL_ERR_SSL_PEER_CLOSE_NOTIFY -0x7880
- #define POLARSSL_ERR_SSL_BAD_HS_CLIENT_HELLO -0x7900
- #define POLARSSL_ERR_SSL_BAD_HS_SERVER_HELLO -0x7980
- #define POLARSSL_ERR_SSL_BAD_HS_CERTIFICATE -0x7A00
- #define POLARSSL_ERR_SSL_BAD_HS_CERTIFICATE_REQUEST -0x7A80
- #define POLARSSL_ERR_SSL_BAD_HS_SERVER_KEY_EXCHANGE -0x7B00
- #define POLARSSL_ERR_SSL_BAD_HS_SERVER_HELLO_DONE -0x7B80
- #define POLARSSL_ERR_SSL_BAD_HS_CLIENT_KEY_EXCHANGE -0x7C00
- #define POLARSSL_ERR_SSL_BAD_HS_CLIENT_KEY_EXCHANGE_DHM_RP -0x7C80
- #define POLARSSL_ERR_SSL_BAD_HS_CLIENT_KEY_EXCHANGE_DHM_CS -0x7D00
- #define POLARSSL_ERR_SSL_BAD_HS_CERTIFICATE_VERIFY -0x7D80
- #define POLARSSL_ERR_SSL_BAD_HS_CHANGE_CIPHER_SPEC -0x7E00
- #define POLARSSL_ERR_SSL_BAD_HS_FINISHED -0x7E80
- #define SSL_MAJOR_VERSION_3 3
- #define SSL_MINOR_VERSION_0 0
- #define SSL_MINOR_VERSION_1 1
- #define SSL_MINOR_VERSION_2 2
- #define SSL_IS_CLIENT 0
- #define SSL_IS_SERVER 1
- #define SSL_COMPRESS_NULL 0
- #define SSL_VERIFY_NONE 0
- #define SSL_VERIFY_OPTIONAL 1
- #define SSL_VERIFY_REQUIRED 2
- #define SSL_MAX_CONTENT_LEN 2024
- #define SSL_BUFFER_LEN (SSL_MAX_CONTENT_LEN + 512)
- #define SSL_RSA_RC4_128_MD5 0x04
- #define SSL_RSA_RC4_128_SHA 0x05
- #define SSL_RSA_DES_168_SHA 0x0A
- #define SSL_EDH_RSA_DES_168_SHA 0x16
- #define SSL_RSA_AES_128_SHA 0x2F
- #define SSL_EDH_RSA_AES_128_SHA 0x33
- #define SSL_RSA_AES_256_SHA 0x35
- #define SSL_EDH_RSA_AES_256_SHA 0x39
- #define SSL_RSA_CAMELLIA_128_SHA 0x41
- #define SSL_EDH_RSA_CAMELLIA_128_SHA 0x45
- #define SSL_RSA_CAMELLIA_256_SHA 0x84
- #define SSL_EDH_RSA_CAMELLIA_256_SHA 0x88
- #define SSL_MSG_CHANGE_CIPHER_SPEC 20
- #define SSL_MSG_ALERT 21
- #define SSL_MSG_HANDSHAKE 22
- #define SSL_MSG_APPLICATION_DATA 23
- #define SSL_ALERT_LEVEL_WARNING 1
- #define SSL_ALERT_LEVEL_FATAL 2
- #define SSL_ALERT_MSG_CLOSE_NOTIFY 0
- #define SSL_ALERT_MSG_UNEXPECTED_MESSAGE 10
- #define SSL_ALERT_MSG_BAD_RECORD_MAC 20
- #define SSL_ALERT_MSG_DECRYPTION_FAILED 21
- #define SSL_ALERT_MSG_RECORD_OVERFLOW 22
- #define SSL_ALERT_MSG_DECOMPRESSION_FAILURE 30
- #define SSL_ALERT_MSG_HANDSHAKE_FAILURE 40
- #define SSL_ALERT_MSG_NO_CERT 41
- #define SSL_ALERT_MSG_BAD_CERT 42
- #define SSL_ALERT_MSG_UNSUPPORTED_CERT 43
- #define SSL_ALERT_MSG_CERT_REVOKED 44
- #define SSL_ALERT_MSG_CERT_EXPIRED 45
- #define SSL_ALERT_MSG_CERT_UNKNOWN 46
- #define SSL_ALERT_MSG_ILLEGAL_PARAMETER 47
- #define SSL_ALERT_MSG_UNKNOWN_CA 48
- #define SSL_ALERT_MSG_ACCESS_DENIED 49
- #define SSL_ALERT_MSG_DECODE_ERROR 50
- #define SSL_ALERT_MSG_DECRYPT_ERROR 51
- #define SSL_ALERT_MSG_EXPORT_RESTRICTION 60
- #define SSL_ALERT_MSG_PROTOCOL_VERSION 70
- #define SSL_ALERT_MSG_INSUFFICIENT_SECURITY 71
- #define SSL_ALERT_MSG_INTERNAL_ERROR 80
- #define SSL_ALERT_MSG_USER_CANCELED 90
- #define SSL_ALERT_MSG_NO_RENEGOTIATION 100
- #define SSL_HS_HELLO_REQUEST 0
- #define SSL_HS_CLIENT_HELLO 1
- #define SSL_HS_SERVER_HELLO 2
- #define SSL_HS_CERTIFICATE 11
- #define SSL_HS_SERVER_KEY_EXCHANGE 12
- #define SSL_HS_CERTIFICATE_REQUEST 13
- #define SSL_HS_SERVER_HELLO_DONE 14
- #define SSL_HS_CERTIFICATE_VERIFY 15
- #define SSL_HS_CLIENT_KEY_EXCHANGE 16
- #define SSL_HS_FINISHED 20
- #define TLS_EXT_SERVERNAME 0
- #define TLS_EXT_SERVERNAME_HOSTNAME 0
- typedef enum
- {
- SSL_HELLO_REQUEST,
- SSL_CLIENT_HELLO,
- SSL_SERVER_HELLO,
- SSL_SERVER_CERTIFICATE,
- SSL_SERVER_KEY_EXCHANGE,
- SSL_CERTIFICATE_REQUEST,
- SSL_SERVER_HELLO_DONE,
- SSL_CLIENT_CERTIFICATE,
- SSL_CLIENT_KEY_EXCHANGE,
- SSL_CERTIFICATE_VERIFY,
- SSL_CLIENT_CHANGE_CIPHER_SPEC,
- SSL_CLIENT_FINISHED,
- SSL_SERVER_CHANGE_CIPHER_SPEC,
- SSL_SERVER_FINISHED,
- SSL_FLUSH_BUFFERS,
- SSL_HANDSHAKE_OVER
- }
- ssl_states;
- typedef struct _ssl_session ssl_session;
- typedef struct _ssl_context ssl_context;
- struct _ssl_session
- {
- time_t start;
- int ciphersuite;
- size_t length;
- unsigned char id[32];
- unsigned char master[48];
- ssl_session *next;
- };
- struct _ssl_context
- {
-
- int state;
- int major_ver;
- int minor_ver;
- int max_major_ver;
- int max_minor_ver;
-
- int (*f_rng)(void *);
- void (*f_dbg)(void *, int, const char *);
- int (*f_recv)(void *, unsigned char *, size_t);
- int (*f_send)(void *, const unsigned char *, size_t);
- int (*f_vrfy)(void *, x509_cert *, int, int);
- void *p_rng;
- void *p_dbg;
- void *p_recv;
- void *p_send;
- void *p_vrfy;
-
- int resume;
- int timeout;
- ssl_session *session;
- int (*s_get)(ssl_context *);
- int (*s_set)(ssl_context *);
-
- unsigned char *in_ctr;
- unsigned char *in_hdr;
- unsigned char *in_msg;
- unsigned char *in_offt;
- int in_msgtype;
- size_t in_msglen;
- size_t in_left;
- size_t in_hslen;
- int nb_zero;
-
- unsigned char *out_ctr;
- unsigned char *out_hdr;
- unsigned char *out_msg;
- int out_msgtype;
- size_t out_msglen;
- size_t out_left;
-
- rsa_context *rsa_key;
- #if defined(POLARSSL_PKCS11_C)
- pkcs11_context *pkcs11_key;
- #endif
- x509_cert *own_cert;
- x509_cert *ca_chain;
- x509_crl *ca_crl;
- x509_cert *peer_cert;
- const char *peer_cn;
- int endpoint;
- int authmode;
- int client_auth;
- int verify_result;
-
- dhm_context dhm_ctx;
- md5_context fin_md5;
- sha1_context fin_sha1;
- int do_crypt;
- int *ciphersuites;
- size_t pmslen;
- unsigned int keylen;
- size_t minlen;
- size_t ivlen;
- size_t maclen;
- unsigned char randbytes[64];
- unsigned char premaster[256];
- unsigned char iv_enc[16];
- unsigned char iv_dec[16];
- unsigned char mac_enc[32];
- unsigned char mac_dec[32];
- unsigned long ctx_enc[128];
- unsigned long ctx_dec[128];
-
- unsigned char *hostname;
- size_t hostname_len;
- };
- #ifdef __cplusplus
- extern "C" {
- #endif
- extern int ssl_default_ciphersuites[];
- static inline const int *ssl_list_ciphersuites( void )
- {
- return ssl_default_ciphersuites;
- }
- const char *ssl_get_ciphersuite_name( const int ciphersuite_id );
- int ssl_get_ciphersuite_id( const char *ciphersuite_name );
- int ssl_init( ssl_context *ssl );
- void ssl_set_endpoint( ssl_context *ssl, int endpoint );
- void ssl_set_authmode( ssl_context *ssl, int authmode );
- void ssl_set_verify( ssl_context *ssl,
- int (*f_vrfy)(void *, x509_cert *, int, int),
- void *p_vrfy );
- void ssl_set_rng( ssl_context *ssl,
- int (*f_rng)(void *),
- void *p_rng );
- void ssl_set_dbg( ssl_context *ssl,
- void (*f_dbg)(void *, int, const char *),
- void *p_dbg );
- void ssl_set_bio( ssl_context *ssl,
- int (*f_recv)(void *, unsigned char *, size_t), void *p_recv,
- int (*f_send)(void *, const unsigned char *, size_t), void *p_send );
- void ssl_set_scb( ssl_context *ssl,
- int (*s_get)(ssl_context *),
- int (*s_set)(ssl_context *) );
- void ssl_set_session( ssl_context *ssl, int resume, int timeout,
- ssl_session *session );
- void ssl_set_ciphersuites( ssl_context *ssl, int *ciphersuites );
- void ssl_set_ca_chain( ssl_context *ssl, x509_cert *ca_chain,
- x509_crl *ca_crl, const char *peer_cn );
- void ssl_set_own_cert( ssl_context *ssl, x509_cert *own_cert,
- rsa_context *rsa_key );
- #if defined(POLARSSL_PKCS11_C)
- void ssl_set_own_cert_pkcs11( ssl_context *ssl, x509_cert *own_cert,
- pkcs11_context *pkcs11_key );
- #endif
- int ssl_set_dh_param( ssl_context *ssl, const char *dhm_P, const char *dhm_G );
- int ssl_set_dh_param_ctx( ssl_context *ssl, dhm_context *dhm_ctx );
- int ssl_set_hostname( ssl_context *ssl, const char *hostname );
- size_t ssl_get_bytes_avail( const ssl_context *ssl );
- int ssl_get_verify_result( const ssl_context *ssl );
- const char *ssl_get_ciphersuite( const ssl_context *ssl );
- const char *ssl_get_version( const ssl_context *ssl );
- int ssl_handshake( ssl_context *ssl );
- int ssl_read( ssl_context *ssl, unsigned char *buf, size_t len );
- int ssl_write( ssl_context *ssl, const unsigned char *buf, size_t len );
- int ssl_close_notify( ssl_context *ssl );
- void ssl_free( ssl_context *ssl );
- int ssl_handshake_client( ssl_context *ssl );
- int ssl_handshake_server( ssl_context *ssl );
- int ssl_derive_keys( ssl_context *ssl );
- void ssl_calc_verify( ssl_context *ssl, unsigned char hash[36] );
- int ssl_read_record( ssl_context *ssl );
- int ssl_fetch_input( ssl_context *ssl, size_t nb_want );
- int ssl_write_record( ssl_context *ssl );
- int ssl_flush_output( ssl_context *ssl );
- int ssl_parse_certificate( ssl_context *ssl );
- int ssl_write_certificate( ssl_context *ssl );
- int ssl_parse_change_cipher_spec( ssl_context *ssl );
- int ssl_write_change_cipher_spec( ssl_context *ssl );
- int ssl_parse_finished( ssl_context *ssl );
- int ssl_write_finished( ssl_context *ssl );
- #ifdef __cplusplus
- }
- #endif
- #endif
|