epoc32/include/stdapis/openssl/x509.h
author William Roberts <williamr@symbian.org>
Wed, 31 Mar 2010 12:27:01 +0100
branchSymbian2
changeset 3 e1b950c65cb4
parent 0 061f57f2323e
permissions -rw-r--r--
Attempt to represent the S^2->S^3 header reorganisation as a series of "hg rename" operations
williamr@2
     1
/* crypto/x509/x509.h */
williamr@2
     2
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
williamr@2
     3
 * All rights reserved.
williamr@2
     4
 *
williamr@2
     5
 * This package is an SSL implementation written
williamr@2
     6
 * by Eric Young (eay@cryptsoft.com).
williamr@2
     7
 * The implementation was written so as to conform with Netscapes SSL.
williamr@2
     8
 * 
williamr@2
     9
 * This library is free for commercial and non-commercial use as long as
williamr@2
    10
 * the following conditions are aheared to.  The following conditions
williamr@2
    11
 * apply to all code found in this distribution, be it the RC4, RSA,
williamr@2
    12
 * lhash, DES, etc., code; not just the SSL code.  The SSL documentation
williamr@2
    13
 * included with this distribution is covered by the same copyright terms
williamr@2
    14
 * except that the holder is Tim Hudson (tjh@cryptsoft.com).
williamr@2
    15
 * 
williamr@2
    16
 * Copyright remains Eric Young's, and as such any Copyright notices in
williamr@2
    17
 * the code are not to be removed.
williamr@2
    18
 * If this package is used in a product, Eric Young should be given attribution
williamr@2
    19
 * as the author of the parts of the library used.
williamr@2
    20
 * This can be in the form of a textual message at program startup or
williamr@2
    21
 * in documentation (online or textual) provided with the package.
williamr@2
    22
 * 
williamr@2
    23
 * Redistribution and use in source and binary forms, with or without
williamr@2
    24
 * modification, are permitted provided that the following conditions
williamr@2
    25
 * are met:
williamr@2
    26
 * 1. Redistributions of source code must retain the copyright
williamr@2
    27
 *    notice, this list of conditions and the following disclaimer.
williamr@2
    28
 * 2. Redistributions in binary form must reproduce the above copyright
williamr@2
    29
 *    notice, this list of conditions and the following disclaimer in the
williamr@2
    30
 *    documentation and/or other materials provided with the distribution.
williamr@2
    31
 * 3. All advertising materials mentioning features or use of this software
williamr@2
    32
 *    must display the following acknowledgement:
williamr@2
    33
 *    "This product includes cryptographic software written by
williamr@2
    34
 *     Eric Young (eay@cryptsoft.com)"
williamr@2
    35
 *    The word 'cryptographic' can be left out if the rouines from the library
williamr@2
    36
 *    being used are not cryptographic related :-).
williamr@2
    37
 * 4. If you include any Windows specific code (or a derivative thereof) from 
williamr@2
    38
 *    the apps directory (application code) you must include an acknowledgement:
williamr@2
    39
 *    "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
williamr@2
    40
 * 
williamr@2
    41
 * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
williamr@2
    42
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
williamr@2
    43
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
williamr@2
    44
 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
williamr@2
    45
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
williamr@2
    46
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
williamr@2
    47
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
williamr@2
    48
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
williamr@2
    49
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
williamr@2
    50
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
williamr@2
    51
 * SUCH DAMAGE.
williamr@2
    52
 * 
williamr@2
    53
 * The licence and distribution terms for any publically available version or
williamr@2
    54
 * derivative of this code cannot be changed.  i.e. this code cannot simply be
williamr@2
    55
 * copied and put under another distribution licence
williamr@2
    56
 * [including the GNU Public Licence.]
williamr@2
    57
 */
williamr@2
    58
/* ====================================================================
williamr@2
    59
 * Copyright 2002 Sun Microsystems, Inc. ALL RIGHTS RESERVED.
williamr@2
    60
 * ECDH support in OpenSSL originally developed by 
williamr@2
    61
 * SUN MICROSYSTEMS, INC., and contributed to the OpenSSL project.
williamr@2
    62
 */
williamr@2
    63
/*
williamr@2
    64
 © Portions copyright (c) 2006 Nokia Corporation.  All rights reserved.
williamr@2
    65
 */
williamr@2
    66
williamr@2
    67
#ifndef HEADER_X509_H
williamr@2
    68
#define HEADER_X509_H
williamr@2
    69
williamr@2
    70
#if (defined(__SYMBIAN32__) && !defined(SYMBIAN))
williamr@2
    71
#define SYMBIAN
williamr@2
    72
#endif
williamr@2
    73
williamr@2
    74
williamr@2
    75
#ifdef SYMBIAN
williamr@2
    76
#include <e32def.h>
williamr@2
    77
#endif
williamr@2
    78
#include <openssl/e_os2.h>
williamr@2
    79
#include <openssl/symhacks.h>
williamr@2
    80
#ifndef OPENSSL_NO_BUFFER
williamr@2
    81
#include <openssl/buffer.h>
williamr@2
    82
#endif
williamr@2
    83
#ifndef OPENSSL_NO_EVP
williamr@2
    84
#include <openssl/evp.h>
williamr@2
    85
#endif
williamr@2
    86
#ifndef OPENSSL_NO_BIO
williamr@2
    87
#include <openssl/bio.h>
williamr@2
    88
#endif
williamr@2
    89
#include <openssl/stack.h>
williamr@2
    90
#include <openssl/asn1.h>
williamr@2
    91
#include <openssl/safestack.h>
williamr@2
    92
williamr@2
    93
#ifndef OPENSSL_NO_EC
williamr@2
    94
#include <openssl/ec.h>
williamr@2
    95
#endif
williamr@2
    96
williamr@2
    97
#ifndef OPENSSL_NO_ECDSA
williamr@2
    98
#include <openssl/ecdsa.h>
williamr@2
    99
#endif
williamr@2
   100
williamr@2
   101
#ifndef OPENSSL_NO_ECDH
williamr@2
   102
#include <openssl/ecdh.h>
williamr@2
   103
#endif
williamr@2
   104
williamr@2
   105
#ifndef OPENSSL_NO_DEPRECATED
williamr@2
   106
#ifndef OPENSSL_NO_RSA
williamr@2
   107
#include <openssl/rsa.h>
williamr@2
   108
#endif
williamr@2
   109
#ifndef OPENSSL_NO_DSA
williamr@2
   110
#include <openssl/dsa.h>
williamr@2
   111
#endif
williamr@2
   112
#ifndef OPENSSL_NO_DH
williamr@2
   113
#include <openssl/dh.h>
williamr@2
   114
#endif
williamr@2
   115
#endif
williamr@2
   116
williamr@2
   117
#ifndef OPENSSL_NO_SHA
williamr@2
   118
#include <openssl/sha.h>
williamr@2
   119
#endif
williamr@2
   120
williamr@2
   121
williamr@2
   122
#include <openssl/ossl_typ.h>
williamr@2
   123
williamr@2
   124
#ifdef  __cplusplus
williamr@2
   125
extern "C" {
williamr@2
   126
#endif
williamr@2
   127
williamr@2
   128
#ifdef OPENSSL_SYS_WIN32
williamr@2
   129
/* Under Win32 these are defined in wincrypt.h */
williamr@2
   130
#undef X509_NAME
williamr@2
   131
#undef X509_CERT_PAIR
williamr@2
   132
#endif
williamr@2
   133
williamr@2
   134
#define X509_FILETYPE_PEM	1
williamr@2
   135
#define X509_FILETYPE_ASN1	2
williamr@2
   136
#define X509_FILETYPE_DEFAULT	3
williamr@2
   137
williamr@2
   138
#define X509v3_KU_DIGITAL_SIGNATURE	0x0080
williamr@2
   139
#define X509v3_KU_NON_REPUDIATION	0x0040
williamr@2
   140
#define X509v3_KU_KEY_ENCIPHERMENT	0x0020
williamr@2
   141
#define X509v3_KU_DATA_ENCIPHERMENT	0x0010
williamr@2
   142
#define X509v3_KU_KEY_AGREEMENT		0x0008
williamr@2
   143
#define X509v3_KU_KEY_CERT_SIGN		0x0004
williamr@2
   144
#define X509v3_KU_CRL_SIGN		0x0002
williamr@2
   145
#define X509v3_KU_ENCIPHER_ONLY		0x0001
williamr@2
   146
#define X509v3_KU_DECIPHER_ONLY		0x8000
williamr@2
   147
#define X509v3_KU_UNDEF			0xffff
williamr@2
   148
williamr@2
   149
typedef struct X509_objects_st
williamr@2
   150
	{
williamr@2
   151
	int nid;
williamr@2
   152
	int (*a2i)(void);
williamr@2
   153
	int (*i2a)(void);
williamr@2
   154
	} X509_OBJECTS;
williamr@2
   155
williamr@2
   156
struct X509_algor_st
williamr@2
   157
	{
williamr@2
   158
	ASN1_OBJECT *algorithm;
williamr@2
   159
	ASN1_TYPE *parameter;
williamr@2
   160
	} /* X509_ALGOR */;
williamr@2
   161
williamr@2
   162
DECLARE_STACK_OF(X509_ALGOR)
williamr@2
   163
DECLARE_ASN1_SET_OF(X509_ALGOR)
williamr@2
   164
williamr@2
   165
typedef struct X509_val_st
williamr@2
   166
	{
williamr@2
   167
	ASN1_TIME *notBefore;
williamr@2
   168
	ASN1_TIME *notAfter;
williamr@2
   169
	} X509_VAL;
williamr@2
   170
williamr@2
   171
typedef struct X509_pubkey_st
williamr@2
   172
	{
williamr@2
   173
	X509_ALGOR *algor;
williamr@2
   174
	ASN1_BIT_STRING *public_key;
williamr@2
   175
	EVP_PKEY *pkey;
williamr@2
   176
	} X509_PUBKEY;
williamr@2
   177
williamr@2
   178
typedef struct X509_sig_st
williamr@2
   179
	{
williamr@2
   180
	X509_ALGOR *algor;
williamr@2
   181
	ASN1_OCTET_STRING *digest;
williamr@2
   182
	} X509_SIG;
williamr@2
   183
williamr@2
   184
typedef struct X509_name_entry_st
williamr@2
   185
	{
williamr@2
   186
	ASN1_OBJECT *object;
williamr@2
   187
	ASN1_STRING *value;
williamr@2
   188
	int set;
williamr@2
   189
	int size; 	/* temp variable */
williamr@2
   190
	} X509_NAME_ENTRY;
williamr@2
   191
williamr@2
   192
DECLARE_STACK_OF(X509_NAME_ENTRY)
williamr@2
   193
DECLARE_ASN1_SET_OF(X509_NAME_ENTRY)
williamr@2
   194
williamr@2
   195
/* we always keep X509_NAMEs in 2 forms. */
williamr@2
   196
struct X509_name_st
williamr@2
   197
	{
williamr@2
   198
	STACK_OF(X509_NAME_ENTRY) *entries;
williamr@2
   199
	int modified;	/* true if 'bytes' needs to be built */
williamr@2
   200
#ifndef OPENSSL_NO_BUFFER
williamr@2
   201
	BUF_MEM *bytes;
williamr@2
   202
#else
williamr@2
   203
	char *bytes;
williamr@2
   204
#endif
williamr@2
   205
	unsigned long hash; /* Keep the hash around for lookups */
williamr@2
   206
	} /* X509_NAME */;
williamr@2
   207
williamr@2
   208
DECLARE_STACK_OF(X509_NAME)
williamr@2
   209
williamr@2
   210
#define X509_EX_V_NETSCAPE_HACK		0x8000
williamr@2
   211
#define X509_EX_V_INIT			0x0001
williamr@2
   212
typedef struct X509_extension_st
williamr@2
   213
	{
williamr@2
   214
	ASN1_OBJECT *object;
williamr@2
   215
	ASN1_BOOLEAN critical;
williamr@2
   216
	ASN1_OCTET_STRING *value;
williamr@2
   217
	} X509_EXTENSION;
williamr@2
   218
williamr@2
   219
DECLARE_STACK_OF(X509_EXTENSION)
williamr@2
   220
DECLARE_ASN1_SET_OF(X509_EXTENSION)
williamr@2
   221
williamr@2
   222
/* a sequence of these are used */
williamr@2
   223
typedef struct x509_attributes_st
williamr@2
   224
	{
williamr@2
   225
	ASN1_OBJECT *object;
williamr@2
   226
	int single; /* 0 for a set, 1 for a single item (which is wrong) */
williamr@2
   227
	union	{
williamr@2
   228
		char		*ptr;
williamr@2
   229
/* 0 */		STACK_OF(ASN1_TYPE) *set;
williamr@2
   230
/* 1 */		ASN1_TYPE	*single;
williamr@2
   231
		} value;
williamr@2
   232
	} X509_ATTRIBUTE;
williamr@2
   233
williamr@2
   234
DECLARE_STACK_OF(X509_ATTRIBUTE)
williamr@2
   235
DECLARE_ASN1_SET_OF(X509_ATTRIBUTE)
williamr@2
   236
williamr@2
   237
williamr@2
   238
typedef struct X509_req_info_st
williamr@2
   239
	{
williamr@2
   240
	ASN1_ENCODING enc;
williamr@2
   241
	ASN1_INTEGER *version;
williamr@2
   242
	X509_NAME *subject;
williamr@2
   243
	X509_PUBKEY *pubkey;
williamr@2
   244
	/*  d=2 hl=2 l=  0 cons: cont: 00 */
williamr@2
   245
	STACK_OF(X509_ATTRIBUTE) *attributes; /* [ 0 ] */
williamr@2
   246
	} X509_REQ_INFO;
williamr@2
   247
williamr@2
   248
typedef struct X509_req_st
williamr@2
   249
	{
williamr@2
   250
	X509_REQ_INFO *req_info;
williamr@2
   251
	X509_ALGOR *sig_alg;
williamr@2
   252
	ASN1_BIT_STRING *signature;
williamr@2
   253
	int references;
williamr@2
   254
	} X509_REQ;
williamr@2
   255
williamr@2
   256
typedef struct x509_cinf_st
williamr@2
   257
	{
williamr@2
   258
	ASN1_INTEGER *version;		/* [ 0 ] default of v1 */
williamr@2
   259
	ASN1_INTEGER *serialNumber;
williamr@2
   260
	X509_ALGOR *signature;
williamr@2
   261
	X509_NAME *issuer;
williamr@2
   262
	X509_VAL *validity;
williamr@2
   263
	X509_NAME *subject;
williamr@2
   264
	X509_PUBKEY *key;
williamr@2
   265
	ASN1_BIT_STRING *issuerUID;		/* [ 1 ] optional in v2 */
williamr@2
   266
	ASN1_BIT_STRING *subjectUID;		/* [ 2 ] optional in v2 */
williamr@2
   267
	STACK_OF(X509_EXTENSION) *extensions;	/* [ 3 ] optional in v3 */
williamr@2
   268
	} X509_CINF;
williamr@2
   269
williamr@2
   270
/* This stuff is certificate "auxiliary info"
williamr@2
   271
 * it contains details which are useful in certificate
williamr@2
   272
 * stores and databases. When used this is tagged onto
williamr@2
   273
 * the end of the certificate itself
williamr@2
   274
 */
williamr@2
   275
williamr@2
   276
typedef struct x509_cert_aux_st
williamr@2
   277
	{
williamr@2
   278
	STACK_OF(ASN1_OBJECT) *trust;		/* trusted uses */
williamr@2
   279
	STACK_OF(ASN1_OBJECT) *reject;		/* rejected uses */
williamr@2
   280
	ASN1_UTF8STRING *alias;			/* "friendly name" */
williamr@2
   281
	ASN1_OCTET_STRING *keyid;		/* key id of private key */
williamr@2
   282
	STACK_OF(X509_ALGOR) *other;		/* other unspecified info */
williamr@2
   283
	} X509_CERT_AUX;
williamr@2
   284
williamr@2
   285
struct x509_st
williamr@2
   286
	{
williamr@2
   287
	X509_CINF *cert_info;
williamr@2
   288
	X509_ALGOR *sig_alg;
williamr@2
   289
	ASN1_BIT_STRING *signature;
williamr@2
   290
	int valid;
williamr@2
   291
	int references;
williamr@2
   292
	char *name;
williamr@2
   293
	CRYPTO_EX_DATA ex_data;
williamr@2
   294
	/* These contain copies of various extension values */
williamr@2
   295
	long ex_pathlen;
williamr@2
   296
	long ex_pcpathlen;
williamr@2
   297
	unsigned long ex_flags;
williamr@2
   298
	unsigned long ex_kusage;
williamr@2
   299
	unsigned long ex_xkusage;
williamr@2
   300
	unsigned long ex_nscert;
williamr@2
   301
	ASN1_OCTET_STRING *skid;
williamr@2
   302
	struct AUTHORITY_KEYID_st *akid;
williamr@2
   303
	X509_POLICY_CACHE *policy_cache;
williamr@2
   304
#ifndef OPENSSL_NO_SHA
williamr@2
   305
	unsigned char sha1_hash[SHA_DIGEST_LENGTH];
williamr@2
   306
#endif
williamr@2
   307
	X509_CERT_AUX *aux;
williamr@2
   308
	} /* X509 */;
williamr@2
   309
williamr@2
   310
DECLARE_STACK_OF(X509)
williamr@2
   311
DECLARE_ASN1_SET_OF(X509)
williamr@2
   312
williamr@2
   313
/* This is used for a table of trust checking functions */
williamr@2
   314
williamr@2
   315
typedef struct x509_trust_st {
williamr@2
   316
	int trust;
williamr@2
   317
	int flags;
williamr@2
   318
	int (*check_trust)(struct x509_trust_st *, X509 *, int);
williamr@2
   319
	char *name;
williamr@2
   320
	int arg1;
williamr@2
   321
	void *arg2;
williamr@2
   322
} X509_TRUST;
williamr@2
   323
williamr@2
   324
DECLARE_STACK_OF(X509_TRUST)
williamr@2
   325
williamr@2
   326
typedef struct x509_cert_pair_st {
williamr@2
   327
	X509 *forward;
williamr@2
   328
	X509 *reverse;
williamr@2
   329
} X509_CERT_PAIR;
williamr@2
   330
williamr@2
   331
/* standard trust ids */
williamr@2
   332
williamr@2
   333
#define X509_TRUST_DEFAULT	-1	/* Only valid in purpose settings */
williamr@2
   334
williamr@2
   335
#define X509_TRUST_COMPAT	1
williamr@2
   336
#define X509_TRUST_SSL_CLIENT	2
williamr@2
   337
#define X509_TRUST_SSL_SERVER	3
williamr@2
   338
#define X509_TRUST_EMAIL	4
williamr@2
   339
#define X509_TRUST_OBJECT_SIGN	5
williamr@2
   340
#define X509_TRUST_OCSP_SIGN	6
williamr@2
   341
#define X509_TRUST_OCSP_REQUEST	7
williamr@2
   342
williamr@2
   343
/* Keep these up to date! */
williamr@2
   344
#define X509_TRUST_MIN		1
williamr@2
   345
#define X509_TRUST_MAX		7
williamr@2
   346
williamr@2
   347
williamr@2
   348
/* trust_flags values */
williamr@2
   349
#define	X509_TRUST_DYNAMIC 	1
williamr@2
   350
#define	X509_TRUST_DYNAMIC_NAME	2
williamr@2
   351
williamr@2
   352
/* check_trust return codes */
williamr@2
   353
williamr@2
   354
#define X509_TRUST_TRUSTED	1
williamr@2
   355
#define X509_TRUST_REJECTED	2
williamr@2
   356
#define X509_TRUST_UNTRUSTED	3
williamr@2
   357
williamr@2
   358
/* Flags for X509_print_ex() */
williamr@2
   359
williamr@2
   360
#define	X509_FLAG_COMPAT		0
williamr@2
   361
#define	X509_FLAG_NO_HEADER		1L
williamr@2
   362
#define	X509_FLAG_NO_VERSION		(1L << 1)
williamr@2
   363
#define	X509_FLAG_NO_SERIAL		(1L << 2)
williamr@2
   364
#define	X509_FLAG_NO_SIGNAME		(1L << 3)
williamr@2
   365
#define	X509_FLAG_NO_ISSUER		(1L << 4)
williamr@2
   366
#define	X509_FLAG_NO_VALIDITY		(1L << 5)
williamr@2
   367
#define	X509_FLAG_NO_SUBJECT		(1L << 6)
williamr@2
   368
#define	X509_FLAG_NO_PUBKEY		(1L << 7)
williamr@2
   369
#define	X509_FLAG_NO_EXTENSIONS		(1L << 8)
williamr@2
   370
#define	X509_FLAG_NO_SIGDUMP		(1L << 9)
williamr@2
   371
#define	X509_FLAG_NO_AUX		(1L << 10)
williamr@2
   372
#define	X509_FLAG_NO_ATTRIBUTES		(1L << 11)
williamr@2
   373
williamr@2
   374
/* Flags specific to X509_NAME_print_ex() */	
williamr@2
   375
williamr@2
   376
/* The field separator information */
williamr@2
   377
williamr@2
   378
#define XN_FLAG_SEP_MASK	(0xf << 16)
williamr@2
   379
williamr@2
   380
#define XN_FLAG_COMPAT		0		/* Traditional SSLeay: use old X509_NAME_print */
williamr@2
   381
#define XN_FLAG_SEP_COMMA_PLUS	(1 << 16)	/* RFC2253 ,+ */
williamr@2
   382
#define XN_FLAG_SEP_CPLUS_SPC	(2 << 16)	/* ,+ spaced: more readable */
williamr@2
   383
#define XN_FLAG_SEP_SPLUS_SPC	(3 << 16)	/* ;+ spaced */
williamr@2
   384
#define XN_FLAG_SEP_MULTILINE	(4 << 16)	/* One line per field */
williamr@2
   385
williamr@2
   386
#define XN_FLAG_DN_REV		(1 << 20)	/* Reverse DN order */
williamr@2
   387
williamr@2
   388
/* How the field name is shown */
williamr@2
   389
williamr@2
   390
#define XN_FLAG_FN_MASK		(0x3 << 21)
williamr@2
   391
williamr@2
   392
#define XN_FLAG_FN_SN		0		/* Object short name */
williamr@2
   393
#define XN_FLAG_FN_LN		(1 << 21)	/* Object long name */
williamr@2
   394
#define XN_FLAG_FN_OID		(2 << 21)	/* Always use OIDs */
williamr@2
   395
#define XN_FLAG_FN_NONE		(3 << 21)	/* No field names */
williamr@2
   396
williamr@2
   397
#define XN_FLAG_SPC_EQ		(1 << 23)	/* Put spaces round '=' */
williamr@2
   398
williamr@2
   399
/* This determines if we dump fields we don't recognise:
williamr@2
   400
 * RFC2253 requires this.
williamr@2
   401
 */
williamr@2
   402
williamr@2
   403
#define XN_FLAG_DUMP_UNKNOWN_FIELDS (1 << 24)
williamr@2
   404
williamr@2
   405
#define XN_FLAG_FN_ALIGN	(1 << 25)	/* Align field names to 20 characters */
williamr@2
   406
williamr@2
   407
/* Complete set of RFC2253 flags */
williamr@2
   408
williamr@2
   409
#define XN_FLAG_RFC2253 (ASN1_STRFLGS_RFC2253 | \
williamr@2
   410
			XN_FLAG_SEP_COMMA_PLUS | \
williamr@2
   411
			XN_FLAG_DN_REV | \
williamr@2
   412
			XN_FLAG_FN_SN | \
williamr@2
   413
			XN_FLAG_DUMP_UNKNOWN_FIELDS)
williamr@2
   414
williamr@2
   415
/* readable oneline form */
williamr@2
   416
williamr@2
   417
#define XN_FLAG_ONELINE (ASN1_STRFLGS_RFC2253 | \
williamr@2
   418
			ASN1_STRFLGS_ESC_QUOTE | \
williamr@2
   419
			XN_FLAG_SEP_CPLUS_SPC | \
williamr@2
   420
			XN_FLAG_SPC_EQ | \
williamr@2
   421
			XN_FLAG_FN_SN)
williamr@2
   422
williamr@2
   423
/* readable multiline form */
williamr@2
   424
williamr@2
   425
#define XN_FLAG_MULTILINE (ASN1_STRFLGS_ESC_CTRL | \
williamr@2
   426
			ASN1_STRFLGS_ESC_MSB | \
williamr@2
   427
			XN_FLAG_SEP_MULTILINE | \
williamr@2
   428
			XN_FLAG_SPC_EQ | \
williamr@2
   429
			XN_FLAG_FN_LN | \
williamr@2
   430
			XN_FLAG_FN_ALIGN)
williamr@2
   431
williamr@2
   432
typedef struct X509_revoked_st
williamr@2
   433
	{
williamr@2
   434
	ASN1_INTEGER *serialNumber;
williamr@2
   435
	ASN1_TIME *revocationDate;
williamr@2
   436
	STACK_OF(X509_EXTENSION) /* optional */ *extensions;
williamr@2
   437
	int sequence; /* load sequence */
williamr@2
   438
	} X509_REVOKED;
williamr@2
   439
williamr@2
   440
DECLARE_STACK_OF(X509_REVOKED)
williamr@2
   441
DECLARE_ASN1_SET_OF(X509_REVOKED)
williamr@2
   442
williamr@2
   443
typedef struct X509_crl_info_st
williamr@2
   444
	{
williamr@2
   445
	ASN1_INTEGER *version;
williamr@2
   446
	X509_ALGOR *sig_alg;
williamr@2
   447
	X509_NAME *issuer;
williamr@2
   448
	ASN1_TIME *lastUpdate;
williamr@2
   449
	ASN1_TIME *nextUpdate;
williamr@2
   450
	STACK_OF(X509_REVOKED) *revoked;
williamr@2
   451
	STACK_OF(X509_EXTENSION) /* [0] */ *extensions;
williamr@2
   452
	ASN1_ENCODING enc;
williamr@2
   453
	} X509_CRL_INFO;
williamr@2
   454
williamr@2
   455
struct X509_crl_st
williamr@2
   456
	{
williamr@2
   457
	/* actual signature */
williamr@2
   458
	X509_CRL_INFO *crl;
williamr@2
   459
	X509_ALGOR *sig_alg;
williamr@2
   460
	ASN1_BIT_STRING *signature;
williamr@2
   461
	int references;
williamr@2
   462
	} /* X509_CRL */;
williamr@2
   463
williamr@2
   464
DECLARE_STACK_OF(X509_CRL)
williamr@2
   465
DECLARE_ASN1_SET_OF(X509_CRL)
williamr@2
   466
williamr@2
   467
typedef struct private_key_st
williamr@2
   468
	{
williamr@2
   469
	int version;
williamr@2
   470
	/* The PKCS#8 data types */
williamr@2
   471
	X509_ALGOR *enc_algor;
williamr@2
   472
	ASN1_OCTET_STRING *enc_pkey;	/* encrypted pub key */
williamr@2
   473
williamr@2
   474
	/* When decrypted, the following will not be NULL */
williamr@2
   475
	EVP_PKEY *dec_pkey;
williamr@2
   476
williamr@2
   477
	/* used to encrypt and decrypt */
williamr@2
   478
	int key_length;
williamr@2
   479
	char *key_data;
williamr@2
   480
	int key_free;	/* true if we should auto free key_data */
williamr@2
   481
williamr@2
   482
	/* expanded version of 'enc_algor' */
williamr@2
   483
	EVP_CIPHER_INFO cipher;
williamr@2
   484
williamr@2
   485
	int references;
williamr@2
   486
	} X509_PKEY;
williamr@2
   487
williamr@2
   488
#ifndef OPENSSL_NO_EVP
williamr@2
   489
typedef struct X509_info_st
williamr@2
   490
	{
williamr@2
   491
	X509 *x509;
williamr@2
   492
	X509_CRL *crl;
williamr@2
   493
	X509_PKEY *x_pkey;
williamr@2
   494
williamr@2
   495
	EVP_CIPHER_INFO enc_cipher;
williamr@2
   496
	int enc_len;
williamr@2
   497
	char *enc_data;
williamr@2
   498
williamr@2
   499
	int references;
williamr@2
   500
	} X509_INFO;
williamr@2
   501
williamr@2
   502
DECLARE_STACK_OF(X509_INFO)
williamr@2
   503
#endif
williamr@2
   504
williamr@2
   505
/* The next 2 structures and their 8 routines were sent to me by
williamr@2
   506
 * Pat Richard <patr@x509.com> and are used to manipulate
williamr@2
   507
 * Netscapes spki structures - useful if you are writing a CA web page
williamr@2
   508
 */
williamr@2
   509
typedef struct Netscape_spkac_st
williamr@2
   510
	{
williamr@2
   511
	X509_PUBKEY *pubkey;
williamr@2
   512
	ASN1_IA5STRING *challenge;	/* challenge sent in atlas >= PR2 */
williamr@2
   513
	} NETSCAPE_SPKAC;
williamr@2
   514
williamr@2
   515
typedef struct Netscape_spki_st
williamr@2
   516
	{
williamr@2
   517
	NETSCAPE_SPKAC *spkac;	/* signed public key and challenge */
williamr@2
   518
	X509_ALGOR *sig_algor;
williamr@2
   519
	ASN1_BIT_STRING *signature;
williamr@2
   520
	} NETSCAPE_SPKI;
williamr@2
   521
williamr@2
   522
/* Netscape certificate sequence structure */
williamr@2
   523
typedef struct Netscape_certificate_sequence
williamr@2
   524
	{
williamr@2
   525
	ASN1_OBJECT *type;
williamr@2
   526
	STACK_OF(X509) *certs;
williamr@2
   527
	} NETSCAPE_CERT_SEQUENCE;
williamr@2
   528
williamr@2
   529
/* Unused (and iv length is wrong)
williamr@2
   530
typedef struct CBCParameter_st
williamr@2
   531
	{
williamr@2
   532
	unsigned char iv[8];
williamr@2
   533
	} CBC_PARAM;
williamr@2
   534
*/
williamr@2
   535
williamr@2
   536
/* Password based encryption structure */
williamr@2
   537
williamr@2
   538
typedef struct PBEPARAM_st {
williamr@2
   539
ASN1_OCTET_STRING *salt;
williamr@2
   540
ASN1_INTEGER *iter;
williamr@2
   541
} PBEPARAM;
williamr@2
   542
williamr@2
   543
/* Password based encryption V2 structures */
williamr@2
   544
williamr@2
   545
typedef struct PBE2PARAM_st {
williamr@2
   546
X509_ALGOR *keyfunc;
williamr@2
   547
X509_ALGOR *encryption;
williamr@2
   548
} PBE2PARAM;
williamr@2
   549
williamr@2
   550
typedef struct PBKDF2PARAM_st {
williamr@2
   551
ASN1_TYPE *salt;	/* Usually OCTET STRING but could be anything */
williamr@2
   552
ASN1_INTEGER *iter;
williamr@2
   553
ASN1_INTEGER *keylength;
williamr@2
   554
X509_ALGOR *prf;
williamr@2
   555
} PBKDF2PARAM;
williamr@2
   556
williamr@2
   557
williamr@2
   558
/* PKCS#8 private key info structure */
williamr@2
   559
williamr@2
   560
typedef struct pkcs8_priv_key_info_st
williamr@2
   561
        {
williamr@2
   562
        int broken;     /* Flag for various broken formats */
williamr@2
   563
#define PKCS8_OK		0
williamr@2
   564
#define PKCS8_NO_OCTET		1
williamr@2
   565
#define PKCS8_EMBEDDED_PARAM	2
williamr@2
   566
#define PKCS8_NS_DB		3
williamr@2
   567
        ASN1_INTEGER *version;
williamr@2
   568
        X509_ALGOR *pkeyalg;
williamr@2
   569
        ASN1_TYPE *pkey; /* Should be OCTET STRING but some are broken */
williamr@2
   570
        STACK_OF(X509_ATTRIBUTE) *attributes;
williamr@2
   571
        } PKCS8_PRIV_KEY_INFO;
williamr@2
   572
williamr@2
   573
#ifdef  __cplusplus
williamr@2
   574
}
williamr@2
   575
#endif
williamr@2
   576
williamr@2
   577
#include <openssl/x509_vfy.h>
williamr@2
   578
#include <openssl/pkcs7.h>
williamr@2
   579
williamr@2
   580
#ifdef  __cplusplus
williamr@2
   581
extern "C" {
williamr@2
   582
#endif
williamr@2
   583
williamr@2
   584
#ifdef SSLEAY_MACROS
williamr@2
   585
#define X509_verify(a,r) ASN1_verify((int (*)())i2d_X509_CINF,a->sig_alg,\
williamr@2
   586
	a->signature,(char *)a->cert_info,r)
williamr@2
   587
#define X509_REQ_verify(a,r) ASN1_verify((int (*)())i2d_X509_REQ_INFO, \
williamr@2
   588
	a->sig_alg,a->signature,(char *)a->req_info,r)
williamr@2
   589
#define X509_CRL_verify(a,r) ASN1_verify((int (*)())i2d_X509_CRL_INFO, \
williamr@2
   590
	a->sig_alg, a->signature,(char *)a->crl,r)
williamr@2
   591
williamr@2
   592
#define X509_sign(x,pkey,md) \
williamr@2
   593
	ASN1_sign((int (*)())i2d_X509_CINF, x->cert_info->signature, \
williamr@2
   594
		x->sig_alg, x->signature, (char *)x->cert_info,pkey,md)
williamr@2
   595
#define X509_REQ_sign(x,pkey,md) \
williamr@2
   596
	ASN1_sign((int (*)())i2d_X509_REQ_INFO,x->sig_alg, NULL, \
williamr@2
   597
		x->signature, (char *)x->req_info,pkey,md)
williamr@2
   598
#define X509_CRL_sign(x,pkey,md) \
williamr@2
   599
	ASN1_sign((int (*)())i2d_X509_CRL_INFO,x->crl->sig_alg,x->sig_alg, \
williamr@2
   600
		x->signature, (char *)x->crl,pkey,md)
williamr@2
   601
#define NETSCAPE_SPKI_sign(x,pkey,md) \
williamr@2
   602
	ASN1_sign((int (*)())i2d_NETSCAPE_SPKAC, x->sig_algor,NULL, \
williamr@2
   603
		x->signature, (char *)x->spkac,pkey,md)
williamr@2
   604
williamr@2
   605
#define X509_dup(x509) (X509 *)ASN1_dup((int (*)())i2d_X509, \
williamr@2
   606
		(char *(*)())d2i_X509,(char *)x509)
williamr@2
   607
#define X509_ATTRIBUTE_dup(xa) (X509_ATTRIBUTE *)ASN1_dup(\
williamr@2
   608
		(int (*)())i2d_X509_ATTRIBUTE, \
williamr@2
   609
		(char *(*)())d2i_X509_ATTRIBUTE,(char *)xa)
williamr@2
   610
#define X509_EXTENSION_dup(ex) (X509_EXTENSION *)ASN1_dup( \
williamr@2
   611
		(int (*)())i2d_X509_EXTENSION, \
williamr@2
   612
		(char *(*)())d2i_X509_EXTENSION,(char *)ex)
williamr@2
   613
#define d2i_X509_fp(fp,x509) (X509 *)ASN1_d2i_fp((char *(*)())X509_new, \
williamr@2
   614
		(char *(*)())d2i_X509, (fp),(unsigned char **)(x509))
williamr@2
   615
#define i2d_X509_fp(fp,x509) ASN1_i2d_fp(i2d_X509,fp,(unsigned char *)x509)
williamr@2
   616
#define d2i_X509_bio(bp,x509) (X509 *)ASN1_d2i_bio((char *(*)())X509_new, \
williamr@2
   617
		(char *(*)())d2i_X509, (bp),(unsigned char **)(x509))
williamr@2
   618
#define i2d_X509_bio(bp,x509) ASN1_i2d_bio(i2d_X509,bp,(unsigned char *)x509)
williamr@2
   619
williamr@2
   620
#define X509_CRL_dup(crl) (X509_CRL *)ASN1_dup((int (*)())i2d_X509_CRL, \
williamr@2
   621
		(char *(*)())d2i_X509_CRL,(char *)crl)
williamr@2
   622
#define d2i_X509_CRL_fp(fp,crl) (X509_CRL *)ASN1_d2i_fp((char *(*)()) \
williamr@2
   623
		X509_CRL_new,(char *(*)())d2i_X509_CRL, (fp),\
williamr@2
   624
		(unsigned char **)(crl))
williamr@2
   625
#define i2d_X509_CRL_fp(fp,crl) ASN1_i2d_fp(i2d_X509_CRL,fp,\
williamr@2
   626
		(unsigned char *)crl)
williamr@2
   627
#define d2i_X509_CRL_bio(bp,crl) (X509_CRL *)ASN1_d2i_bio((char *(*)()) \
williamr@2
   628
		X509_CRL_new,(char *(*)())d2i_X509_CRL, (bp),\
williamr@2
   629
		(unsigned char **)(crl))
williamr@2
   630
#define i2d_X509_CRL_bio(bp,crl) ASN1_i2d_bio(i2d_X509_CRL,bp,\
williamr@2
   631
		(unsigned char *)crl)
williamr@2
   632
williamr@2
   633
#define PKCS7_dup(p7) (PKCS7 *)ASN1_dup((int (*)())i2d_PKCS7, \
williamr@2
   634
		(char *(*)())d2i_PKCS7,(char *)p7)
williamr@2
   635
#define d2i_PKCS7_fp(fp,p7) (PKCS7 *)ASN1_d2i_fp((char *(*)()) \
williamr@2
   636
		PKCS7_new,(char *(*)())d2i_PKCS7, (fp),\
williamr@2
   637
		(unsigned char **)(p7))
williamr@2
   638
#define i2d_PKCS7_fp(fp,p7) ASN1_i2d_fp(i2d_PKCS7,fp,\
williamr@2
   639
		(unsigned char *)p7)
williamr@2
   640
#define d2i_PKCS7_bio(bp,p7) (PKCS7 *)ASN1_d2i_bio((char *(*)()) \
williamr@2
   641
		PKCS7_new,(char *(*)())d2i_PKCS7, (bp),\
williamr@2
   642
		(unsigned char **)(p7))
williamr@2
   643
#define i2d_PKCS7_bio(bp,p7) ASN1_i2d_bio(i2d_PKCS7,bp,\
williamr@2
   644
		(unsigned char *)p7)
williamr@2
   645
williamr@2
   646
#define X509_REQ_dup(req) (X509_REQ *)ASN1_dup((int (*)())i2d_X509_REQ, \
williamr@2
   647
		(char *(*)())d2i_X509_REQ,(char *)req)
williamr@2
   648
#define d2i_X509_REQ_fp(fp,req) (X509_REQ *)ASN1_d2i_fp((char *(*)())\
williamr@2
   649
		X509_REQ_new, (char *(*)())d2i_X509_REQ, (fp),\
williamr@2
   650
		(unsigned char **)(req))
williamr@2
   651
#define i2d_X509_REQ_fp(fp,req) ASN1_i2d_fp(i2d_X509_REQ,fp,\
williamr@2
   652
		(unsigned char *)req)
williamr@2
   653
#define d2i_X509_REQ_bio(bp,req) (X509_REQ *)ASN1_d2i_bio((char *(*)())\
williamr@2
   654
		X509_REQ_new, (char *(*)())d2i_X509_REQ, (bp),\
williamr@2
   655
		(unsigned char **)(req))
williamr@2
   656
#define i2d_X509_REQ_bio(bp,req) ASN1_i2d_bio(i2d_X509_REQ,bp,\
williamr@2
   657
		(unsigned char *)req)
williamr@2
   658
williamr@2
   659
#define RSAPublicKey_dup(rsa) (RSA *)ASN1_dup((int (*)())i2d_RSAPublicKey, \
williamr@2
   660
		(char *(*)())d2i_RSAPublicKey,(char *)rsa)
williamr@2
   661
#define RSAPrivateKey_dup(rsa) (RSA *)ASN1_dup((int (*)())i2d_RSAPrivateKey, \
williamr@2
   662
		(char *(*)())d2i_RSAPrivateKey,(char *)rsa)
williamr@2
   663
williamr@2
   664
#define d2i_RSAPrivateKey_fp(fp,rsa) (RSA *)ASN1_d2i_fp((char *(*)())\
williamr@2
   665
		RSA_new,(char *(*)())d2i_RSAPrivateKey, (fp), \
williamr@2
   666
		(unsigned char **)(rsa))
williamr@2
   667
#define i2d_RSAPrivateKey_fp(fp,rsa) ASN1_i2d_fp(i2d_RSAPrivateKey,fp, \
williamr@2
   668
		(unsigned char *)rsa)
williamr@2
   669
#define d2i_RSAPrivateKey_bio(bp,rsa) (RSA *)ASN1_d2i_bio((char *(*)())\
williamr@2
   670
		RSA_new,(char *(*)())d2i_RSAPrivateKey, (bp), \
williamr@2
   671
		(unsigned char **)(rsa))
williamr@2
   672
#define i2d_RSAPrivateKey_bio(bp,rsa) ASN1_i2d_bio(i2d_RSAPrivateKey,bp, \
williamr@2
   673
		(unsigned char *)rsa)
williamr@2
   674
williamr@2
   675
#define d2i_RSAPublicKey_fp(fp,rsa) (RSA *)ASN1_d2i_fp((char *(*)())\
williamr@2
   676
		RSA_new,(char *(*)())d2i_RSAPublicKey, (fp), \
williamr@2
   677
		(unsigned char **)(rsa))
williamr@2
   678
#define i2d_RSAPublicKey_fp(fp,rsa) ASN1_i2d_fp(i2d_RSAPublicKey,fp, \
williamr@2
   679
		(unsigned char *)rsa)
williamr@2
   680
#define d2i_RSAPublicKey_bio(bp,rsa) (RSA *)ASN1_d2i_bio((char *(*)())\
williamr@2
   681
		RSA_new,(char *(*)())d2i_RSAPublicKey, (bp), \
williamr@2
   682
		(unsigned char **)(rsa))
williamr@2
   683
#define i2d_RSAPublicKey_bio(bp,rsa) ASN1_i2d_bio(i2d_RSAPublicKey,bp, \
williamr@2
   684
		(unsigned char *)rsa)
williamr@2
   685
williamr@2
   686
#define d2i_DSAPrivateKey_fp(fp,dsa) (DSA *)ASN1_d2i_fp((char *(*)())\
williamr@2
   687
		DSA_new,(char *(*)())d2i_DSAPrivateKey, (fp), \
williamr@2
   688
		(unsigned char **)(dsa))
williamr@2
   689
#define i2d_DSAPrivateKey_fp(fp,dsa) ASN1_i2d_fp(i2d_DSAPrivateKey,fp, \
williamr@2
   690
		(unsigned char *)dsa)
williamr@2
   691
#define d2i_DSAPrivateKey_bio(bp,dsa) (DSA *)ASN1_d2i_bio((char *(*)())\
williamr@2
   692
		DSA_new,(char *(*)())d2i_DSAPrivateKey, (bp), \
williamr@2
   693
		(unsigned char **)(dsa))
williamr@2
   694
#define i2d_DSAPrivateKey_bio(bp,dsa) ASN1_i2d_bio(i2d_DSAPrivateKey,bp, \
williamr@2
   695
		(unsigned char *)dsa)
williamr@2
   696
williamr@2
   697
#define d2i_ECPrivateKey_fp(fp,ecdsa) (EC_KEY *)ASN1_d2i_fp((char *(*)())\
williamr@2
   698
		EC_KEY_new,(char *(*)())d2i_ECPrivateKey, (fp), \
williamr@2
   699
		(unsigned char **)(ecdsa))
williamr@2
   700
#define i2d_ECPrivateKey_fp(fp,ecdsa) ASN1_i2d_fp(i2d_ECPrivateKey,fp, \
williamr@2
   701
		(unsigned char *)ecdsa)
williamr@2
   702
#define d2i_ECPrivateKey_bio(bp,ecdsa) (EC_KEY *)ASN1_d2i_bio((char *(*)())\
williamr@2
   703
		EC_KEY_new,(char *(*)())d2i_ECPrivateKey, (bp), \
williamr@2
   704
		(unsigned char **)(ecdsa))
williamr@2
   705
#define i2d_ECPrivateKey_bio(bp,ecdsa) ASN1_i2d_bio(i2d_ECPrivateKey,bp, \
williamr@2
   706
		(unsigned char *)ecdsa)
williamr@2
   707
williamr@2
   708
#define X509_ALGOR_dup(xn) (X509_ALGOR *)ASN1_dup((int (*)())i2d_X509_ALGOR,\
williamr@2
   709
		(char *(*)())d2i_X509_ALGOR,(char *)xn)
williamr@2
   710
williamr@2
   711
#define X509_NAME_dup(xn) (X509_NAME *)ASN1_dup((int (*)())i2d_X509_NAME, \
williamr@2
   712
		(char *(*)())d2i_X509_NAME,(char *)xn)
williamr@2
   713
#define X509_NAME_ENTRY_dup(ne) (X509_NAME_ENTRY *)ASN1_dup( \
williamr@2
   714
		(int (*)())i2d_X509_NAME_ENTRY, \
williamr@2
   715
		(char *(*)())d2i_X509_NAME_ENTRY,\
williamr@2
   716
		(char *)ne)
williamr@2
   717
williamr@2
   718
#define X509_digest(data,type,md,len) \
williamr@2
   719
	ASN1_digest((int (*)())i2d_X509,type,(char *)data,md,len)
williamr@2
   720
#define X509_NAME_digest(data,type,md,len) \
williamr@2
   721
	ASN1_digest((int (*)())i2d_X509_NAME,type,(char *)data,md,len)
williamr@2
   722
#ifndef PKCS7_ISSUER_AND_SERIAL_digest
williamr@2
   723
#define PKCS7_ISSUER_AND_SERIAL_digest(data,type,md,len) \
williamr@2
   724
	ASN1_digest((int (*)())i2d_PKCS7_ISSUER_AND_SERIAL,type,\
williamr@2
   725
		(char *)data,md,len)
williamr@2
   726
#endif
williamr@2
   727
#endif
williamr@2
   728
williamr@2
   729
#define X509_EXT_PACK_UNKNOWN	1
williamr@2
   730
#define X509_EXT_PACK_STRING	2
williamr@2
   731
williamr@2
   732
#define		X509_get_version(x) ASN1_INTEGER_get((x)->cert_info->version)
williamr@2
   733
/* #define	X509_get_serialNumber(x) ((x)->cert_info->serialNumber) */
williamr@2
   734
#define		X509_get_notBefore(x) ((x)->cert_info->validity->notBefore)
williamr@2
   735
#define		X509_get_notAfter(x) ((x)->cert_info->validity->notAfter)
williamr@2
   736
#define		X509_extract_key(x)	X509_get_pubkey(x) /*****/
williamr@2
   737
#define		X509_REQ_get_version(x) ASN1_INTEGER_get((x)->req_info->version)
williamr@2
   738
#define		X509_REQ_get_subject_name(x) ((x)->req_info->subject)
williamr@2
   739
#define		X509_REQ_extract_key(a)	X509_REQ_get_pubkey(a)
williamr@2
   740
#define		X509_name_cmp(a,b)	X509_NAME_cmp((a),(b))
williamr@2
   741
#define		X509_get_signature_type(x) EVP_PKEY_type(OBJ_obj2nid((x)->sig_alg->algorithm))
williamr@2
   742
williamr@2
   743
#define		X509_CRL_get_version(x) ASN1_INTEGER_get((x)->crl->version)
williamr@2
   744
#define 	X509_CRL_get_lastUpdate(x) ((x)->crl->lastUpdate)
williamr@2
   745
#define 	X509_CRL_get_nextUpdate(x) ((x)->crl->nextUpdate)
williamr@2
   746
#define		X509_CRL_get_issuer(x) ((x)->crl->issuer)
williamr@2
   747
#define		X509_CRL_get_REVOKED(x) ((x)->crl->revoked)
williamr@2
   748
williamr@2
   749
/* This one is only used so that a binary form can output, as in
williamr@2
   750
 * i2d_X509_NAME(X509_get_X509_PUBKEY(x),&buf) */
williamr@2
   751
#define 	X509_get_X509_PUBKEY(x) ((x)->cert_info->key)
williamr@2
   752
williamr@2
   753
williamr@2
   754
IMPORT_C const char *X509_verify_cert_error_string(long n);
williamr@2
   755
williamr@2
   756
#ifndef SSLEAY_MACROS
williamr@2
   757
#ifndef OPENSSL_NO_EVP
williamr@2
   758
IMPORT_C int X509_verify(X509 *a, EVP_PKEY *r);
williamr@2
   759
williamr@2
   760
IMPORT_C int X509_REQ_verify(X509_REQ *a, EVP_PKEY *r);
williamr@2
   761
IMPORT_C int X509_CRL_verify(X509_CRL *a, EVP_PKEY *r);
williamr@2
   762
IMPORT_C int NETSCAPE_SPKI_verify(NETSCAPE_SPKI *a, EVP_PKEY *r);
williamr@2
   763
williamr@2
   764
IMPORT_C NETSCAPE_SPKI * NETSCAPE_SPKI_b64_decode(const char *str, int len);
williamr@2
   765
IMPORT_C char * NETSCAPE_SPKI_b64_encode(NETSCAPE_SPKI *x);
williamr@2
   766
IMPORT_C EVP_PKEY *NETSCAPE_SPKI_get_pubkey(NETSCAPE_SPKI *x);
williamr@2
   767
IMPORT_C int NETSCAPE_SPKI_set_pubkey(NETSCAPE_SPKI *x, EVP_PKEY *pkey);
williamr@2
   768
williamr@2
   769
IMPORT_C int NETSCAPE_SPKI_print(BIO *out, NETSCAPE_SPKI *spki);
williamr@2
   770
williamr@2
   771
IMPORT_C int X509_signature_print(BIO *bp,X509_ALGOR *alg, ASN1_STRING *sig);
williamr@2
   772
williamr@2
   773
IMPORT_C int X509_sign(X509 *x, EVP_PKEY *pkey, const EVP_MD *md);
williamr@2
   774
IMPORT_C int X509_REQ_sign(X509_REQ *x, EVP_PKEY *pkey, const EVP_MD *md);
williamr@2
   775
IMPORT_C int X509_CRL_sign(X509_CRL *x, EVP_PKEY *pkey, const EVP_MD *md);
williamr@2
   776
IMPORT_C int NETSCAPE_SPKI_sign(NETSCAPE_SPKI *x, EVP_PKEY *pkey, const EVP_MD *md);
williamr@2
   777
williamr@2
   778
IMPORT_C int X509_pubkey_digest(const X509 *data,const EVP_MD *type,
williamr@2
   779
		unsigned char *md, unsigned int *len);
williamr@2
   780
IMPORT_C int X509_digest(const X509 *data,const EVP_MD *type,
williamr@2
   781
		unsigned char *md, unsigned int *len);
williamr@2
   782
IMPORT_C int X509_CRL_digest(const X509_CRL *data,const EVP_MD *type,
williamr@2
   783
		unsigned char *md, unsigned int *len);
williamr@2
   784
IMPORT_C int X509_REQ_digest(const X509_REQ *data,const EVP_MD *type,
williamr@2
   785
		unsigned char *md, unsigned int *len);
williamr@2
   786
IMPORT_C int X509_NAME_digest(const X509_NAME *data,const EVP_MD *type,
williamr@2
   787
		unsigned char *md, unsigned int *len);
williamr@2
   788
#endif
williamr@2
   789
williamr@2
   790
#ifndef OPENSSL_NO_FP_API
williamr@2
   791
IMPORT_C X509 *d2i_X509_fp(FILE *fp, X509 **x509);
williamr@2
   792
IMPORT_C int i2d_X509_fp(FILE *fp,X509 *x509);
williamr@2
   793
IMPORT_C X509_CRL *d2i_X509_CRL_fp(FILE *fp,X509_CRL **crl);
williamr@2
   794
IMPORT_C int i2d_X509_CRL_fp(FILE *fp,X509_CRL *crl);
williamr@2
   795
X509_REQ *d2i_X509_REQ_fp(FILE *fp,X509_REQ **req);
williamr@2
   796
IMPORT_C int i2d_X509_REQ_fp(FILE *fp,X509_REQ *req);
williamr@2
   797
#ifndef OPENSSL_NO_RSA
williamr@2
   798
IMPORT_C RSA *d2i_RSAPrivateKey_fp(FILE *fp,RSA **rsa);
williamr@2
   799
IMPORT_C int i2d_RSAPrivateKey_fp(FILE *fp,RSA *rsa);
williamr@2
   800
IMPORT_C RSA *d2i_RSAPublicKey_fp(FILE *fp,RSA **rsa);
williamr@2
   801
IMPORT_C int i2d_RSAPublicKey_fp(FILE *fp,RSA *rsa);
williamr@2
   802
IMPORT_C RSA *d2i_RSA_PUBKEY_fp(FILE *fp,RSA **rsa);
williamr@2
   803
IMPORT_C int i2d_RSA_PUBKEY_fp(FILE *fp,RSA *rsa);
williamr@2
   804
#endif
williamr@2
   805
#ifndef OPENSSL_NO_DSA
williamr@2
   806
IMPORT_C DSA *d2i_DSA_PUBKEY_fp(FILE *fp, DSA **dsa);
williamr@2
   807
IMPORT_C int i2d_DSA_PUBKEY_fp(FILE *fp, DSA *dsa);
williamr@2
   808
IMPORT_C DSA *d2i_DSAPrivateKey_fp(FILE *fp, DSA **dsa);
williamr@2
   809
IMPORT_C int i2d_DSAPrivateKey_fp(FILE *fp, DSA *dsa);
williamr@2
   810
#endif
williamr@2
   811
IMPORT_C X509_SIG *d2i_PKCS8_fp(FILE *fp,X509_SIG **p8);
williamr@2
   812
IMPORT_C int i2d_PKCS8_fp(FILE *fp,X509_SIG *p8);
williamr@2
   813
IMPORT_C PKCS8_PRIV_KEY_INFO *d2i_PKCS8_PRIV_KEY_INFO_fp(FILE *fp,
williamr@2
   814
						PKCS8_PRIV_KEY_INFO **p8inf);
williamr@2
   815
IMPORT_C int i2d_PKCS8_PRIV_KEY_INFO_fp(FILE *fp,PKCS8_PRIV_KEY_INFO *p8inf);
williamr@2
   816
IMPORT_C int i2d_PKCS8PrivateKeyInfo_fp(FILE *fp, EVP_PKEY *key);
williamr@2
   817
IMPORT_C int i2d_PrivateKey_fp(FILE *fp, EVP_PKEY *pkey);
williamr@2
   818
IMPORT_C EVP_PKEY *d2i_PrivateKey_fp(FILE *fp, EVP_PKEY **a);
williamr@2
   819
IMPORT_C int i2d_PUBKEY_fp(FILE *fp, EVP_PKEY *pkey);
williamr@2
   820
IMPORT_C EVP_PKEY *d2i_PUBKEY_fp(FILE *fp, EVP_PKEY **a);
williamr@2
   821
#endif
williamr@2
   822
williamr@2
   823
#ifndef OPENSSL_NO_BIO
williamr@2
   824
IMPORT_C X509 *d2i_X509_bio(BIO *bp,X509 **x509);
williamr@2
   825
IMPORT_C int i2d_X509_bio(BIO *bp,X509 *x509);
williamr@2
   826
IMPORT_C X509_CRL *d2i_X509_CRL_bio(BIO *bp,X509_CRL **crl);
williamr@2
   827
IMPORT_C int i2d_X509_CRL_bio(BIO *bp,X509_CRL *crl);
williamr@2
   828
IMPORT_C X509_REQ *d2i_X509_REQ_bio(BIO *bp,X509_REQ **req);
williamr@2
   829
IMPORT_C int i2d_X509_REQ_bio(BIO *bp,X509_REQ *req);
williamr@2
   830
#ifndef OPENSSL_NO_RSA
williamr@2
   831
IMPORT_C RSA *d2i_RSAPrivateKey_bio(BIO *bp,RSA **rsa);
williamr@2
   832
IMPORT_C int i2d_RSAPrivateKey_bio(BIO *bp,RSA *rsa);
williamr@2
   833
IMPORT_C RSA *d2i_RSAPublicKey_bio(BIO *bp,RSA **rsa);
williamr@2
   834
IMPORT_C int i2d_RSAPublicKey_bio(BIO *bp,RSA *rsa);
williamr@2
   835
IMPORT_C RSA *d2i_RSA_PUBKEY_bio(BIO *bp,RSA **rsa);
williamr@2
   836
IMPORT_C int i2d_RSA_PUBKEY_bio(BIO *bp,RSA *rsa);
williamr@2
   837
#endif
williamr@2
   838
#ifndef OPENSSL_NO_DSA
williamr@2
   839
IMPORT_C DSA *d2i_DSA_PUBKEY_bio(BIO *bp, DSA **dsa);
williamr@2
   840
IMPORT_C int i2d_DSA_PUBKEY_bio(BIO *bp, DSA *dsa);
williamr@2
   841
IMPORT_C DSA *d2i_DSAPrivateKey_bio(BIO *bp, DSA **dsa);
williamr@2
   842
IMPORT_C int i2d_DSAPrivateKey_bio(BIO *bp, DSA *dsa);
williamr@2
   843
#endif
williamr@2
   844
IMPORT_C X509_SIG *d2i_PKCS8_bio(BIO *bp,X509_SIG **p8);
williamr@2
   845
IMPORT_C int i2d_PKCS8_bio(BIO *bp,X509_SIG *p8);
williamr@2
   846
IMPORT_C PKCS8_PRIV_KEY_INFO *d2i_PKCS8_PRIV_KEY_INFO_bio(BIO *bp,
williamr@2
   847
						PKCS8_PRIV_KEY_INFO **p8inf);
williamr@2
   848
IMPORT_C int i2d_PKCS8_PRIV_KEY_INFO_bio(BIO *bp,PKCS8_PRIV_KEY_INFO *p8inf);
williamr@2
   849
IMPORT_C int i2d_PKCS8PrivateKeyInfo_bio(BIO *bp, EVP_PKEY *key);
williamr@2
   850
IMPORT_C int i2d_PrivateKey_bio(BIO *bp, EVP_PKEY *pkey);
williamr@2
   851
IMPORT_C EVP_PKEY *d2i_PrivateKey_bio(BIO *bp, EVP_PKEY **a);
williamr@2
   852
IMPORT_C int i2d_PUBKEY_bio(BIO *bp, EVP_PKEY *pkey);
williamr@2
   853
IMPORT_C EVP_PKEY *d2i_PUBKEY_bio(BIO *bp, EVP_PKEY **a);
williamr@2
   854
#endif
williamr@2
   855
williamr@2
   856
IMPORT_C X509 *X509_dup(X509 *x509);
williamr@2
   857
IMPORT_C X509_ATTRIBUTE *X509_ATTRIBUTE_dup(X509_ATTRIBUTE *xa);
williamr@2
   858
IMPORT_C X509_EXTENSION *X509_EXTENSION_dup(X509_EXTENSION *ex);
williamr@2
   859
IMPORT_C X509_CRL *X509_CRL_dup(X509_CRL *crl);
williamr@2
   860
IMPORT_C X509_REQ *X509_REQ_dup(X509_REQ *req);
williamr@2
   861
IMPORT_C X509_ALGOR *X509_ALGOR_dup(X509_ALGOR *xn);
williamr@2
   862
IMPORT_C X509_NAME *X509_NAME_dup(X509_NAME *xn);
williamr@2
   863
IMPORT_C X509_NAME_ENTRY *X509_NAME_ENTRY_dup(X509_NAME_ENTRY *ne);
williamr@2
   864
williamr@2
   865
#endif /* !SSLEAY_MACROS */
williamr@2
   866
williamr@2
   867
IMPORT_C int		X509_cmp_time(ASN1_TIME *s, time_t *t);
williamr@2
   868
IMPORT_C int		X509_cmp_current_time(ASN1_TIME *s);
williamr@2
   869
IMPORT_C ASN1_TIME *	X509_time_adj(ASN1_TIME *s, long adj, time_t *t);
williamr@2
   870
IMPORT_C ASN1_TIME *	X509_gmtime_adj(ASN1_TIME *s, long adj);
williamr@2
   871
williamr@2
   872
IMPORT_C const char *	X509_get_default_cert_area(void );
williamr@2
   873
IMPORT_C const char *	X509_get_default_cert_dir(void );
williamr@2
   874
IMPORT_C const char *	X509_get_default_cert_file(void );
williamr@2
   875
IMPORT_C const char *	X509_get_default_cert_dir_env(void );
williamr@2
   876
IMPORT_C const char *	X509_get_default_cert_file_env(void );
williamr@2
   877
IMPORT_C const char *	X509_get_default_private_dir(void );
williamr@2
   878
williamr@2
   879
IMPORT_C X509_REQ *	X509_to_X509_REQ(X509 *x, EVP_PKEY *pkey, const EVP_MD *md);
williamr@2
   880
IMPORT_C X509 *		X509_REQ_to_X509(X509_REQ *r, int days,EVP_PKEY *pkey);
williamr@2
   881
williamr@2
   882
DECLARE_ASN1_FUNCTIONS(X509_ALGOR)
williamr@2
   883
DECLARE_ASN1_FUNCTIONS(X509_VAL)
williamr@2
   884
williamr@2
   885
DECLARE_ASN1_FUNCTIONS(X509_PUBKEY)
williamr@2
   886
williamr@2
   887
IMPORT_C int		X509_PUBKEY_set(X509_PUBKEY **x, EVP_PKEY *pkey);
williamr@2
   888
IMPORT_C EVP_PKEY *	X509_PUBKEY_get(X509_PUBKEY *key);
williamr@2
   889
IMPORT_C int		X509_get_pubkey_parameters(EVP_PKEY *pkey,
williamr@2
   890
					   STACK_OF(X509) *chain);
williamr@2
   891
IMPORT_C int		i2d_PUBKEY(EVP_PKEY *a,unsigned char **pp);
williamr@2
   892
IMPORT_C EVP_PKEY *	d2i_PUBKEY(EVP_PKEY **a,const unsigned char **pp,
williamr@2
   893
			long length);
williamr@2
   894
#ifndef OPENSSL_NO_RSA
williamr@2
   895
IMPORT_C int		i2d_RSA_PUBKEY(RSA *a,unsigned char **pp);
williamr@2
   896
IMPORT_C RSA *		d2i_RSA_PUBKEY(RSA **a,const unsigned char **pp,
williamr@2
   897
			long length);
williamr@2
   898
#endif
williamr@2
   899
#ifndef OPENSSL_NO_DSA
williamr@2
   900
IMPORT_C int		i2d_DSA_PUBKEY(DSA *a,unsigned char **pp);
williamr@2
   901
IMPORT_C DSA *		d2i_DSA_PUBKEY(DSA **a,const unsigned char **pp,
williamr@2
   902
			long length);
williamr@2
   903
#endif
williamr@2
   904
#ifndef OPENSSL_NO_EC
williamr@2
   905
IMPORT_C int		i2d_EC_PUBKEY(EC_KEY *a, unsigned char **pp);
williamr@2
   906
EC_KEY 		*d2i_EC_PUBKEY(EC_KEY **a, const unsigned char **pp,
williamr@2
   907
			long length);
williamr@2
   908
#endif
williamr@2
   909
williamr@2
   910
DECLARE_ASN1_FUNCTIONS(X509_SIG)
williamr@2
   911
DECLARE_ASN1_FUNCTIONS(X509_REQ_INFO)
williamr@2
   912
DECLARE_ASN1_FUNCTIONS(X509_REQ)
williamr@2
   913
williamr@2
   914
DECLARE_ASN1_FUNCTIONS(X509_ATTRIBUTE)
williamr@2
   915
IMPORT_C X509_ATTRIBUTE *X509_ATTRIBUTE_create(int nid, int atrtype, void *value);
williamr@2
   916
williamr@2
   917
DECLARE_ASN1_FUNCTIONS(X509_EXTENSION)
williamr@2
   918
williamr@2
   919
DECLARE_ASN1_FUNCTIONS(X509_NAME_ENTRY)
williamr@2
   920
williamr@2
   921
DECLARE_ASN1_FUNCTIONS(X509_NAME)
williamr@2
   922
williamr@2
   923
IMPORT_C int		X509_NAME_set(X509_NAME **xn, X509_NAME *name);
williamr@2
   924
williamr@2
   925
DECLARE_ASN1_FUNCTIONS(X509_CINF)
williamr@2
   926
williamr@2
   927
DECLARE_ASN1_FUNCTIONS(X509)
williamr@2
   928
DECLARE_ASN1_FUNCTIONS(X509_CERT_AUX)
williamr@2
   929
williamr@2
   930
DECLARE_ASN1_FUNCTIONS(X509_CERT_PAIR)
williamr@2
   931
williamr@2
   932
IMPORT_C int X509_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func,
williamr@2
   933
	     CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func);
williamr@2
   934
IMPORT_C int X509_set_ex_data(X509 *r, int idx, void *arg);
williamr@2
   935
IMPORT_C void *X509_get_ex_data(X509 *r, int idx);
williamr@2
   936
IMPORT_C int		i2d_X509_AUX(X509 *a,unsigned char **pp);
williamr@2
   937
IMPORT_C X509 *		d2i_X509_AUX(X509 **a,const unsigned char **pp,long length);
williamr@2
   938
williamr@2
   939
IMPORT_C int X509_alias_set1(X509 *x, unsigned char *name, int len);
williamr@2
   940
IMPORT_C int X509_keyid_set1(X509 *x, unsigned char *id, int len);
williamr@2
   941
IMPORT_C unsigned char * X509_alias_get0(X509 *x, int *len);
williamr@2
   942
IMPORT_C unsigned char * X509_keyid_get0(X509 *x, int *len);
williamr@2
   943
IMPORT_C int (*X509_TRUST_set_default(int (*trust)(int , X509 *, int)))(int, X509 *, int);
williamr@2
   944
IMPORT_C int X509_TRUST_set(int *t, int trust);
williamr@2
   945
IMPORT_C int X509_add1_trust_object(X509 *x, ASN1_OBJECT *obj);
williamr@2
   946
IMPORT_C int X509_add1_reject_object(X509 *x, ASN1_OBJECT *obj);
williamr@2
   947
IMPORT_C void X509_trust_clear(X509 *x);
williamr@2
   948
IMPORT_C void X509_reject_clear(X509 *x);
williamr@2
   949
williamr@2
   950
DECLARE_ASN1_FUNCTIONS(X509_REVOKED)
williamr@2
   951
DECLARE_ASN1_FUNCTIONS(X509_CRL_INFO)
williamr@2
   952
DECLARE_ASN1_FUNCTIONS(X509_CRL)
williamr@2
   953
williamr@2
   954
IMPORT_C int X509_CRL_add0_revoked(X509_CRL *crl, X509_REVOKED *rev);
williamr@2
   955
williamr@2
   956
IMPORT_C X509_PKEY *	X509_PKEY_new(void );
williamr@2
   957
IMPORT_C void		X509_PKEY_free(X509_PKEY *a);
williamr@2
   958
IMPORT_C int		i2d_X509_PKEY(X509_PKEY *a,unsigned char **pp);
williamr@2
   959
IMPORT_C X509_PKEY *	d2i_X509_PKEY(X509_PKEY **a,const unsigned char **pp,long length);
williamr@2
   960
williamr@2
   961
DECLARE_ASN1_FUNCTIONS(NETSCAPE_SPKI)
williamr@2
   962
DECLARE_ASN1_FUNCTIONS(NETSCAPE_SPKAC)
williamr@2
   963
DECLARE_ASN1_FUNCTIONS(NETSCAPE_CERT_SEQUENCE)
williamr@2
   964
williamr@2
   965
#ifndef OPENSSL_NO_EVP
williamr@2
   966
IMPORT_C X509_INFO *	X509_INFO_new(void);
williamr@2
   967
IMPORT_C void		X509_INFO_free(X509_INFO *a);
williamr@2
   968
IMPORT_C char *		X509_NAME_oneline(X509_NAME *a,char *buf,int size);
williamr@2
   969
williamr@2
   970
IMPORT_C int ASN1_verify(i2d_of_void *i2d, X509_ALGOR *algor1,
williamr@2
   971
		ASN1_BIT_STRING *signature,char *data,EVP_PKEY *pkey);
williamr@2
   972
williamr@2
   973
IMPORT_C int ASN1_digest(i2d_of_void *i2d,const EVP_MD *type,char *data,
williamr@2
   974
		unsigned char *md,unsigned int *len);
williamr@2
   975
williamr@2
   976
IMPORT_C int ASN1_sign(i2d_of_void *i2d, X509_ALGOR *algor1,
williamr@2
   977
	      X509_ALGOR *algor2, ASN1_BIT_STRING *signature,
williamr@2
   978
	      char *data,EVP_PKEY *pkey, const EVP_MD *type);
williamr@2
   979
williamr@2
   980
IMPORT_C int ASN1_item_digest(const ASN1_ITEM *it,const EVP_MD *type,void *data,
williamr@2
   981
	unsigned char *md,unsigned int *len);
williamr@2
   982
williamr@2
   983
IMPORT_C int ASN1_item_verify(const ASN1_ITEM *it, X509_ALGOR *algor1,
williamr@2
   984
	ASN1_BIT_STRING *signature,void *data,EVP_PKEY *pkey);
williamr@2
   985
williamr@2
   986
IMPORT_C int ASN1_item_sign(const ASN1_ITEM *it, X509_ALGOR *algor1, X509_ALGOR *algor2,
williamr@2
   987
	ASN1_BIT_STRING *signature,
williamr@2
   988
	void *data, EVP_PKEY *pkey, const EVP_MD *type);
williamr@2
   989
#endif
williamr@2
   990
williamr@2
   991
IMPORT_C int 		X509_set_version(X509 *x,long version);
williamr@2
   992
IMPORT_C int 		X509_set_serialNumber(X509 *x, ASN1_INTEGER *serial);
williamr@2
   993
IMPORT_C ASN1_INTEGER *	X509_get_serialNumber(X509 *x);
williamr@2
   994
IMPORT_C int 		X509_set_issuer_name(X509 *x, X509_NAME *name);
williamr@2
   995
IMPORT_C X509_NAME *	X509_get_issuer_name(X509 *a);
williamr@2
   996
IMPORT_C int 		X509_set_subject_name(X509 *x, X509_NAME *name);
williamr@2
   997
IMPORT_C X509_NAME *	X509_get_subject_name(X509 *a);
williamr@2
   998
IMPORT_C int 		X509_set_notBefore(X509 *x, ASN1_TIME *tm);
williamr@2
   999
IMPORT_C int 		X509_set_notAfter(X509 *x, ASN1_TIME *tm);
williamr@2
  1000
IMPORT_C int 		X509_set_pubkey(X509 *x, EVP_PKEY *pkey);
williamr@2
  1001
IMPORT_C EVP_PKEY *	X509_get_pubkey(X509 *x);
williamr@2
  1002
IMPORT_C ASN1_BIT_STRING * X509_get0_pubkey_bitstr(const X509 *x);
williamr@2
  1003
IMPORT_C int		X509_certificate_type(X509 *x,EVP_PKEY *pubkey /* optional */);
williamr@2
  1004
williamr@2
  1005
IMPORT_C int		X509_REQ_set_version(X509_REQ *x,long version);
williamr@2
  1006
IMPORT_C int		X509_REQ_set_subject_name(X509_REQ *req,X509_NAME *name);
williamr@2
  1007
IMPORT_C int		X509_REQ_set_pubkey(X509_REQ *x, EVP_PKEY *pkey);
williamr@2
  1008
IMPORT_C EVP_PKEY *	X509_REQ_get_pubkey(X509_REQ *req);
williamr@2
  1009
IMPORT_C int		X509_REQ_extension_nid(int nid);
williamr@2
  1010
IMPORT_C int *		X509_REQ_get_extension_nids(void);
williamr@2
  1011
IMPORT_C void		X509_REQ_set_extension_nids(int *nids);
williamr@2
  1012
IMPORT_C STACK_OF(X509_EXTENSION) *X509_REQ_get_extensions(X509_REQ *req);
williamr@2
  1013
IMPORT_C int X509_REQ_add_extensions_nid(X509_REQ *req, STACK_OF(X509_EXTENSION) *exts,
williamr@2
  1014
				int nid);
williamr@2
  1015
IMPORT_C int X509_REQ_add_extensions(X509_REQ *req, STACK_OF(X509_EXTENSION) *exts);
williamr@2
  1016
IMPORT_C int X509_REQ_get_attr_count(const X509_REQ *req);
williamr@2
  1017
IMPORT_C int X509_REQ_get_attr_by_NID(const X509_REQ *req, int nid,
williamr@2
  1018
			  int lastpos);
williamr@2
  1019
IMPORT_C int X509_REQ_get_attr_by_OBJ(const X509_REQ *req, ASN1_OBJECT *obj,
williamr@2
  1020
			  int lastpos);
williamr@2
  1021
IMPORT_C X509_ATTRIBUTE *X509_REQ_get_attr(const X509_REQ *req, int loc);
williamr@2
  1022
IMPORT_C X509_ATTRIBUTE *X509_REQ_delete_attr(X509_REQ *req, int loc);
williamr@2
  1023
IMPORT_C int X509_REQ_add1_attr(X509_REQ *req, X509_ATTRIBUTE *attr);
williamr@2
  1024
IMPORT_C int X509_REQ_add1_attr_by_OBJ(X509_REQ *req,
williamr@2
  1025
			const ASN1_OBJECT *obj, int type,
williamr@2
  1026
			const unsigned char *bytes, int len);
williamr@2
  1027
IMPORT_C int X509_REQ_add1_attr_by_NID(X509_REQ *req,
williamr@2
  1028
			int nid, int type,
williamr@2
  1029
			const unsigned char *bytes, int len);
williamr@2
  1030
int X509_REQ_add1_attr_by_txt(X509_REQ *req,
williamr@2
  1031
			const char *attrname, int type,
williamr@2
  1032
			const unsigned char *bytes, int len);
williamr@2
  1033
williamr@2
  1034
IMPORT_C int X509_CRL_set_version(X509_CRL *x, long version);
williamr@2
  1035
IMPORT_C int X509_CRL_set_issuer_name(X509_CRL *x, X509_NAME *name);
williamr@2
  1036
IMPORT_C int X509_CRL_set_lastUpdate(X509_CRL *x, ASN1_TIME *tm);
williamr@2
  1037
IMPORT_C int X509_CRL_set_nextUpdate(X509_CRL *x, ASN1_TIME *tm);
williamr@2
  1038
IMPORT_C int X509_CRL_sort(X509_CRL *crl);
williamr@2
  1039
williamr@2
  1040
IMPORT_C int X509_REVOKED_set_serialNumber(X509_REVOKED *x, ASN1_INTEGER *serial);
williamr@2
  1041
IMPORT_C int X509_REVOKED_set_revocationDate(X509_REVOKED *r, ASN1_TIME *tm);
williamr@2
  1042
williamr@2
  1043
IMPORT_C int		X509_REQ_check_private_key(X509_REQ *x509,EVP_PKEY *pkey);
williamr@2
  1044
williamr@2
  1045
IMPORT_C int		X509_check_private_key(X509 *x509,EVP_PKEY *pkey);
williamr@2
  1046
williamr@2
  1047
IMPORT_C int		X509_issuer_and_serial_cmp(const X509 *a, const X509 *b);
williamr@2
  1048
IMPORT_C unsigned long	X509_issuer_and_serial_hash(X509 *a);
williamr@2
  1049
williamr@2
  1050
IMPORT_C int		X509_issuer_name_cmp(const X509 *a, const X509 *b);
williamr@2
  1051
IMPORT_C unsigned long	X509_issuer_name_hash(X509 *a);
williamr@2
  1052
williamr@2
  1053
IMPORT_C int		X509_subject_name_cmp(const X509 *a, const X509 *b);
williamr@2
  1054
IMPORT_C unsigned long	X509_subject_name_hash(X509 *x);
williamr@2
  1055
williamr@2
  1056
IMPORT_C int		X509_cmp(const X509 *a, const X509 *b);
williamr@2
  1057
IMPORT_C int		X509_NAME_cmp(const X509_NAME *a, const X509_NAME *b);
williamr@2
  1058
IMPORT_C unsigned long	X509_NAME_hash(X509_NAME *x);
williamr@2
  1059
williamr@2
  1060
IMPORT_C int		X509_CRL_cmp(const X509_CRL *a, const X509_CRL *b);
williamr@2
  1061
#ifndef OPENSSL_NO_FP_API
williamr@2
  1062
IMPORT_C int		X509_print_ex_fp(FILE *bp,X509 *x, unsigned long nmflag, unsigned long cflag);
williamr@2
  1063
IMPORT_C int		X509_print_fp(FILE *bp,X509 *x);
williamr@2
  1064
IMPORT_C int		X509_CRL_print_fp(FILE *bp,X509_CRL *x);
williamr@2
  1065
IMPORT_C int		X509_REQ_print_fp(FILE *bp,X509_REQ *req);
williamr@2
  1066
IMPORT_C int X509_NAME_print_ex_fp(FILE *fp, X509_NAME *nm, int indent, unsigned long flags);
williamr@2
  1067
#endif
williamr@2
  1068
williamr@2
  1069
#ifndef OPENSSL_NO_BIO
williamr@2
  1070
IMPORT_C int		X509_NAME_print(BIO *bp, X509_NAME *name, int obase);
williamr@2
  1071
IMPORT_C int X509_NAME_print_ex(BIO *out, X509_NAME *nm, int indent, unsigned long flags);
williamr@2
  1072
IMPORT_C int		X509_print_ex(BIO *bp,X509 *x, unsigned long nmflag, unsigned long cflag);
williamr@2
  1073
IMPORT_C int		X509_print(BIO *bp,X509 *x);
williamr@2
  1074
IMPORT_C int		X509_ocspid_print(BIO *bp,X509 *x);
williamr@2
  1075
IMPORT_C int		X509_CERT_AUX_print(BIO *bp,X509_CERT_AUX *x, int indent);
williamr@2
  1076
IMPORT_C int		X509_CRL_print(BIO *bp,X509_CRL *x);
williamr@2
  1077
IMPORT_C int		X509_REQ_print_ex(BIO *bp, X509_REQ *x, unsigned long nmflag, unsigned long cflag);
williamr@2
  1078
IMPORT_C int		X509_REQ_print(BIO *bp,X509_REQ *req);
williamr@2
  1079
#endif
williamr@2
  1080
williamr@2
  1081
IMPORT_C int 		X509_NAME_entry_count(X509_NAME *name);
williamr@2
  1082
IMPORT_C int 		X509_NAME_get_text_by_NID(X509_NAME *name, int nid,
williamr@2
  1083
			char *buf,int len);
williamr@2
  1084
IMPORT_C int		X509_NAME_get_text_by_OBJ(X509_NAME *name, ASN1_OBJECT *obj,
williamr@2
  1085
			char *buf,int len);
williamr@2
  1086
williamr@2
  1087
/* NOTE: you should be passsing -1, not 0 as lastpos.  The functions that use
williamr@2
  1088
 * lastpos, search after that position on. */
williamr@2
  1089
IMPORT_C int 		X509_NAME_get_index_by_NID(X509_NAME *name,int nid,int lastpos);
williamr@2
  1090
IMPORT_C int 		X509_NAME_get_index_by_OBJ(X509_NAME *name,ASN1_OBJECT *obj,
williamr@2
  1091
			int lastpos);
williamr@2
  1092
IMPORT_C X509_NAME_ENTRY *X509_NAME_get_entry(X509_NAME *name, int loc);
williamr@2
  1093
IMPORT_C X509_NAME_ENTRY *X509_NAME_delete_entry(X509_NAME *name, int loc);
williamr@2
  1094
IMPORT_C int 		X509_NAME_add_entry(X509_NAME *name,X509_NAME_ENTRY *ne,
williamr@2
  1095
			int loc, int set);
williamr@2
  1096
IMPORT_C int X509_NAME_add_entry_by_OBJ(X509_NAME *name, ASN1_OBJECT *obj, int type,
williamr@2
  1097
			unsigned char *bytes, int len, int loc, int set);
williamr@2
  1098
IMPORT_C int X509_NAME_add_entry_by_NID(X509_NAME *name, int nid, int type,
williamr@2
  1099
			unsigned char *bytes, int len, int loc, int set);
williamr@2
  1100
IMPORT_C X509_NAME_ENTRY *X509_NAME_ENTRY_create_by_txt(X509_NAME_ENTRY **ne,
williamr@2
  1101
		const char *field, int type, const unsigned char *bytes, int len);
williamr@2
  1102
IMPORT_C X509_NAME_ENTRY *X509_NAME_ENTRY_create_by_NID(X509_NAME_ENTRY **ne, int nid,
williamr@2
  1103
			int type,unsigned char *bytes, int len);
williamr@2
  1104
IMPORT_C int X509_NAME_add_entry_by_txt(X509_NAME *name, const char *field, int type,
williamr@2
  1105
			const unsigned char *bytes, int len, int loc, int set);
williamr@2
  1106
IMPORT_C X509_NAME_ENTRY *X509_NAME_ENTRY_create_by_OBJ(X509_NAME_ENTRY **ne,
williamr@2
  1107
			ASN1_OBJECT *obj, int type,const unsigned char *bytes,
williamr@2
  1108
			int len);
williamr@2
  1109
IMPORT_C int 		X509_NAME_ENTRY_set_object(X509_NAME_ENTRY *ne,
williamr@2
  1110
			ASN1_OBJECT *obj);
williamr@2
  1111
IMPORT_C int 		X509_NAME_ENTRY_set_data(X509_NAME_ENTRY *ne, int type,
williamr@2
  1112
			const unsigned char *bytes, int len);
williamr@2
  1113
IMPORT_C ASN1_OBJECT *	X509_NAME_ENTRY_get_object(X509_NAME_ENTRY *ne);
williamr@2
  1114
IMPORT_C ASN1_STRING *	X509_NAME_ENTRY_get_data(X509_NAME_ENTRY *ne);
williamr@2
  1115
williamr@2
  1116
IMPORT_C int		X509v3_get_ext_count(const STACK_OF(X509_EXTENSION) *x);
williamr@2
  1117
IMPORT_C int		X509v3_get_ext_by_NID(const STACK_OF(X509_EXTENSION) *x,
williamr@2
  1118
				      int nid, int lastpos);
williamr@2
  1119
IMPORT_C int		X509v3_get_ext_by_OBJ(const STACK_OF(X509_EXTENSION) *x,
williamr@2
  1120
				      ASN1_OBJECT *obj,int lastpos);
williamr@2
  1121
IMPORT_C int		X509v3_get_ext_by_critical(const STACK_OF(X509_EXTENSION) *x,
williamr@2
  1122
					   int crit, int lastpos);
williamr@2
  1123
IMPORT_C X509_EXTENSION *X509v3_get_ext(const STACK_OF(X509_EXTENSION) *x, int loc);
williamr@2
  1124
IMPORT_C X509_EXTENSION *X509v3_delete_ext(STACK_OF(X509_EXTENSION) *x, int loc);
williamr@2
  1125
IMPORT_C STACK_OF(X509_EXTENSION) *X509v3_add_ext(STACK_OF(X509_EXTENSION) **x,
williamr@2
  1126
					 X509_EXTENSION *ex, int loc);
williamr@2
  1127
williamr@2
  1128
IMPORT_C int		X509_get_ext_count(X509 *x);
williamr@2
  1129
IMPORT_C int		X509_get_ext_by_NID(X509 *x, int nid, int lastpos);
williamr@2
  1130
IMPORT_C int		X509_get_ext_by_OBJ(X509 *x,ASN1_OBJECT *obj,int lastpos);
williamr@2
  1131
IMPORT_C int		X509_get_ext_by_critical(X509 *x, int crit, int lastpos);
williamr@2
  1132
IMPORT_C X509_EXTENSION *X509_get_ext(X509 *x, int loc);
williamr@2
  1133
IMPORT_C X509_EXTENSION *X509_delete_ext(X509 *x, int loc);
williamr@2
  1134
IMPORT_C int		X509_add_ext(X509 *x, X509_EXTENSION *ex, int loc);
williamr@2
  1135
IMPORT_C void	*	X509_get_ext_d2i(X509 *x, int nid, int *crit, int *idx);
williamr@2
  1136
IMPORT_C int		X509_add1_ext_i2d(X509 *x, int nid, void *value, int crit,
williamr@2
  1137
							unsigned long flags);
williamr@2
  1138
williamr@2
  1139
IMPORT_C int		X509_CRL_get_ext_count(X509_CRL *x);
williamr@2
  1140
IMPORT_C int		X509_CRL_get_ext_by_NID(X509_CRL *x, int nid, int lastpos);
williamr@2
  1141
IMPORT_C int		X509_CRL_get_ext_by_OBJ(X509_CRL *x,ASN1_OBJECT *obj,int lastpos);
williamr@2
  1142
IMPORT_C int		X509_CRL_get_ext_by_critical(X509_CRL *x, int crit, int lastpos);
williamr@2
  1143
IMPORT_C X509_EXTENSION *X509_CRL_get_ext(X509_CRL *x, int loc);
williamr@2
  1144
IMPORT_C X509_EXTENSION *X509_CRL_delete_ext(X509_CRL *x, int loc);
williamr@2
  1145
IMPORT_C int		X509_CRL_add_ext(X509_CRL *x, X509_EXTENSION *ex, int loc);
williamr@2
  1146
IMPORT_C void	*	X509_CRL_get_ext_d2i(X509_CRL *x, int nid, int *crit, int *idx);
williamr@2
  1147
IMPORT_C int		X509_CRL_add1_ext_i2d(X509_CRL *x, int nid, void *value, int crit,
williamr@2
  1148
							unsigned long flags);
williamr@2
  1149
williamr@2
  1150
IMPORT_C int		X509_REVOKED_get_ext_count(X509_REVOKED *x);
williamr@2
  1151
IMPORT_C int		X509_REVOKED_get_ext_by_NID(X509_REVOKED *x, int nid, int lastpos);
williamr@2
  1152
IMPORT_C int		X509_REVOKED_get_ext_by_OBJ(X509_REVOKED *x,ASN1_OBJECT *obj,int lastpos);
williamr@2
  1153
IMPORT_C int		X509_REVOKED_get_ext_by_critical(X509_REVOKED *x, int crit, int lastpos);
williamr@2
  1154
IMPORT_C X509_EXTENSION *X509_REVOKED_get_ext(X509_REVOKED *x, int loc);
williamr@2
  1155
IMPORT_C X509_EXTENSION *X509_REVOKED_delete_ext(X509_REVOKED *x, int loc);
williamr@2
  1156
IMPORT_C int		X509_REVOKED_add_ext(X509_REVOKED *x, X509_EXTENSION *ex, int loc);
williamr@2
  1157
IMPORT_C void	*	X509_REVOKED_get_ext_d2i(X509_REVOKED *x, int nid, int *crit, int *idx);
williamr@2
  1158
IMPORT_C int		X509_REVOKED_add1_ext_i2d(X509_REVOKED *x, int nid, void *value, int crit,
williamr@2
  1159
							unsigned long flags);
williamr@2
  1160
williamr@2
  1161
IMPORT_C X509_EXTENSION *X509_EXTENSION_create_by_NID(X509_EXTENSION **ex,
williamr@2
  1162
			int nid, int crit, ASN1_OCTET_STRING *data);
williamr@2
  1163
IMPORT_C X509_EXTENSION *X509_EXTENSION_create_by_OBJ(X509_EXTENSION **ex,
williamr@2
  1164
			ASN1_OBJECT *obj,int crit,ASN1_OCTET_STRING *data);
williamr@2
  1165
IMPORT_C int		X509_EXTENSION_set_object(X509_EXTENSION *ex,ASN1_OBJECT *obj);
williamr@2
  1166
IMPORT_C int		X509_EXTENSION_set_critical(X509_EXTENSION *ex, int crit);
williamr@2
  1167
IMPORT_C int		X509_EXTENSION_set_data(X509_EXTENSION *ex,
williamr@2
  1168
			ASN1_OCTET_STRING *data);
williamr@2
  1169
IMPORT_C ASN1_OBJECT *	X509_EXTENSION_get_object(X509_EXTENSION *ex);
williamr@2
  1170
IMPORT_C ASN1_OCTET_STRING *X509_EXTENSION_get_data(X509_EXTENSION *ne);
williamr@2
  1171
IMPORT_C int		X509_EXTENSION_get_critical(X509_EXTENSION *ex);
williamr@2
  1172
williamr@2
  1173
IMPORT_C int X509at_get_attr_count(const STACK_OF(X509_ATTRIBUTE) *x);
williamr@2
  1174
IMPORT_C int X509at_get_attr_by_NID(const STACK_OF(X509_ATTRIBUTE) *x, int nid,
williamr@2
  1175
			  int lastpos);
williamr@2
  1176
IMPORT_C int X509at_get_attr_by_OBJ(const STACK_OF(X509_ATTRIBUTE) *sk, ASN1_OBJECT *obj,
williamr@2
  1177
			  int lastpos);
williamr@2
  1178
IMPORT_C X509_ATTRIBUTE *X509at_get_attr(const STACK_OF(X509_ATTRIBUTE) *x, int loc);
williamr@2
  1179
IMPORT_C X509_ATTRIBUTE *X509at_delete_attr(STACK_OF(X509_ATTRIBUTE) *x, int loc);
williamr@2
  1180
IMPORT_C STACK_OF(X509_ATTRIBUTE) *X509at_add1_attr(STACK_OF(X509_ATTRIBUTE) **x,
williamr@2
  1181
					 X509_ATTRIBUTE *attr);
williamr@2
  1182
IMPORT_C STACK_OF(X509_ATTRIBUTE) *X509at_add1_attr_by_OBJ(STACK_OF(X509_ATTRIBUTE) **x,
williamr@2
  1183
			const ASN1_OBJECT *obj, int type,
williamr@2
  1184
			const unsigned char *bytes, int len);
williamr@2
  1185
IMPORT_C STACK_OF(X509_ATTRIBUTE) *X509at_add1_attr_by_NID(STACK_OF(X509_ATTRIBUTE) **x,
williamr@2
  1186
			int nid, int type,
williamr@2
  1187
			const unsigned char *bytes, int len);
williamr@2
  1188
IMPORT_C STACK_OF(X509_ATTRIBUTE) *X509at_add1_attr_by_txt(STACK_OF(X509_ATTRIBUTE) **x,
williamr@2
  1189
			const char *attrname, int type,
williamr@2
  1190
			const unsigned char *bytes, int len);
williamr@2
  1191
IMPORT_C X509_ATTRIBUTE *X509_ATTRIBUTE_create_by_NID(X509_ATTRIBUTE **attr, int nid,
williamr@2
  1192
	     int atrtype, const void *data, int len);
williamr@2
  1193
IMPORT_C X509_ATTRIBUTE *X509_ATTRIBUTE_create_by_OBJ(X509_ATTRIBUTE **attr,
williamr@2
  1194
	     const ASN1_OBJECT *obj, int atrtype, const void *data, int len);
williamr@2
  1195
IMPORT_C X509_ATTRIBUTE *X509_ATTRIBUTE_create_by_txt(X509_ATTRIBUTE **attr,
williamr@2
  1196
		const char *atrname, int type, const unsigned char *bytes, int len);
williamr@2
  1197
IMPORT_C int X509_ATTRIBUTE_set1_object(X509_ATTRIBUTE *attr, const ASN1_OBJECT *obj);
williamr@2
  1198
IMPORT_C int X509_ATTRIBUTE_set1_data(X509_ATTRIBUTE *attr, int attrtype, const void *data, int len);
williamr@2
  1199
IMPORT_C void *X509_ATTRIBUTE_get0_data(X509_ATTRIBUTE *attr, int idx,
williamr@2
  1200
					int atrtype, void *data);
williamr@2
  1201
IMPORT_C int X509_ATTRIBUTE_count(X509_ATTRIBUTE *attr);
williamr@2
  1202
IMPORT_C ASN1_OBJECT *X509_ATTRIBUTE_get0_object(X509_ATTRIBUTE *attr);
williamr@2
  1203
IMPORT_C ASN1_TYPE *X509_ATTRIBUTE_get0_type(X509_ATTRIBUTE *attr, int idx);
williamr@2
  1204
williamr@2
  1205
IMPORT_C int EVP_PKEY_get_attr_count(const EVP_PKEY *key);
williamr@2
  1206
IMPORT_C int EVP_PKEY_get_attr_by_NID(const EVP_PKEY *key, int nid,
williamr@2
  1207
			  int lastpos);
williamr@2
  1208
IMPORT_C int EVP_PKEY_get_attr_by_OBJ(const EVP_PKEY *key, ASN1_OBJECT *obj,
williamr@2
  1209
			  int lastpos);
williamr@2
  1210
IMPORT_C X509_ATTRIBUTE *EVP_PKEY_get_attr(const EVP_PKEY *key, int loc);
williamr@2
  1211
IMPORT_C X509_ATTRIBUTE *EVP_PKEY_delete_attr(EVP_PKEY *key, int loc);
williamr@2
  1212
IMPORT_C int EVP_PKEY_add1_attr(EVP_PKEY *key, X509_ATTRIBUTE *attr);
williamr@2
  1213
IMPORT_C int EVP_PKEY_add1_attr_by_OBJ(EVP_PKEY *key,
williamr@2
  1214
			const ASN1_OBJECT *obj, int type,
williamr@2
  1215
			const unsigned char *bytes, int len);
williamr@2
  1216
IMPORT_C int EVP_PKEY_add1_attr_by_NID(EVP_PKEY *key,
williamr@2
  1217
			int nid, int type,
williamr@2
  1218
			const unsigned char *bytes, int len);
williamr@2
  1219
IMPORT_C int EVP_PKEY_add1_attr_by_txt(EVP_PKEY *key,
williamr@2
  1220
			const char *attrname, int type,
williamr@2
  1221
			const unsigned char *bytes, int len);
williamr@2
  1222
williamr@2
  1223
IMPORT_C int		X509_verify_cert(X509_STORE_CTX *ctx);
williamr@2
  1224
williamr@2
  1225
/* lookup a cert from a X509 STACK */
williamr@2
  1226
IMPORT_C X509 *X509_find_by_issuer_and_serial(STACK_OF(X509) *sk,X509_NAME *name,
williamr@2
  1227
				     ASN1_INTEGER *serial);
williamr@2
  1228
IMPORT_C X509 *X509_find_by_subject(STACK_OF(X509) *sk,X509_NAME *name);
williamr@2
  1229
williamr@2
  1230
DECLARE_ASN1_FUNCTIONS(PBEPARAM)
williamr@2
  1231
DECLARE_ASN1_FUNCTIONS(PBE2PARAM)
williamr@2
  1232
DECLARE_ASN1_FUNCTIONS(PBKDF2PARAM)
williamr@2
  1233
williamr@2
  1234
IMPORT_C X509_ALGOR *PKCS5_pbe_set(int alg, int iter, unsigned char *salt, int saltlen);
williamr@2
  1235
IMPORT_C X509_ALGOR *PKCS5_pbe2_set(const EVP_CIPHER *cipher, int iter,
williamr@2
  1236
					 unsigned char *salt, int saltlen);
williamr@2
  1237
williamr@2
  1238
/* PKCS#8 utilities */
williamr@2
  1239
williamr@2
  1240
DECLARE_ASN1_FUNCTIONS(PKCS8_PRIV_KEY_INFO)
williamr@2
  1241
williamr@2
  1242
IMPORT_C EVP_PKEY *EVP_PKCS82PKEY(PKCS8_PRIV_KEY_INFO *p8);
williamr@2
  1243
IMPORT_C PKCS8_PRIV_KEY_INFO *EVP_PKEY2PKCS8(EVP_PKEY *pkey);
williamr@2
  1244
IMPORT_C PKCS8_PRIV_KEY_INFO *EVP_PKEY2PKCS8_broken(EVP_PKEY *pkey, int broken);
williamr@2
  1245
IMPORT_C PKCS8_PRIV_KEY_INFO *PKCS8_set_broken(PKCS8_PRIV_KEY_INFO *p8, int broken);
williamr@2
  1246
williamr@2
  1247
IMPORT_C int X509_check_trust(X509 *x, int id, int flags);
williamr@2
  1248
IMPORT_C int X509_TRUST_get_count(void);
williamr@2
  1249
IMPORT_C X509_TRUST * X509_TRUST_get0(int idx);
williamr@2
  1250
IMPORT_C int X509_TRUST_get_by_id(int id);
williamr@2
  1251
IMPORT_C int X509_TRUST_add(int id, int flags, int (*ck)(X509_TRUST *, X509 *, int),
williamr@2
  1252
					char *name, int arg1, void *arg2);
williamr@2
  1253
IMPORT_C void X509_TRUST_cleanup(void);
williamr@2
  1254
IMPORT_C int X509_TRUST_get_flags(X509_TRUST *xp);
williamr@2
  1255
IMPORT_C char *X509_TRUST_get0_name(X509_TRUST *xp);
williamr@2
  1256
IMPORT_C int X509_TRUST_get_trust(X509_TRUST *xp);
williamr@2
  1257
williamr@2
  1258
/* BEGIN ERROR CODES */
williamr@2
  1259
/* The following lines are auto generated by the script mkerr.pl. Any changes
williamr@2
  1260
 * made after this point may be overwritten when the script is next run.
williamr@2
  1261
 */
williamr@2
  1262
IMPORT_C void ERR_load_X509_strings(void);
williamr@2
  1263
williamr@2
  1264
/* Error codes for the X509 functions. */
williamr@2
  1265
williamr@2
  1266
/* Function codes. */
williamr@2
  1267
#define X509_F_ADD_CERT_DIR				 100
williamr@2
  1268
#define X509_F_BY_FILE_CTRL				 101
williamr@2
  1269
#define X509_F_CHECK_POLICY				 145
williamr@2
  1270
#define X509_F_DIR_CTRL					 102
williamr@2
  1271
#define X509_F_GET_CERT_BY_SUBJECT			 103
williamr@2
  1272
#define X509_F_NETSCAPE_SPKI_B64_DECODE			 129
williamr@2
  1273
#define X509_F_NETSCAPE_SPKI_B64_ENCODE			 130
williamr@2
  1274
#define X509_F_X509AT_ADD1_ATTR				 135
williamr@2
  1275
#define X509_F_X509V3_ADD_EXT				 104
williamr@2
  1276
#define X509_F_X509_ATTRIBUTE_CREATE_BY_NID		 136
williamr@2
  1277
#define X509_F_X509_ATTRIBUTE_CREATE_BY_OBJ		 137
williamr@2
  1278
#define X509_F_X509_ATTRIBUTE_CREATE_BY_TXT		 140
williamr@2
  1279
#define X509_F_X509_ATTRIBUTE_GET0_DATA			 139
williamr@2
  1280
#define X509_F_X509_ATTRIBUTE_SET1_DATA			 138
williamr@2
  1281
#define X509_F_X509_CHECK_PRIVATE_KEY			 128
williamr@2
  1282
#define X509_F_X509_CRL_PRINT_FP			 147
williamr@2
  1283
#define X509_F_X509_EXTENSION_CREATE_BY_NID		 108
williamr@2
  1284
#define X509_F_X509_EXTENSION_CREATE_BY_OBJ		 109
williamr@2
  1285
#define X509_F_X509_GET_PUBKEY_PARAMETERS		 110
williamr@2
  1286
#define X509_F_X509_LOAD_CERT_CRL_FILE			 132
williamr@2
  1287
#define X509_F_X509_LOAD_CERT_FILE			 111
williamr@2
  1288
#define X509_F_X509_LOAD_CRL_FILE			 112
williamr@2
  1289
#define X509_F_X509_NAME_ADD_ENTRY			 113
williamr@2
  1290
#define X509_F_X509_NAME_ENTRY_CREATE_BY_NID		 114
williamr@2
  1291
#define X509_F_X509_NAME_ENTRY_CREATE_BY_TXT		 131
williamr@2
  1292
#define X509_F_X509_NAME_ENTRY_SET_OBJECT		 115
williamr@2
  1293
#define X509_F_X509_NAME_ONELINE			 116
williamr@2
  1294
#define X509_F_X509_NAME_PRINT				 117
williamr@2
  1295
#define X509_F_X509_PRINT_EX_FP				 118
williamr@2
  1296
#define X509_F_X509_PUBKEY_GET				 119
williamr@2
  1297
#define X509_F_X509_PUBKEY_SET				 120
williamr@2
  1298
#define X509_F_X509_REQ_CHECK_PRIVATE_KEY		 144
williamr@2
  1299
#define X509_F_X509_REQ_PRINT_EX			 121
williamr@2
  1300
#define X509_F_X509_REQ_PRINT_FP			 122
williamr@2
  1301
#define X509_F_X509_REQ_TO_X509				 123
williamr@2
  1302
#define X509_F_X509_STORE_ADD_CERT			 124
williamr@2
  1303
#define X509_F_X509_STORE_ADD_CRL			 125
williamr@2
  1304
#define X509_F_X509_STORE_CTX_GET1_ISSUER		 146
williamr@2
  1305
#define X509_F_X509_STORE_CTX_INIT			 143
williamr@2
  1306
#define X509_F_X509_STORE_CTX_NEW			 142
williamr@2
  1307
#define X509_F_X509_STORE_CTX_PURPOSE_INHERIT		 134
williamr@2
  1308
#define X509_F_X509_TO_X509_REQ				 126
williamr@2
  1309
#define X509_F_X509_TRUST_ADD				 133
williamr@2
  1310
#define X509_F_X509_TRUST_SET				 141
williamr@2
  1311
#define X509_F_X509_VERIFY_CERT				 127
williamr@2
  1312
williamr@2
  1313
/* Reason codes. */
williamr@2
  1314
#define X509_R_BAD_X509_FILETYPE			 100
williamr@2
  1315
#define X509_R_BASE64_DECODE_ERROR			 118
williamr@2
  1316
#define X509_R_CANT_CHECK_DH_KEY			 114
williamr@2
  1317
#define X509_R_CERT_ALREADY_IN_HASH_TABLE		 101
williamr@2
  1318
#define X509_R_ERR_ASN1_LIB				 102
williamr@2
  1319
#define X509_R_INVALID_DIRECTORY			 113
williamr@2
  1320
#define X509_R_INVALID_FIELD_NAME			 119
williamr@2
  1321
#define X509_R_INVALID_TRUST				 123
williamr@2
  1322
#define X509_R_KEY_TYPE_MISMATCH			 115
williamr@2
  1323
#define X509_R_KEY_VALUES_MISMATCH			 116
williamr@2
  1324
#define X509_R_LOADING_CERT_DIR				 103
williamr@2
  1325
#define X509_R_LOADING_DEFAULTS				 104
williamr@2
  1326
#define X509_R_NO_CERT_SET_FOR_US_TO_VERIFY		 105
williamr@2
  1327
#define X509_R_SHOULD_RETRY				 106
williamr@2
  1328
#define X509_R_UNABLE_TO_FIND_PARAMETERS_IN_CHAIN	 107
williamr@2
  1329
#define X509_R_UNABLE_TO_GET_CERTS_PUBLIC_KEY		 108
williamr@2
  1330
#define X509_R_UNKNOWN_KEY_TYPE				 117
williamr@2
  1331
#define X509_R_UNKNOWN_NID				 109
williamr@2
  1332
#define X509_R_UNKNOWN_PURPOSE_ID			 121
williamr@2
  1333
#define X509_R_UNKNOWN_TRUST_ID				 120
williamr@2
  1334
#define X509_R_UNSUPPORTED_ALGORITHM			 111
williamr@2
  1335
#define X509_R_WRONG_LOOKUP_TYPE			 112
williamr@2
  1336
#define X509_R_WRONG_TYPE				 122
williamr@2
  1337
williamr@2
  1338
#ifdef  __cplusplus
williamr@2
  1339
}
williamr@2
  1340
#endif
williamr@2
  1341
#endif