/usr/src/redhat/BUILD/httpd-2.2.3/modules/ssl/ssl_toolkit_compat.h

説明を見る。
00001 /* Licensed to the Apache Software Foundation (ASF) under one or more
00002  * contributor license agreements.  See the NOTICE file distributed with
00003  * this work for additional information regarding copyright ownership.
00004  * The ASF licenses this file to You under the Apache License, Version 2.0
00005  * (the "License"); you may not use this file except in compliance with
00006  * the License.  You may obtain a copy of the License at
00007  *
00008  *     http://www.apache.org/licenses/LICENSE-2.0
00009  *
00010  * Unless required by applicable law or agreed to in writing, software
00011  * distributed under the License is distributed on an "AS IS" BASIS,
00012  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
00013  * See the License for the specific language governing permissions and
00014  * limitations under the License.
00015  */
00016 
00017 #ifndef SSL_TOOLKIT_COMPAT_H
00018 #define SSL_TOOLKIT_COMPAT_H
00019 
00030 #ifdef HAVE_OPENSSL
00031 
00033 #include <openssl/ssl.h>
00034 #include <openssl/err.h>
00035 #include <openssl/x509.h>
00036 #include <openssl/pem.h>
00037 #include <openssl/crypto.h>
00038 #include <openssl/evp.h>
00039 #include <openssl/rand.h>
00040 #include <openssl/x509v3.h>
00044 #if defined(HAVE_OPENSSL_ENGINE_H) && defined(HAVE_ENGINE_INIT)
00045 #include <openssl/engine.h>
00046 #endif
00047 
00054 #define EVP_PKEY_key_type(k)              (EVP_PKEY_type(k->type))
00055 
00056 #define X509_NAME_get_entries(xs)         (xs->entries)
00057 #define X509_REVOKED_get_serialNumber(xs) (xs->serialNumber)
00058 
00059 #define X509_get_signature_algorithm(xs) (xs->cert_info->signature->algorithm)
00060 #define X509_get_key_algorithm(xs)       (xs->cert_info->key->algor->algorithm)
00061 
00062 #define X509_NAME_ENTRY_get_data_ptr(xs) (xs->value->data)
00063 #define X509_NAME_ENTRY_get_data_len(xs) (xs->value->length)
00064 
00065 #define SSL_CTX_get_extra_certs(ctx)       (ctx->extra_certs)
00066 #define SSL_CTX_set_extra_certs(ctx,value) {ctx->extra_certs = value;}
00067 
00068 #define SSL_CIPHER_get_name(s)             (s->name)
00069 #define SSL_CIPHER_get_valid(s)            (s->valid)
00070 
00071 #define SSL_SESSION_get_session_id(s)      (s->session_id)
00072 #define SSL_SESSION_get_session_id_length(s) (s->session_id_length)
00073 
00077 #ifndef SSL_get_state
00078 #define SSL_get_state(ssl) SSL_state(ssl)
00079 #endif
00080 
00081 #define SSL_set_state(ssl,val) (ssl)->state = val
00082 
00083 #define MODSSL_BIO_CB_ARG_TYPE const char
00084 #define MODSSL_CRYPTO_CB_ARG_TYPE const char
00085 #if (OPENSSL_VERSION_NUMBER < 0x00907000)
00086 # define MODSSL_INFO_CB_ARG_TYPE SSL*
00087 #else
00088 # define MODSSL_INFO_CB_ARG_TYPE const SSL*
00089 #endif
00090 #define MODSSL_CLIENT_CERT_CB_ARG_TYPE X509
00091 #define MODSSL_PCHAR_CAST
00092 
00094 #if (OPENSSL_VERSION_NUMBER >= 0x0090707f)
00095 # define MODSSL_D2I_SSL_SESSION_CONST    const
00096 #else
00097 # define MODSSL_D2I_SSL_SESSION_CONST
00098 #endif
00099 
00100 #if (OPENSSL_VERSION_NUMBER >= 0x00908000)
00101 # define MODSSL_D2I_PrivateKey_CONST const
00102 # define MODSSL_D2I_X509_CONST const
00103 #else
00104 # define MODSSL_D2I_PrivateKey_CONST
00105 # define MODSSL_D2I_X509_CONST
00106 #endif
00107 
00108 #define modssl_X509_verify_cert X509_verify_cert
00109 
00110 typedef int (modssl_read_bio_cb_fn)(char*,int,int,void*);
00111 
00112 #if (OPENSSL_VERSION_NUMBER < 0x00904000)
00113 #define modssl_PEM_read_bio_X509(b, x, cb, arg) PEM_read_bio_X509(b, x, cb)
00114 #else
00115 #define modssl_PEM_read_bio_X509(b, x, cb, arg) PEM_read_bio_X509(b, x, cb, arg)
00116 #endif
00117 
00118 #define modssl_PEM_X509_INFO_read_bio PEM_X509_INFO_read_bio 
00119 
00120 #define modssl_PEM_read_bio_PrivateKey PEM_read_bio_PrivateKey
00121 
00122 #define modssl_set_cipher_list SSL_set_cipher_list
00123 
00124 #define modssl_free OPENSSL_free
00125 
00126 #define EVP_PKEY_reference_inc(pkey) \
00127    CRYPTO_add(&((pkey)->references), +1, CRYPTO_LOCK_X509_PKEY)
00128 
00129 #define X509_reference_inc(cert) \
00130    CRYPTO_add(&((cert)->references), +1, CRYPTO_LOCK_X509)
00131 
00132 #define HAVE_SSL_RAND_EGD /* since 9.5.1 */
00133 
00134 #define HAVE_SSL_X509V3_EXT_d2i
00135 
00136 #ifndef PEM_F_DEF_CALLBACK
00137 #ifdef PEM_F_PEM_DEF_CALLBACK
00138 
00139 #define PEM_F_DEF_CALLBACK PEM_F_PEM_DEF_CALLBACK 
00140 #endif
00141 #endif
00142 
00143 #elif defined(HAVE_SSLC)
00144 
00145 #include <bio.h>
00146 #include <ssl.h>
00147 #include <err.h>
00148 #include <x509.h>
00149 #include <pem.h>
00150 #include <evp.h>
00151 #include <objects.h>
00152 #include <sslc.h>
00153 
00155 #define RAND_status() 1
00156 
00158 #define CRYPTO_num_locks() CRYPTO_get_num_locks()
00159 
00160 #ifndef STACK_OF
00161 #define STACK_OF(type) STACK
00162 #endif
00163 
00164 #define MODSSL_BIO_CB_ARG_TYPE char
00165 #define MODSSL_CRYPTO_CB_ARG_TYPE char
00166 #define MODSSL_INFO_CB_ARG_TYPE SSL*
00167 #define MODSSL_CLIENT_CERT_CB_ARG_TYPE void
00168 #define MODSSL_PCHAR_CAST (char *)
00169 #define MODSSL_D2I_SSL_SESSION_CONST
00170 #define MODSSL_D2I_PrivateKey_CONST
00171 #define MODSSL_D2I_X509_CONST
00172 
00173 typedef int (modssl_read_bio_cb_fn)(char*,int,int);
00174 
00175 #define modssl_X509_verify_cert(c) X509_verify_cert(c, NULL)
00176 
00177 #define modssl_PEM_read_bio_X509(b, x, cb, arg) \
00178    PEM_read_bio_X509(b, x, cb)
00179 
00180 #define modssl_PEM_X509_INFO_read_bio(b, x, cb, arg)\
00181    PEM_X509_INFO_read_bio(b, x, cb)
00182 
00183 #define modssl_PEM_read_bio_PrivateKey(b, k, cb, arg) \
00184    PEM_read_bio_PrivateKey(b, k, cb)
00185 
00186 #ifndef HAVE_SSL_SET_STATE
00187 #define SSL_set_state(ssl, state) 
00188 #endif
00189 
00190 #define modssl_set_cipher_list(ssl, l) \
00191    SSL_set_cipher_list(ssl, (char *)l)
00192 
00193 #define modssl_free free
00194 
00195 #ifndef PEM_F_DEF_CALLBACK
00196 #define PEM_F_DEF_CALLBACK PEM_F_DEF_CB
00197 #endif
00198 
00199 #if SSLC_VERSION_NUMBER < 0x2000
00200 
00201 #define X509_STORE_CTX_set_depth(st, d)    
00202 #define X509_CRL_get_lastUpdate(x) ((x)->crl->lastUpdate)
00203 #define X509_CRL_get_nextUpdate(x) ((x)->crl->nextUpdate)
00204 #define X509_CRL_get_REVOKED(x)    ((x)->crl->revoked)
00205 #define X509_REVOKED_get_serialNumber(xs) (xs->serialNumber)
00206 
00207 #define modssl_set_verify(ssl, verify, cb) \
00208     SSL_set_verify(ssl, verify)
00209 
00210 #else 
00212 #define CRYPTO_malloc_init R_malloc_init
00213 
00214 #define EVP_cleanup() 
00215 
00216 #endif 
00218 typedef void (*modssl_popfree_fn)(char *data);
00219 
00220 #define sk_SSL_CIPHER_dup sk_dup
00221 #define sk_SSL_CIPHER_find(st, data) sk_find(st, (void *)data)
00222 #define sk_SSL_CIPHER_free sk_free
00223 #define sk_SSL_CIPHER_num sk_num
00224 #define sk_SSL_CIPHER_value (SSL_CIPHER *)sk_value
00225 #define sk_X509_num sk_num
00226 #define sk_X509_push sk_push
00227 #define sk_X509_pop_free(st, free) sk_pop_free((STACK*)(st), (modssl_popfree_fn)(free))
00228 #define sk_X509_value (X509 *)sk_value
00229 #define sk_X509_INFO_free sk_free
00230 #define sk_X509_INFO_pop_free(st, free) sk_pop_free((STACK*)(st), (modssl_popfree_fn)(free))
00231 #define sk_X509_INFO_num sk_num
00232 #define sk_X509_INFO_new_null sk_new_null
00233 #define sk_X509_INFO_value (X509_INFO *)sk_value
00234 #define sk_X509_NAME_find(st, data) sk_find(st, (void *)data)
00235 #define sk_X509_NAME_free sk_free
00236 #define sk_X509_NAME_new sk_new
00237 #define sk_X509_NAME_num sk_num
00238 #define sk_X509_NAME_push(st, data) sk_push(st, (void *)data)
00239 #define sk_X509_NAME_value (X509_NAME *)sk_value
00240 #define sk_X509_NAME_ENTRY_num sk_num
00241 #define sk_X509_NAME_ENTRY_value (X509_NAME_ENTRY *)sk_value
00242 #define sk_X509_NAME_set_cmp_func sk_set_cmp_func
00243 #define sk_X509_REVOKED_num sk_num
00244 #define sk_X509_REVOKED_value (X509_REVOKED *)sk_value
00245 
00246 #else 
00248 #error "Unrecognized SSL Toolkit!"
00249 
00250 #endif /* ! HAVE_OPENSSL && ! HAVE_SSLC */
00251 
00252 #ifndef modssl_set_verify
00253 #define modssl_set_verify(ssl, verify, cb) \
00254     SSL_set_verify(ssl, verify, cb)
00255 #endif
00256 
00257 #ifndef SSL_SESS_CACHE_NO_INTERNAL
00258 #define SSL_SESS_CACHE_NO_INTERNAL  SSL_SESS_CACHE_NO_INTERNAL_LOOKUP
00259 #endif
00260 
00261 #endif /* SSL_TOOLKIT_COMPAT_H */
00262 

Apacheに対してSun Jul 19 22:05:23 2009に生成されました。  doxygen 1.4.7