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
51 #define STACK_OF(type) STACK
54 #define MODSSL_BIO_CB_ARG_TYPE char
56 #if SSLC_VERSION < 0x2000
58 #define X509_STORE_CTX_set_depth(st, d)
59 #define X509_CRL_get_lastUpdate(x) ((x)->crl->lastUpdate)
60 #define X509_CRL_get_nextUpdate(x) ((x)->crl->nextUpdate)
61 #define X509_CRL_get_REVOKED(x) ((x)->crl->revoked)
62 #define X509_REVOKED_get_serialNumber(xs) (xs->serialNumber)
66 #endif /* OPENSSL_VERSION_NUMBER */
68 #endif /* SSL_TOOLKIT_COMPAT_H */