sl@0: /* ==================================================================== sl@0: * Copyright (c) 1998-2001 The OpenSSL Project. All rights reserved. sl@0: * sl@0: * Redistribution and use in source and binary forms, with or without sl@0: * modification, are permitted provided that the following conditions sl@0: * are met: sl@0: * sl@0: * 1. Redistributions of source code must retain the above copyright sl@0: * notice, this list of conditions and the following disclaimer. sl@0: * sl@0: * 2. Redistributions in binary form must reproduce the above copyright sl@0: * notice, this list of conditions and the following disclaimer in sl@0: * the documentation and/or other materials provided with the sl@0: * distribution. sl@0: * sl@0: * 3. All advertising materials mentioning features or use of this sl@0: * software must display the following acknowledgment: sl@0: * "This product includes software developed by the OpenSSL Project sl@0: * for use in the OpenSSL Toolkit. (http://www.openssl.org/)" sl@0: * sl@0: * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to sl@0: * endorse or promote products derived from this software without sl@0: * prior written permission. For written permission, please contact sl@0: * openssl-core@openssl.org. sl@0: * sl@0: * 5. Products derived from this software may not be called "OpenSSL" sl@0: * nor may "OpenSSL" appear in their names without prior written sl@0: * permission of the OpenSSL Project. sl@0: * sl@0: * 6. Redistributions of any form whatsoever must retain the following sl@0: * acknowledgment: sl@0: * "This product includes software developed by the OpenSSL Project sl@0: * for use in the OpenSSL Toolkit (http://www.openssl.org/)" sl@0: * sl@0: * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY sl@0: * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE sl@0: * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR sl@0: * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR sl@0: * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, sl@0: * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT sl@0: * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; sl@0: * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) sl@0: * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, sl@0: * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) sl@0: * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED sl@0: * OF THE POSSIBILITY OF SUCH DAMAGE. sl@0: * ==================================================================== sl@0: * sl@0: * This product includes cryptographic software written by Eric Young sl@0: * (eay@cryptsoft.com). This product includes software written by Tim sl@0: * Hudson (tjh@cryptsoft.com). sl@0: * sl@0: */ sl@0: sl@0: #ifndef HEADER_OPENSSL_TYPES_H sl@0: #define HEADER_OPENSSL_TYPES_H sl@0: sl@0: #include <openssl/e_os2.h> sl@0: sl@0: #ifdef NO_ASN1_TYPEDEFS sl@0: #define ASN1_INTEGER ASN1_STRING sl@0: #define ASN1_ENUMERATED ASN1_STRING sl@0: #define ASN1_BIT_STRING ASN1_STRING sl@0: #define ASN1_OCTET_STRING ASN1_STRING sl@0: #define ASN1_PRINTABLESTRING ASN1_STRING sl@0: #define ASN1_T61STRING ASN1_STRING sl@0: #define ASN1_IA5STRING ASN1_STRING sl@0: #define ASN1_UTCTIME ASN1_STRING sl@0: #define ASN1_GENERALIZEDTIME ASN1_STRING sl@0: #define ASN1_TIME ASN1_STRING sl@0: #define ASN1_GENERALSTRING ASN1_STRING sl@0: #define ASN1_UNIVERSALSTRING ASN1_STRING sl@0: #define ASN1_BMPSTRING ASN1_STRING sl@0: #define ASN1_VISIBLESTRING ASN1_STRING sl@0: #define ASN1_UTF8STRING ASN1_STRING sl@0: #define ASN1_BOOLEAN int sl@0: #define ASN1_NULL int sl@0: #else sl@0: typedef struct asn1_string_st ASN1_INTEGER; sl@0: typedef struct asn1_string_st ASN1_ENUMERATED; sl@0: typedef struct asn1_string_st ASN1_BIT_STRING; sl@0: typedef struct asn1_string_st ASN1_OCTET_STRING; sl@0: typedef struct asn1_string_st ASN1_PRINTABLESTRING; sl@0: typedef struct asn1_string_st ASN1_T61STRING; sl@0: typedef struct asn1_string_st ASN1_IA5STRING; sl@0: typedef struct asn1_string_st ASN1_GENERALSTRING; sl@0: typedef struct asn1_string_st ASN1_UNIVERSALSTRING; sl@0: typedef struct asn1_string_st ASN1_BMPSTRING; sl@0: typedef struct asn1_string_st ASN1_UTCTIME; sl@0: typedef struct asn1_string_st ASN1_TIME; sl@0: typedef struct asn1_string_st ASN1_GENERALIZEDTIME; sl@0: typedef struct asn1_string_st ASN1_VISIBLESTRING; sl@0: typedef struct asn1_string_st ASN1_UTF8STRING; sl@0: typedef int ASN1_BOOLEAN; sl@0: typedef int ASN1_NULL; sl@0: #endif sl@0: sl@0: #ifdef OPENSSL_SYS_WIN32 sl@0: #undef X509_NAME sl@0: #undef X509_CERT_PAIR sl@0: #undef PKCS7_ISSUER_AND_SERIAL sl@0: #endif sl@0: sl@0: #ifdef BIGNUM sl@0: #undef BIGNUM sl@0: #endif sl@0: typedef struct bignum_st BIGNUM; sl@0: typedef struct bignum_ctx BN_CTX; sl@0: typedef struct bn_blinding_st BN_BLINDING; sl@0: typedef struct bn_mont_ctx_st BN_MONT_CTX; sl@0: typedef struct bn_recp_ctx_st BN_RECP_CTX; sl@0: typedef struct bn_gencb_st BN_GENCB; sl@0: sl@0: typedef struct buf_mem_st BUF_MEM; sl@0: sl@0: typedef struct evp_cipher_st EVP_CIPHER; sl@0: typedef struct evp_cipher_ctx_st EVP_CIPHER_CTX; sl@0: typedef struct env_md_st EVP_MD; sl@0: typedef struct env_md_ctx_st EVP_MD_CTX; sl@0: typedef struct evp_pkey_st EVP_PKEY; sl@0: sl@0: typedef struct dh_st DH; sl@0: typedef struct dh_method DH_METHOD; sl@0: sl@0: typedef struct dsa_st DSA; sl@0: typedef struct dsa_method DSA_METHOD; sl@0: sl@0: typedef struct rsa_st RSA; sl@0: typedef struct rsa_meth_st RSA_METHOD; sl@0: sl@0: typedef struct rand_meth_st RAND_METHOD; sl@0: sl@0: typedef struct ecdh_method ECDH_METHOD; sl@0: typedef struct ecdsa_method ECDSA_METHOD; sl@0: sl@0: typedef struct x509_st X509; sl@0: typedef struct X509_algor_st X509_ALGOR; sl@0: typedef struct X509_crl_st X509_CRL; sl@0: typedef struct X509_name_st X509_NAME; sl@0: typedef struct x509_store_st X509_STORE; sl@0: typedef struct x509_store_ctx_st X509_STORE_CTX; sl@0: sl@0: typedef struct v3_ext_ctx X509V3_CTX; sl@0: typedef struct conf_st CONF; sl@0: sl@0: typedef struct store_st STORE; sl@0: typedef struct store_method_st STORE_METHOD; sl@0: sl@0: typedef struct ui_st UI; sl@0: typedef struct ui_method_st UI_METHOD; sl@0: sl@0: typedef struct st_ERR_FNS ERR_FNS; sl@0: sl@0: typedef struct engine_st ENGINE; sl@0: sl@0: typedef struct X509_POLICY_NODE_st X509_POLICY_NODE; sl@0: typedef struct X509_POLICY_LEVEL_st X509_POLICY_LEVEL; sl@0: typedef struct X509_POLICY_TREE_st X509_POLICY_TREE; sl@0: typedef struct X509_POLICY_CACHE_st X509_POLICY_CACHE; sl@0: sl@0: /* If placed in pkcs12.h, we end up with a circular depency with pkcs7.h */ sl@0: #define DECLARE_PKCS12_STACK_OF(type) /* Nothing */ sl@0: #define IMPLEMENT_PKCS12_STACK_OF(type) /* Nothing */ sl@0: sl@0: typedef struct crypto_ex_data_st CRYPTO_EX_DATA; sl@0: /* Callback types for crypto.h */ sl@0: typedef int CRYPTO_EX_new(void *parent, void *ptr, CRYPTO_EX_DATA *ad, sl@0: int idx, long argl, void *argp); sl@0: typedef void CRYPTO_EX_free(void *parent, void *ptr, CRYPTO_EX_DATA *ad, sl@0: int idx, long argl, void *argp); sl@0: typedef int CRYPTO_EX_dup(CRYPTO_EX_DATA *to, CRYPTO_EX_DATA *from, void *from_d, sl@0: int idx, long argl, void *argp); sl@0: sl@0: #endif /* def HEADER_OPENSSL_TYPES_H */