1 #ifndef SSL_TOOLKIT_COMPAT_H
2 #define SSL_TOOLKIT_COMPAT_H
5 * this header file provides a compatiblity layer
6 * between OpenSSL and RSA sslc
9 #ifdef OPENSSL_VERSION_NUMBER
12 * rsa sslc uses incomplete types for most structures
13 * so we macroize for OpenSSL those which cannot be dereferenced
14 * using the same sames as the sslc functions
17 #define EVP_PKEY_key_type(k) (EVP_PKEY_type(k->type))
19 #define X509_NAME_get_entries(xs) (xs->entries)
20 #define X509_REVOKED_get_serialNumber(xs) (xs->serialNumber)
22 #define X509_get_signature_algorithm(xs) (xs->cert_info->signature->algorithm)
23 #define X509_get_key_algorithm(xs) (xs->cert_info->key->algor->algorithm)
25 #define X509_NAME_ENTRY_get_data_ptr(xs) (xs->value->data)
26 #define X509_NAME_ENTRY_get_data_len(xs) (xs->value->length)
28 #define SSL_CTX_get_extra_certs(ctx) (ctx->extra_certs)
29 #define SSL_CTX_set_extra_certs(ctx,value) {ctx->extra_certs = value;}
31 #define SSL_CIPHER_get_name(s) (s->name)
32 #define SSL_CIPHER_get_valid(s) (s->valid)
34 #define SSL_SESSION_get_session_id(s) (s->session_id)
35 #define SSL_SESSION_get_session_id_length(s) (s->session_id_length)
38 * Support for retrieving/overriding states
41 #define SSL_get_state(ssl) SSL_state(ssl)
44 #define SSL_set_state(ssl,val) (ssl)->state = val
46 #define MODSSL_BIO_CB_ARG_TYPE const char
47 #define MODSSL_CRYPTO_CB_ARG_TYPE const char
49 #define modssl_X509_verify_cert X509_verify_cert
51 #define modssl_PEM_read_bio_X509 PEM_read_bio_X509
53 #define modssl_PEM_read_bio_PrivateKey PEM_read_bio_PrivateKey
55 #define modssl_set_cipher_list SSL_set_cipher_list
57 #define HAVE_SSL_RAND_EGD /* since 9.5.1 */
59 #define HAVE_SSL_X509V3_EXT_d2i
63 /* sslc does not support this function, OpenSSL has since 9.5.1 */
64 #define RAND_status() 1
67 #define STACK_OF(type) STACK
70 #define MODSSL_BIO_CB_ARG_TYPE char
71 #define MODSSL_CRYPTO_CB_ARG_TYPE char
73 #define modssl_X509_verify_cert(c) X509_verify_cert(c, NULL)
75 #define modssl_PEM_read_bio_X509(b, x, cb, arg) \
76 PEM_read_bio_X509(b, x, cb)
78 #define modssl_PEM_read_bio_PrivateKey(b, k, cb, arg) \
79 PEM_read_bio_PrivateKey(b, k, cb)
81 #ifndef HAVE_SSL_SET_STATE
82 #define SSL_set_state(ssl, state) /* XXX: should throw an error */
85 #define modssl_set_cipher_list(ssl, l) \
86 SSL_set_cipher_list(ssl, (char *)l)
88 #ifndef PEM_F_DEF_CALLBACK
89 #define PEM_F_DEF_CALLBACK PEM_F_DEF_CB
92 #if SSLC_VERSION < 0x2000
94 #define X509_STORE_CTX_set_depth(st, d)
95 #define X509_CRL_get_lastUpdate(x) ((x)->crl->lastUpdate)
96 #define X509_CRL_get_nextUpdate(x) ((x)->crl->nextUpdate)
97 #define X509_CRL_get_REVOKED(x) ((x)->crl->revoked)
98 #define X509_REVOKED_get_serialNumber(xs) (xs->serialNumber)
100 #define modssl_set_verify(ssl, verify, cb) \
101 SSL_set_verify(ssl, verify)
103 #define NO_SSL_X509V3_H
107 /* BEGIN GENERATED SECTION */
108 #define sk_SSL_CIPHER_free sk_free
109 #define sk_SSL_CIPHER_dup sk_dup
110 #define sk_SSL_CIPHER_num sk_num
111 #define sk_SSL_CIPHER_find(st, data) sk_find(st, (void *)data)
112 #define sk_SSL_CIPHER_value (SSL_CIPHER *)sk_value
113 #define sk_X509_num sk_num
114 #define sk_X509_value (X509 *)sk_value
115 #define sk_X509_INFO_value (X509_INFO *)sk_value
116 #define sk_X509_INFO_num sk_num
117 #define sk_X509_INFO_new_null sk_new_null
118 #define sk_X509_NAME_num sk_num
119 #define sk_X509_NAME_push(st, data) sk_push(st, (void *)data)
120 #define sk_X509_NAME_value (X509_NAME *)sk_value
121 #define sk_X509_NAME_free sk_free
122 #define sk_X509_NAME_new sk_new
123 #define sk_X509_NAME_find(st, data) sk_find(st, (void *)data)
124 #define sk_X509_NAME_ENTRY_num sk_num
125 #define sk_X509_NAME_ENTRY_value (X509_NAME_ENTRY *)sk_value
126 #define sk_X509_NAME_set_cmp_func sk_set_cmp_func
127 #define sk_X509_REVOKED_num sk_num
128 #define sk_X509_REVOKED_value (X509_REVOKED *)sk_value
129 #define sk_X509_pop_free sk_pop_free
130 /* END GENERATED SECTION */
132 #endif /* OPENSSL_VERSION_NUMBER */
134 #ifndef modssl_set_verify
135 #define modssl_set_verify(ssl, verify, cb) \
136 SSL_set_verify(ssl, verify, cb)
139 #ifndef NO_SSL_X509V3_H
140 #define HAVE_SSL_X509V3_H
143 #endif /* SSL_TOOLKIT_COMPAT_H */