]> git.saurik.com Git - apple/security.git/blame - OSX/libsecurity_cssm/lib/x509defs.h
Security-59754.80.3.tar.gz
[apple/security.git] / OSX / libsecurity_cssm / lib / x509defs.h
CommitLineData
b1ab9ed8 1/*
d8f41ccd 2 * Copyright (c) 1999-2002,2004,2011,2014 Apple Inc. All Rights Reserved.
b1ab9ed8
A
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
11 * file.
12 *
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
20 *
21 * @APPLE_LICENSE_HEADER_END@
22 *
23 * x509defs.h -- Data structures for X509 Certificate Library field values
24 */
25
26#ifndef _X509DEFS_H_
27#define _X509DEFS_H_ 1
28
29#include <Security/cssmtype.h>
30
31#ifdef __cplusplus
32extern "C" {
33#endif
34
fa7225c8
A
35#pragma clang diagnostic push
36#pragma clang diagnostic ignored "-Wdeprecated-declarations"
37
b1ab9ed8
A
38typedef uint8 CSSM_BER_TAG;
39#define BER_TAG_UNKNOWN 0
40#define BER_TAG_BOOLEAN 1
41#define BER_TAG_INTEGER 2
42#define BER_TAG_BIT_STRING 3
43#define BER_TAG_OCTET_STRING 4
44#define BER_TAG_NULL 5
45#define BER_TAG_OID 6
46#define BER_TAG_OBJECT_DESCRIPTOR 7
47#define BER_TAG_EXTERNAL 8
48#define BER_TAG_REAL 9
49#define BER_TAG_ENUMERATED 10
50/* 12 to 15 are reserved for future versions of the recommendation */
51#define BER_TAG_PKIX_UTF8_STRING 12
52#define BER_TAG_SEQUENCE 16
53#define BER_TAG_SET 17
54#define BER_TAG_NUMERIC_STRING 18
55#define BER_TAG_PRINTABLE_STRING 19
56#define BER_TAG_T61_STRING 20
57#define BER_TAG_TELETEX_STRING BER_TAG_T61_STRING
58#define BER_TAG_VIDEOTEX_STRING 21
59#define BER_TAG_IA5_STRING 22
60#define BER_TAG_UTC_TIME 23
61#define BER_TAG_GENERALIZED_TIME 24
62#define BER_TAG_GRAPHIC_STRING 25
63#define BER_TAG_ISO646_STRING 26
64#define BER_TAG_GENERAL_STRING 27
65#define BER_TAG_VISIBLE_STRING BER_TAG_ISO646_STRING
66/* 28 - are reserved for future versions of the recommendation */
67#define BER_TAG_PKIX_UNIVERSAL_STRING 28
68#define BER_TAG_PKIX_BMP_STRING 30
69
70
71/* Data Structures for X.509 Certificates */
b54c578e
A
72#define CSSM_X509_ALGORITHM_IDENTIFIER SecAsn1AlgId
73typedef SecAsn1AlgId *CSSM_X509_ALGORITHM_IDENTIFIER_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
b1ab9ed8
A
74
75/* X509 Distinguished name structure */
79b9da22 76typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_type_value_pair {
b1ab9ed8
A
77 CSSM_OID type;
78 CSSM_BER_TAG valueType; /* The Tag to be used when */
79 /*this value is BER encoded */
80 CSSM_DATA value;
81} CSSM_X509_TYPE_VALUE_PAIR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_TYPE_VALUE_PAIR_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
82
79b9da22 83typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_rdn {
b1ab9ed8
A
84 uint32 numberOfPairs;
85 CSSM_X509_TYPE_VALUE_PAIR_PTR AttributeTypeAndValue;
86} CSSM_X509_RDN DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_RDN_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
87
79b9da22 88typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_name {
b1ab9ed8
A
89 uint32 numberOfRDNs;
90 CSSM_X509_RDN_PTR RelativeDistinguishedName;
91} CSSM_X509_NAME DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_NAME_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
92
93/* Public key info struct */
b54c578e
A
94#define CSSM_X509_SUBJECT_PUBLIC_KEY_INFO SecAsn1PubKeyInfo
95typedef SecAsn1PubKeyInfo *CSSM_X509_SUBJECT_PUBLIC_KEY_INFO_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
b1ab9ed8 96
79b9da22 97typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_time {
b1ab9ed8
A
98 CSSM_BER_TAG timeType;
99 CSSM_DATA time;
100} CSSM_X509_TIME DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_TIME_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
101
102/* Validity struct */
79b9da22 103typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER x509_validity {
b1ab9ed8
A
104 CSSM_X509_TIME notBefore;
105 CSSM_X509_TIME notAfter;
106} CSSM_X509_VALIDITY DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_VALIDITY_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
107
108#define CSSM_X509_OPTION_PRESENT CSSM_TRUE
109#define CSSM_X509_OPTION_NOT_PRESENT CSSM_FALSE
110typedef CSSM_BOOL CSSM_X509_OPTION;
111
79b9da22 112typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509ext_basicConstraints {
b1ab9ed8
A
113 CSSM_BOOL cA;
114 CSSM_X509_OPTION pathLenConstraintPresent;
115 uint32 pathLenConstraint;
116} CSSM_X509EXT_BASICCONSTRAINTS DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509EXT_BASICCONSTRAINTS_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
117
118typedef enum extension_data_format {
119 CSSM_X509_DATAFORMAT_ENCODED = 0,
120 CSSM_X509_DATAFORMAT_PARSED,
121 CSSM_X509_DATAFORMAT_PAIR
122} CSSM_X509EXT_DATA_FORMAT;
123
79b9da22 124typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_extensionTagAndValue {
b1ab9ed8
A
125 CSSM_BER_TAG type;
126 CSSM_DATA value;
127} CSSM_X509EXT_TAGandVALUE DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509EXT_TAGandVALUE_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
128
79b9da22 129typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509ext_pair {
b1ab9ed8
A
130 CSSM_X509EXT_TAGandVALUE tagAndValue;
131 void *parsedValue;
132} CSSM_X509EXT_PAIR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509EXT_PAIR_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
133
134/* Extension structure */
79b9da22 135typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_extension {
b1ab9ed8
A
136 CSSM_OID extnId;
137 CSSM_BOOL critical;
138 CSSM_X509EXT_DATA_FORMAT format;
79b9da22 139 union DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509ext_value {
b1ab9ed8
A
140 CSSM_X509EXT_TAGandVALUE *tagAndValue;
141 void *parsedValue;
142 CSSM_X509EXT_PAIR *valuePair;
143 } value;
144 CSSM_DATA BERvalue;
145} CSSM_X509_EXTENSION DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_EXTENSION_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
146
79b9da22 147typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_extensions {
b1ab9ed8
A
148 uint32 numberOfExtensions;
149 CSSM_X509_EXTENSION_PTR extensions;
150} CSSM_X509_EXTENSIONS DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_EXTENSIONS_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
151
152/* X509V3 certificate structure */
79b9da22 153typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_tbs_certificate {
b1ab9ed8
A
154 CSSM_DATA version;
155 CSSM_DATA serialNumber;
156 CSSM_X509_ALGORITHM_IDENTIFIER signature;
157 CSSM_X509_NAME issuer;
158 CSSM_X509_VALIDITY validity;
159 CSSM_X509_NAME subject;
160 CSSM_X509_SUBJECT_PUBLIC_KEY_INFO subjectPublicKeyInfo;
161 CSSM_DATA issuerUniqueIdentifier;
162 CSSM_DATA subjectUniqueIdentifier;
163 CSSM_X509_EXTENSIONS extensions;
164} CSSM_X509_TBS_CERTIFICATE DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_TBS_CERTIFICATE_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
165
166/* Signature structure */
79b9da22 167typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_signature {
b1ab9ed8
A
168 CSSM_X509_ALGORITHM_IDENTIFIER algorithmIdentifier;
169 CSSM_DATA encrypted;
170} CSSM_X509_SIGNATURE DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_SIGNATURE_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
171
172/* Signed certificate structure */
79b9da22 173typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_signed_certificate {
b1ab9ed8
A
174 CSSM_X509_TBS_CERTIFICATE certificate;
175 CSSM_X509_SIGNATURE signature;
176} CSSM_X509_SIGNED_CERTIFICATE DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_SIGNED_CERTIFICATE_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
177
79b9da22 178typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509ext_policyQualifierInfo {
b1ab9ed8
A
179 CSSM_OID policyQualifierId;
180 CSSM_DATA value;
181} CSSM_X509EXT_POLICYQUALIFIERINFO DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509EXT_POLICYQUALIFIERINFO_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
182
79b9da22 183typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509ext_policyQualifiers {
b1ab9ed8
A
184 uint32 numberOfPolicyQualifiers;
185 CSSM_X509EXT_POLICYQUALIFIERINFO *policyQualifier;
186} CSSM_X509EXT_POLICYQUALIFIERS DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509EXT_POLICYQUALIFIERS_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
187
79b9da22 188typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509ext_policyInfo {
b1ab9ed8
A
189 CSSM_OID policyIdentifier;
190 CSSM_X509EXT_POLICYQUALIFIERS policyQualifiers;
191} CSSM_X509EXT_POLICYINFO DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509EXT_POLICYINFO_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
192
193
194/* Data Structures for X.509 Certificate Revocations Lists */
195
196/* x509V2 entry in the CRL revokedCertificates sequence */
79b9da22 197typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_revoked_cert_entry {
b1ab9ed8
A
198 CSSM_DATA certificateSerialNumber;
199 CSSM_X509_TIME revocationDate;
200 CSSM_X509_EXTENSIONS extensions;
201} CSSM_X509_REVOKED_CERT_ENTRY DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_REVOKED_CERT_ENTRY_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
202
79b9da22 203typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_revoked_cert_list {
b1ab9ed8
A
204 uint32 numberOfRevokedCertEntries;
205 CSSM_X509_REVOKED_CERT_ENTRY_PTR revokedCertEntry;
206} CSSM_X509_REVOKED_CERT_LIST DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_REVOKED_CERT_LIST_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
207
208/* x509v2 Certificate Revocation List (CRL) (unsigned) structure */
79b9da22 209typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_tbs_certlist {
b1ab9ed8
A
210 CSSM_DATA version;
211 CSSM_X509_ALGORITHM_IDENTIFIER signature;
212 CSSM_X509_NAME issuer;
213 CSSM_X509_TIME thisUpdate;
214 CSSM_X509_TIME nextUpdate;
215 CSSM_X509_REVOKED_CERT_LIST_PTR revokedCertificates;
216 CSSM_X509_EXTENSIONS extensions;
217} CSSM_X509_TBS_CERTLIST DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_TBS_CERTLIST_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
218
79b9da22 219typedef struct DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER cssm_x509_signed_crl {
b1ab9ed8
A
220 CSSM_X509_TBS_CERTLIST tbsCertList;
221 CSSM_X509_SIGNATURE signature;
222} CSSM_X509_SIGNED_CRL DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER, *CSSM_X509_SIGNED_CRL_PTR DEPRECATED_IN_MAC_OS_X_VERSION_10_7_AND_LATER;
223
fa7225c8
A
224#pragma clang diagnostic pop
225
b1ab9ed8
A
226#ifdef __cplusplus
227}
228#endif
229
230#endif /* _X509DEFS_H_ */