]>
Commit | Line | Data |
---|---|---|
d02b48c6 | 1 | /* crypto/asn1/asn1.h */ |
58964a49 | 2 | /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) |
d02b48c6 RE |
3 | * All rights reserved. |
4 | * | |
5 | * This package is an SSL implementation written | |
6 | * by Eric Young (eay@cryptsoft.com). | |
7 | * The implementation was written so as to conform with Netscapes SSL. | |
8 | * | |
9 | * This library is free for commercial and non-commercial use as long as | |
10 | * the following conditions are aheared to. The following conditions | |
11 | * apply to all code found in this distribution, be it the RC4, RSA, | |
12 | * lhash, DES, etc., code; not just the SSL code. The SSL documentation | |
13 | * included with this distribution is covered by the same copyright terms | |
14 | * except that the holder is Tim Hudson (tjh@cryptsoft.com). | |
15 | * | |
16 | * Copyright remains Eric Young's, and as such any Copyright notices in | |
17 | * the code are not to be removed. | |
18 | * If this package is used in a product, Eric Young should be given attribution | |
19 | * as the author of the parts of the library used. | |
20 | * This can be in the form of a textual message at program startup or | |
21 | * in documentation (online or textual) provided with the package. | |
22 | * | |
23 | * Redistribution and use in source and binary forms, with or without | |
24 | * modification, are permitted provided that the following conditions | |
25 | * are met: | |
26 | * 1. Redistributions of source code must retain the copyright | |
27 | * notice, this list of conditions and the following disclaimer. | |
28 | * 2. Redistributions in binary form must reproduce the above copyright | |
29 | * notice, this list of conditions and the following disclaimer in the | |
30 | * documentation and/or other materials provided with the distribution. | |
31 | * 3. All advertising materials mentioning features or use of this software | |
32 | * must display the following acknowledgement: | |
33 | * "This product includes cryptographic software written by | |
34 | * Eric Young (eay@cryptsoft.com)" | |
35 | * The word 'cryptographic' can be left out if the rouines from the library | |
36 | * being used are not cryptographic related :-). | |
37 | * 4. If you include any Windows specific code (or a derivative thereof) from | |
38 | * the apps directory (application code) you must include an acknowledgement: | |
39 | * "This product includes software written by Tim Hudson (tjh@cryptsoft.com)" | |
40 | * | |
41 | * THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND | |
42 | * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |
43 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | |
44 | * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE | |
45 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | |
46 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS | |
47 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) | |
48 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT | |
49 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY | |
50 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF | |
51 | * SUCH DAMAGE. | |
52 | * | |
53 | * The licence and distribution terms for any publically available version or | |
54 | * derivative of this code cannot be changed. i.e. this code cannot simply be | |
55 | * copied and put under another distribution licence | |
56 | * [including the GNU Public Licence.] | |
57 | */ | |
58 | ||
59 | #ifndef HEADER_ASN1_H | |
60 | #define HEADER_ASN1_H | |
61 | ||
62 | #ifdef __cplusplus | |
63 | extern "C" { | |
64 | #endif | |
65 | ||
66 | #include <time.h> | |
ec577822 BM |
67 | #include <openssl/bn.h> |
68 | #include <openssl/stack.h> | |
d35ea5b0 | 69 | #include <openssl/safestack.h> |
d02b48c6 RE |
70 | |
71 | #define V_ASN1_UNIVERSAL 0x00 | |
72 | #define V_ASN1_APPLICATION 0x40 | |
73 | #define V_ASN1_CONTEXT_SPECIFIC 0x80 | |
74 | #define V_ASN1_PRIVATE 0xc0 | |
75 | ||
76 | #define V_ASN1_CONSTRUCTED 0x20 | |
5d818c30 | 77 | #define V_ASN1_PRIMITIVE_TAG 0x1f |
d02b48c6 RE |
78 | #define V_ASN1_PRIMATIVE_TAG 0x1f |
79 | ||
80 | #define V_ASN1_APP_CHOOSE -2 /* let the recipent choose */ | |
81 | ||
82 | #define V_ASN1_UNDEF -1 | |
83 | #define V_ASN1_EOC 0 | |
84 | #define V_ASN1_BOOLEAN 1 /**/ | |
85 | #define V_ASN1_INTEGER 2 | |
86 | #define V_ASN1_NEG_INTEGER (2+0x100) | |
87 | #define V_ASN1_BIT_STRING 3 | |
88 | #define V_ASN1_OCTET_STRING 4 | |
89 | #define V_ASN1_NULL 5 | |
90 | #define V_ASN1_OBJECT 6 | |
58964a49 RE |
91 | #define V_ASN1_OBJECT_DESCRIPTOR 7 |
92 | #define V_ASN1_EXTERNAL 8 | |
d02b48c6 | 93 | #define V_ASN1_REAL 9 |
bceacf93 DSH |
94 | #define V_ASN1_ENUMERATED 10 |
95 | #define V_ASN1_NEG_ENUMERATED (10+0x100) | |
d77b3054 | 96 | #define V_ASN1_UTF8STRING 12 |
d02b48c6 RE |
97 | #define V_ASN1_SEQUENCE 16 |
98 | #define V_ASN1_SET 17 | |
99 | #define V_ASN1_NUMERICSTRING 18 /**/ | |
100 | #define V_ASN1_PRINTABLESTRING 19 | |
101 | #define V_ASN1_T61STRING 20 | |
102 | #define V_ASN1_TELETEXSTRING 20 /* alias */ | |
103 | #define V_ASN1_VIDEOTEXSTRING 21 /**/ | |
104 | #define V_ASN1_IA5STRING 22 | |
105 | #define V_ASN1_UTCTIME 23 | |
106 | #define V_ASN1_GENERALIZEDTIME 24 /**/ | |
107 | #define V_ASN1_GRAPHICSTRING 25 /**/ | |
108 | #define V_ASN1_ISO64STRING 26 /**/ | |
109 | #define V_ASN1_VISIBLESTRING 26 /* alias */ | |
110 | #define V_ASN1_GENERALSTRING 27 /**/ | |
111 | #define V_ASN1_UNIVERSALSTRING 28 /**/ | |
58964a49 | 112 | #define V_ASN1_BMPSTRING 30 |
d02b48c6 RE |
113 | |
114 | /* For use with d2i_ASN1_type_bytes() */ | |
115 | #define B_ASN1_NUMERICSTRING 0x0001 | |
116 | #define B_ASN1_PRINTABLESTRING 0x0002 | |
117 | #define B_ASN1_T61STRING 0x0004 | |
d77b3054 | 118 | #define B_ASN1_TELETEXSTRING 0x0008 |
d02b48c6 RE |
119 | #define B_ASN1_VIDEOTEXSTRING 0x0008 |
120 | #define B_ASN1_IA5STRING 0x0010 | |
121 | #define B_ASN1_GRAPHICSTRING 0x0020 | |
122 | #define B_ASN1_ISO64STRING 0x0040 | |
d77b3054 | 123 | #define B_ASN1_VISIBLESTRING 0x0040 |
d02b48c6 RE |
124 | #define B_ASN1_GENERALSTRING 0x0080 |
125 | #define B_ASN1_UNIVERSALSTRING 0x0100 | |
126 | #define B_ASN1_OCTET_STRING 0x0200 | |
58964a49 RE |
127 | #define B_ASN1_BIT_STRING 0x0400 |
128 | #define B_ASN1_BMPSTRING 0x0800 | |
d02b48c6 | 129 | #define B_ASN1_UNKNOWN 0x1000 |
d77b3054 | 130 | #define B_ASN1_UTF8STRING 0x2000 |
d02b48c6 | 131 | |
d35ea5b0 BL |
132 | #define DECLARE_ASN1_SET_OF(type) \ |
133 | int i2d_ASN1_SET_OF_##type(STACK_OF(type) *a,unsigned char **pp, \ | |
134 | int (*func)(type *,unsigned char **), int ex_tag, \ | |
135 | int ex_class, int is_set); \ | |
136 | STACK_OF(type) *d2i_ASN1_SET_OF_##type(STACK_OF(type) **a,unsigned char **pp, \ | |
137 | long length, \ | |
138 | type *(*func)(type **, \ | |
139 | unsigned char **,long), \ | |
140 | void (*free_func)(type *), \ | |
141 | int ex_tag,int ex_class); | |
142 | ||
143 | #define IMPLEMENT_ASN1_SET_OF(type) \ | |
144 | int i2d_ASN1_SET_OF_##type(STACK_OF(type) *a,unsigned char **pp, \ | |
145 | int (*func)(type *,unsigned char **), int ex_tag, \ | |
146 | int ex_class, int is_set) \ | |
147 | { return i2d_ASN1_SET((STACK *)a,pp,func,ex_tag,ex_class,is_set); } \ | |
148 | STACK_OF(type) *d2i_ASN1_SET_OF_##type(STACK_OF(type) **a,unsigned char **pp, \ | |
149 | long length, \ | |
150 | type *(*func)(type **, \ | |
151 | unsigned char **,long), \ | |
152 | void (*free_func)(type *), \ | |
153 | int ex_tag,int ex_class) \ | |
154 | { return (STACK_OF(type) *)d2i_ASN1_SET((STACK **)a,pp,length, \ | |
155 | (char *(*)())func, \ | |
156 | (void (*)())free_func, \ | |
157 | ex_tag,ex_class); } | |
158 | ||
d02b48c6 RE |
159 | typedef struct asn1_ctx_st |
160 | { | |
161 | unsigned char *p;/* work char pointer */ | |
162 | int eos; /* end of sequence read for indefinite encoding */ | |
163 | int error; /* error code to use when returning an error */ | |
164 | int inf; /* constructed if 0x20, indefinite is 0x21 */ | |
165 | int tag; /* tag from last 'get object' */ | |
166 | int xclass; /* class from last 'get object' */ | |
167 | long slen; /* length of last 'get object' */ | |
168 | unsigned char *max; /* largest value of p alowed */ | |
169 | unsigned char *q;/* temporary variable */ | |
170 | unsigned char **pp;/* variable */ | |
dfeab068 | 171 | int line; /* used in error processing */ |
d02b48c6 RE |
172 | } ASN1_CTX; |
173 | ||
174 | /* These are used internally in the ASN1_OBJECT to keep track of | |
175 | * whether the names and data need to be free()ed */ | |
176 | #define ASN1_OBJECT_FLAG_DYNAMIC 0x01 /* internal use */ | |
177 | #define ASN1_OBJECT_FLAG_CRITICAL 0x02 /* critical x509v3 object id */ | |
178 | #define ASN1_OBJECT_FLAG_DYNAMIC_STRINGS 0x04 /* internal use */ | |
179 | #define ASN1_OBJECT_FLAG_DYNAMIC_DATA 0x08 /* internal use */ | |
180 | typedef struct asn1_object_st | |
181 | { | |
e778802f | 182 | const char *sn,*ln; |
d02b48c6 RE |
183 | int nid; |
184 | int length; | |
185 | unsigned char *data; | |
186 | int flags; /* Should we free this one */ | |
187 | } ASN1_OBJECT; | |
188 | ||
dfeab068 | 189 | #define ASN1_STRING_FLAG_BITS_LEFT 0x08 /* Set if 0x07 has bits left value */ |
d02b48c6 RE |
190 | /* This is the base type that holds just about everything :-) */ |
191 | typedef struct asn1_string_st | |
192 | { | |
193 | int length; | |
194 | int type; | |
195 | unsigned char *data; | |
dfeab068 RE |
196 | /* The value of the following field depends on the type being |
197 | * held. It is mostly being used for BIT_STRING so if the | |
198 | * input data has a non-zero 'unused bits' value, it will be | |
199 | * handled correctly */ | |
200 | long flags; | |
d02b48c6 RE |
201 | } ASN1_STRING; |
202 | ||
dfeab068 RE |
203 | #ifndef DEBUG |
204 | #define ASN1_INTEGER ASN1_STRING | |
bceacf93 | 205 | #define ASN1_ENUMERATED ASN1_STRING |
dfeab068 RE |
206 | #define ASN1_BIT_STRING ASN1_STRING |
207 | #define ASN1_OCTET_STRING ASN1_STRING | |
208 | #define ASN1_PRINTABLESTRING ASN1_STRING | |
209 | #define ASN1_T61STRING ASN1_STRING | |
210 | #define ASN1_IA5STRING ASN1_STRING | |
211 | #define ASN1_UTCTIME ASN1_STRING | |
212 | #define ASN1_GENERALIZEDTIME ASN1_STRING | |
f6aed2cd | 213 | #define ASN1_TIME ASN1_STRING |
dfeab068 RE |
214 | #define ASN1_GENERALSTRING ASN1_STRING |
215 | #define ASN1_UNIVERSALSTRING ASN1_STRING | |
216 | #define ASN1_BMPSTRING ASN1_STRING | |
d77b3054 DSH |
217 | #define ASN1_VISIBLESTRING ASN1_STRING |
218 | #define ASN1_UTF8STRING ASN1_STRING | |
dfeab068 RE |
219 | #else |
220 | typedef struct asn1_string_st ASN1_INTEGER; | |
bceacf93 | 221 | typedef struct asn1_string_st ASN1_ENUMERATED; |
dfeab068 RE |
222 | typedef struct asn1_string_st ASN1_BIT_STRING; |
223 | typedef struct asn1_string_st ASN1_OCTET_STRING; | |
224 | typedef struct asn1_string_st ASN1_PRINTABLESTRING; | |
225 | typedef struct asn1_string_st ASN1_T61STRING; | |
226 | typedef struct asn1_string_st ASN1_IA5STRING; | |
227 | typedef struct asn1_string_st ASN1_GENERALSTRING; | |
228 | typedef struct asn1_string_st ASN1_UNIVERSALSTRING; | |
229 | typedef struct asn1_string_st ASN1_BMPSTRING; | |
230 | typedef struct asn1_string_st ASN1_UTCTIME; | |
f6aed2cd | 231 | typedef struct asn1_string_st ASN1_TIME; |
dfeab068 | 232 | typedef struct asn1_string_st ASN1_GENERALIZEDTIME; |
d77b3054 DSH |
233 | typedef struct asn1_string_st ASN1_VISIBLESTRING; |
234 | typedef struct asn1_string_st ASN1_UTF8STRING; | |
dfeab068 RE |
235 | #endif |
236 | ||
d02b48c6 RE |
237 | typedef struct asn1_type_st |
238 | { | |
239 | int type; | |
240 | union { | |
241 | char *ptr; | |
242 | ASN1_STRING * asn1_string; | |
243 | ASN1_OBJECT * object; | |
244 | ASN1_INTEGER * integer; | |
bceacf93 | 245 | ASN1_ENUMERATED * enumerated; |
d02b48c6 RE |
246 | ASN1_BIT_STRING * bit_string; |
247 | ASN1_OCTET_STRING * octet_string; | |
248 | ASN1_PRINTABLESTRING * printablestring; | |
249 | ASN1_T61STRING * t61string; | |
250 | ASN1_IA5STRING * ia5string; | |
251 | ASN1_GENERALSTRING * generalstring; | |
58964a49 | 252 | ASN1_BMPSTRING * bmpstring; |
d02b48c6 RE |
253 | ASN1_UNIVERSALSTRING * universalstring; |
254 | ASN1_UTCTIME * utctime; | |
58964a49 | 255 | ASN1_GENERALIZEDTIME * generalizedtime; |
d77b3054 DSH |
256 | ASN1_VISIBLESTRING * visiblestring; |
257 | ASN1_UTF8STRING * utf8string; | |
d02b48c6 RE |
258 | /* set and sequence are left complete and still |
259 | * contain the set or sequence bytes */ | |
260 | ASN1_STRING * set; | |
261 | ASN1_STRING * sequence; | |
262 | } value; | |
263 | } ASN1_TYPE; | |
264 | ||
d35ea5b0 BL |
265 | DECLARE_STACK_OF(ASN1_TYPE) |
266 | DECLARE_ASN1_SET_OF(ASN1_TYPE) | |
267 | ||
d02b48c6 RE |
268 | typedef struct asn1_method_st |
269 | { | |
270 | int (*i2d)(); | |
271 | char *(*d2i)(); | |
272 | char *(*create)(); | |
273 | void (*destroy)(); | |
274 | } ASN1_METHOD; | |
275 | ||
276 | /* This is used when parsing some Netscape objects */ | |
277 | typedef struct asn1_header_st | |
278 | { | |
279 | ASN1_OCTET_STRING *header; | |
280 | char *data; | |
281 | ASN1_METHOD *meth; | |
282 | } ASN1_HEADER; | |
283 | ||
58964a49 | 284 | #define ASN1_STRING_length(x) ((x)->length) |
d02b48c6 RE |
285 | #define ASN1_STRING_type(x) ((x)->type) |
286 | #define ASN1_STRING_data(x) ((x)->data) | |
287 | ||
288 | /* Macros for string operations */ | |
289 | #define ASN1_BIT_STRING_new() (ASN1_BIT_STRING *)\ | |
290 | ASN1_STRING_type_new(V_ASN1_BIT_STRING) | |
291 | #define ASN1_BIT_STRING_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
292 | #define ASN1_BIT_STRING_dup(a) (ASN1_BIT_STRING *)\ | |
293 | ASN1_STRING_dup((ASN1_STRING *)a) | |
294 | #define ASN1_BIT_STRING_cmp(a,b) ASN1_STRING_cmp(\ | |
295 | (ASN1_STRING *)a,(ASN1_STRING *)b) | |
296 | #define ASN1_BIT_STRING_set(a,b,c) ASN1_STRING_set((ASN1_STRING *)a,b,c) | |
297 | /* i2d_ASN1_BIT_STRING() is a function */ | |
298 | /* d2i_ASN1_BIT_STRING() is a function */ | |
299 | ||
300 | #define ASN1_INTEGER_new() (ASN1_INTEGER *)\ | |
301 | ASN1_STRING_type_new(V_ASN1_INTEGER) | |
302 | #define ASN1_INTEGER_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
303 | #define ASN1_INTEGER_dup(a) (ASN1_INTEGER *)ASN1_STRING_dup((ASN1_STRING *)a) | |
304 | #define ASN1_INTEGER_cmp(a,b) ASN1_STRING_cmp(\ | |
305 | (ASN1_STRING *)a,(ASN1_STRING *)b) | |
306 | /* ASN1_INTEGER_set() is a function, also see BN_to_ASN1_INTEGER() */ | |
307 | /* ASN1_INTEGER_get() is a function, also see ASN1_INTEGER_to_BN() */ | |
308 | /* i2d_ASN1_INTEGER() is a function */ | |
309 | /* d2i_ASN1_INTEGER() is a function */ | |
310 | ||
bceacf93 DSH |
311 | #define ASN1_ENUMERATED_new() (ASN1_ENUMERATED *)\ |
312 | ASN1_STRING_type_new(V_ASN1_ENUMERATED) | |
313 | #define ASN1_ENUMERATED_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
314 | #define ASN1_ENUMERATED_dup(a) (ASN1_ENUMERATED *)ASN1_STRING_dup((ASN1_STRING *)a) | |
315 | #define ASN1_ENUMERATED_cmp(a,b) ASN1_STRING_cmp(\ | |
316 | (ASN1_STRING *)a,(ASN1_STRING *)b) | |
317 | /* ASN1_ENUMERATED_set() is a function, also see BN_to_ASN1_ENUMERATED() */ | |
318 | /* ASN1_ENUMERATED_get() is a function, also see ASN1_ENUMERATED_to_BN() */ | |
319 | /* i2d_ASN1_ENUMERATED() is a function */ | |
320 | /* d2i_ASN1_ENUMERATED() is a function */ | |
321 | ||
d02b48c6 RE |
322 | #define ASN1_OCTET_STRING_new() (ASN1_OCTET_STRING *)\ |
323 | ASN1_STRING_type_new(V_ASN1_OCTET_STRING) | |
324 | #define ASN1_OCTET_STRING_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
325 | #define ASN1_OCTET_STRING_dup(a) (ASN1_OCTET_STRING *)\ | |
326 | ASN1_STRING_dup((ASN1_STRING *)a) | |
327 | #define ASN1_OCTET_STRING_cmp(a,b) ASN1_STRING_cmp(\ | |
328 | (ASN1_STRING *)a,(ASN1_STRING *)b) | |
329 | #define ASN1_OCTET_STRING_set(a,b,c) ASN1_STRING_set((ASN1_STRING *)a,b,c) | |
330 | #define ASN1_OCTET_STRING_print(a,b) ASN1_STRING_print(a,(ASN1_STRING *)b) | |
331 | #define M_i2d_ASN1_OCTET_STRING(a,pp) \ | |
332 | i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_OCTET_STRING,\ | |
333 | V_ASN1_OCTET_STRING) | |
334 | /* d2i_ASN1_OCTET_STRING() is a function */ | |
335 | ||
336 | #define ASN1_PRINTABLE_new() ASN1_STRING_type_new(V_ASN1_T61STRING) | |
337 | #define ASN1_PRINTABLE_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
338 | #define M_i2d_ASN1_PRINTABLE(a,pp) i2d_ASN1_bytes((ASN1_STRING *)a,\ | |
339 | pp,a->type,V_ASN1_UNIVERSAL) | |
340 | #define M_d2i_ASN1_PRINTABLE(a,pp,l) \ | |
341 | d2i_ASN1_type_bytes((ASN1_STRING **)a,pp,l, \ | |
342 | B_ASN1_PRINTABLESTRING| \ | |
343 | B_ASN1_T61STRING| \ | |
344 | B_ASN1_IA5STRING| \ | |
58964a49 | 345 | B_ASN1_BIT_STRING| \ |
d02b48c6 | 346 | B_ASN1_UNIVERSALSTRING|\ |
58964a49 | 347 | B_ASN1_BMPSTRING|\ |
d02b48c6 RE |
348 | B_ASN1_UNKNOWN) |
349 | ||
c83e523d DSH |
350 | #define DIRECTORYSTRING_new() ASN1_STRING_type_new(V_ASN1_PRINTABLESTRING) |
351 | #define DIRECTORYSTRING_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
352 | #define M_i2d_DIRECTORYSTRING(a,pp) i2d_ASN1_bytes((ASN1_STRING *)a,\ | |
353 | pp,a->type,V_ASN1_UNIVERSAL) | |
354 | #define M_d2i_DIRECTORYSTRING(a,pp,l) \ | |
355 | d2i_ASN1_type_bytes((ASN1_STRING **)a,pp,l, \ | |
356 | B_ASN1_PRINTABLESTRING| \ | |
357 | B_ASN1_TELETEXSTRING|\ | |
358 | B_ASN1_BMPSTRING|\ | |
359 | B_ASN1_UNIVERSALSTRING|\ | |
360 | B_ASN1_UTF8STRING) | |
361 | ||
362 | #define DISPLAYTEXT_new() ASN1_STRING_type_new(V_ASN1_VISIBLESTRING) | |
363 | #define DISPLAYTEXT_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
364 | #define M_i2d_DISPLAYTEXT(a,pp) i2d_ASN1_bytes((ASN1_STRING *)a,\ | |
365 | pp,a->type,V_ASN1_UNIVERSAL) | |
366 | #define M_d2i_DISPLAYTEXT(a,pp,l) \ | |
367 | d2i_ASN1_type_bytes((ASN1_STRING **)a,pp,l, \ | |
368 | B_ASN1_VISIBLESTRING| \ | |
369 | B_ASN1_BMPSTRING|\ | |
370 | B_ASN1_UTF8STRING) | |
371 | ||
e4119b93 | 372 | #define ASN1_PRINTABLESTRING_new() (ASN1_PRINTABLESTRING *)\ |
d02b48c6 RE |
373 | ASN1_STRING_type_new(V_ASN1_PRINTABLESTRING) |
374 | #define ASN1_PRINTABLESTRING_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
375 | #define M_i2d_ASN1_PRINTABLESTRING(a,pp) \ | |
376 | i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_PRINTABLESTRING,\ | |
377 | V_ASN1_UNIVERSAL) | |
378 | #define M_d2i_ASN1_PRINTABLESTRING(a,pp,l) \ | |
379 | (ASN1_PRINTABLESTRING *)d2i_ASN1_type_bytes\ | |
380 | ((ASN1_STRING **)a,pp,l,B_ASN1_PRINTABLESTRING) | |
381 | ||
382 | #define ASN1_T61STRING_new() (ASN1_T61STRING_STRING *)\ | |
383 | ASN1_STRING_type_new(V_ASN1_T61STRING) | |
384 | #define ASN1_T61STRING_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
385 | #define M_i2d_ASN1_T61STRING(a,pp) \ | |
386 | i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_T61STRING,\ | |
387 | V_ASN1_UNIVERSAL) | |
388 | #define M_d2i_ASN1_T61STRING(a,pp,l) \ | |
389 | (ASN1_T61STRING *)d2i_ASN1_type_bytes\ | |
390 | ((ASN1_STRING **)a,pp,l,B_ASN1_T61STRING) | |
391 | ||
392 | #define ASN1_IA5STRING_new() (ASN1_IA5STRING *)\ | |
393 | ASN1_STRING_type_new(V_ASN1_IA5STRING) | |
394 | #define ASN1_IA5STRING_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
aa066b9e DSH |
395 | #define ASN1_IA5STRING_dup(a) \ |
396 | (ASN1_IA5STRING *)ASN1_STRING_dup((ASN1_STRING *)a) | |
d02b48c6 RE |
397 | #define M_i2d_ASN1_IA5STRING(a,pp) \ |
398 | i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_IA5STRING,\ | |
399 | V_ASN1_UNIVERSAL) | |
400 | #define M_d2i_ASN1_IA5STRING(a,pp,l) \ | |
401 | (ASN1_IA5STRING *)d2i_ASN1_type_bytes((ASN1_STRING **)a,pp,l,\ | |
402 | B_ASN1_IA5STRING) | |
403 | ||
404 | #define ASN1_UTCTIME_new() (ASN1_UTCTIME *)\ | |
405 | ASN1_STRING_type_new(V_ASN1_UTCTIME) | |
406 | #define ASN1_UTCTIME_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
407 | #define ASN1_UTCTIME_dup(a) (ASN1_UTCTIME *)ASN1_STRING_dup((ASN1_STRING *)a) | |
408 | /* i2d_ASN1_UTCTIME() is a function */ | |
409 | /* d2i_ASN1_UTCTIME() is a function */ | |
410 | /* ASN1_UTCTIME_set() is a function */ | |
411 | /* ASN1_UTCTIME_check() is a function */ | |
58964a49 RE |
412 | |
413 | #define ASN1_GENERALIZEDTIME_new() (ASN1_GENERALIZEDTIME *)\ | |
414 | ASN1_STRING_type_new(V_ASN1_GENERALIZEDTIME) | |
415 | #define ASN1_GENERALIZEDTIME_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
f6aed2cd | 416 | #define ASN1_GENERALIZEDTIME_dup(a) (ASN1_GENERALIZEDTIME *)ASN1_STRING_dup(\ |
58964a49 | 417 | (ASN1_STRING *)a) |
f6aed2cd DSH |
418 | /* i2d_ASN1_GENERALIZEDTIME() is a function */ |
419 | /* d2i_ASN1_GENERALIZEDTIME() is a function */ | |
420 | /* ASN1_GENERALIZEDTIME_set() is a function */ | |
421 | /* ASN1_GENERALIZEDTIME_check() is a function */ | |
422 | ||
423 | #define ASN1_TIME_new() (ASN1_TIME *)\ | |
424 | ASN1_STRING_type_new(V_ASN1_UTCTIME) | |
425 | #define ASN1_TIME_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
426 | #define ASN1_TIME_dup(a) (ASN1_TIME *)ASN1_STRING_dup((ASN1_STRING *)a) | |
427 | ||
428 | /* i2d_ASN1_TIME() is a function */ | |
429 | /* d2i_ASN1_TIME() is a function */ | |
430 | /* ASN1_TIME_set() is a function */ | |
431 | /* ASN1_TIME_check() is a function */ | |
d02b48c6 RE |
432 | |
433 | #define ASN1_GENERALSTRING_new() (ASN1_GENERALSTRING *)\ | |
434 | ASN1_STRING_type_new(V_ASN1_GENERALSTRING) | |
435 | #define ASN1_GENERALSTRING_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
436 | #define M_i2d_ASN1_GENERALSTRING(a,pp) \ | |
437 | i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_GENERALSTRING,\ | |
438 | V_ASN1_UNIVERSAL) | |
439 | #define M_d2i_ASN1_GENERALSTRING(a,pp,l) \ | |
440 | (ASN1_GENERALSTRING *)d2i_ASN1_type_bytes\ | |
441 | ((ASN1_STRING **)a,pp,l,B_ASN1_GENERALSTRING) | |
442 | ||
443 | #define ASN1_UNIVERSALSTRING_new() (ASN1_UNIVERSALSTRING *)\ | |
444 | ASN1_STRING_type_new(V_ASN1_UNIVERSALSTRING) | |
445 | #define ASN1_UNIVERSALSTRING_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
446 | #define M_i2d_ASN1_UNIVERSALSTRING(a,pp) \ | |
447 | i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_UNIVERSALSTRING,\ | |
448 | V_ASN1_UNIVERSAL) | |
449 | #define M_d2i_ASN1_UNIVERSALSTRING(a,pp,l) \ | |
450 | (ASN1_UNIVERSALSTRING *)d2i_ASN1_type_bytes\ | |
451 | ((ASN1_STRING **)a,pp,l,B_ASN1_UNIVERSALSTRING) | |
452 | ||
58964a49 RE |
453 | #define ASN1_BMPSTRING_new() (ASN1_BMPSTRING *)\ |
454 | ASN1_STRING_type_new(V_ASN1_BMPSTRING) | |
455 | #define ASN1_BMPSTRING_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
456 | #define M_i2d_ASN1_BMPSTRING(a,pp) \ | |
457 | i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_BMPSTRING,\ | |
458 | V_ASN1_UNIVERSAL) | |
459 | #define M_d2i_ASN1_BMPSTRING(a,pp,l) \ | |
460 | (ASN1_BMPSTRING *)d2i_ASN1_type_bytes\ | |
461 | ((ASN1_STRING **)a,pp,l,B_ASN1_BMPSTRING) | |
462 | ||
d77b3054 DSH |
463 | #define ASN1_VISIBLESTRING_new() (ASN1_VISIBLESTRING *)\ |
464 | ASN1_STRING_type_new(V_ASN1_VISIBLESTRING) | |
465 | #define ASN1_VISIBLESTRING_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
466 | #define M_i2d_ASN1_VISIBLESTRING(a,pp) \ | |
467 | i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_VISIBLESTRING,\ | |
468 | V_ASN1_UNIVERSAL) | |
469 | #define M_d2i_ASN1_VISIBLESTRING(a,pp,l) \ | |
470 | (ASN1_VISIBLESTRING *)d2i_ASN1_type_bytes\ | |
471 | ((ASN1_STRING **)a,pp,l,B_ASN1_VISIBLESTRING) | |
472 | ||
473 | #define ASN1_UTF8STRING_new() (ASN1_UTF8STRING *)\ | |
474 | ASN1_STRING_type_new(V_ASN1_UTF8STRING) | |
475 | #define ASN1_UTF8STRING_free(a) ASN1_STRING_free((ASN1_STRING *)a) | |
476 | #define M_i2d_ASN1_UTF8STRING(a,pp) \ | |
477 | i2d_ASN1_bytes((ASN1_STRING *)a,pp,V_ASN1_UTF8STRING,\ | |
478 | V_ASN1_UNIVERSAL) | |
479 | #define M_d2i_ASN1_UTF8STRING(a,pp,l) \ | |
480 | (ASN1_UTF8STRING *)d2i_ASN1_type_bytes\ | |
481 | ((ASN1_STRING **)a,pp,l,B_ASN1_UTF8STRING) | |
482 | ||
1b276f30 RE |
483 | /* for the is_set parameter to i2d_ASN1_SET */ |
484 | #define IS_SEQUENCE 0 | |
485 | #define IS_SET 1 | |
486 | ||
d02b48c6 RE |
487 | ASN1_TYPE * ASN1_TYPE_new(void ); |
488 | void ASN1_TYPE_free(ASN1_TYPE *a); | |
489 | int i2d_ASN1_TYPE(ASN1_TYPE *a,unsigned char **pp); | |
490 | ASN1_TYPE * d2i_ASN1_TYPE(ASN1_TYPE **a,unsigned char **pp,long length); | |
491 | int ASN1_TYPE_get(ASN1_TYPE *a); | |
c8b41850 | 492 | void ASN1_TYPE_set(ASN1_TYPE *a, int type, void *value); |
d02b48c6 RE |
493 | |
494 | ASN1_OBJECT * ASN1_OBJECT_new(void ); | |
495 | void ASN1_OBJECT_free(ASN1_OBJECT *a); | |
496 | int i2d_ASN1_OBJECT(ASN1_OBJECT *a,unsigned char **pp); | |
497 | ASN1_OBJECT * d2i_ASN1_OBJECT(ASN1_OBJECT **a,unsigned char **pp, | |
498 | long length); | |
499 | ||
500 | ASN1_STRING * ASN1_STRING_new(void ); | |
501 | void ASN1_STRING_free(ASN1_STRING *a); | |
502 | ASN1_STRING * ASN1_STRING_dup(ASN1_STRING *a); | |
503 | ASN1_STRING * ASN1_STRING_type_new(int type ); | |
504 | int ASN1_STRING_cmp(ASN1_STRING *a, ASN1_STRING *b); | |
61f5b6f3 BL |
505 | /* Since this is used to store all sorts of things, via macros, for now, make |
506 | its data void * */ | |
507 | int ASN1_STRING_set(ASN1_STRING *str, const void *data, int len); | |
d02b48c6 RE |
508 | |
509 | int i2d_ASN1_BIT_STRING(ASN1_BIT_STRING *a,unsigned char **pp); | |
510 | ASN1_BIT_STRING *d2i_ASN1_BIT_STRING(ASN1_BIT_STRING **a,unsigned char **pp, | |
511 | long length); | |
58964a49 RE |
512 | int ASN1_BIT_STRING_set_bit(ASN1_BIT_STRING *a, int n, int value); |
513 | int ASN1_BIT_STRING_get_bit(ASN1_BIT_STRING *a, int n); | |
514 | ||
d02b48c6 RE |
515 | |
516 | int i2d_ASN1_BOOLEAN(int a,unsigned char **pp); | |
517 | int d2i_ASN1_BOOLEAN(int *a,unsigned char **pp,long length); | |
518 | ||
519 | int i2d_ASN1_INTEGER(ASN1_INTEGER *a,unsigned char **pp); | |
520 | ASN1_INTEGER *d2i_ASN1_INTEGER(ASN1_INTEGER **a,unsigned char **pp, | |
521 | long length); | |
1ad2ecb6 DSH |
522 | ASN1_INTEGER *d2i_ASN1_UINTEGER(ASN1_INTEGER **a,unsigned char **pp, |
523 | long length); | |
d02b48c6 | 524 | |
bceacf93 DSH |
525 | int i2d_ASN1_ENUMERATED(ASN1_ENUMERATED *a,unsigned char **pp); |
526 | ASN1_ENUMERATED *d2i_ASN1_ENUMERATED(ASN1_ENUMERATED **a,unsigned char **pp, | |
527 | long length); | |
528 | ||
d02b48c6 RE |
529 | int ASN1_UTCTIME_check(ASN1_UTCTIME *a); |
530 | ASN1_UTCTIME *ASN1_UTCTIME_set(ASN1_UTCTIME *s,time_t t); | |
58964a49 | 531 | int ASN1_UTCTIME_set_string(ASN1_UTCTIME *s, char *str); |
d02b48c6 | 532 | |
f6aed2cd DSH |
533 | int ASN1_GENERALIZEDTIME_check(ASN1_GENERALIZEDTIME *a); |
534 | ASN1_GENERALIZEDTIME *ASN1_GENERALIZEDTIME_set(ASN1_GENERALIZEDTIME *s,time_t t); | |
535 | int ASN1_GENERALIZEDTIME_set_string(ASN1_GENERALIZEDTIME *s, char *str); | |
536 | ||
d02b48c6 RE |
537 | int i2d_ASN1_OCTET_STRING(ASN1_OCTET_STRING *a,unsigned char **pp); |
538 | ASN1_OCTET_STRING *d2i_ASN1_OCTET_STRING(ASN1_OCTET_STRING **a, | |
539 | unsigned char **pp,long length); | |
540 | ||
d77b3054 DSH |
541 | int i2d_ASN1_VISIBLESTRING(ASN1_VISIBLESTRING *a,unsigned char **pp); |
542 | ASN1_VISIBLESTRING *d2i_ASN1_VISIBLESTRING(ASN1_VISIBLESTRING **a, | |
543 | unsigned char **pp,long length); | |
544 | ||
545 | int i2d_ASN1_UTF8STRING(ASN1_UTF8STRING *a,unsigned char **pp); | |
546 | ASN1_UTF8STRING *d2i_ASN1_UTF8STRING(ASN1_UTF8STRING **a, | |
547 | unsigned char **pp,long length); | |
548 | ||
dfeab068 RE |
549 | int i2d_ASN1_BMPSTRING(ASN1_BMPSTRING *a, unsigned char **pp); |
550 | ASN1_BMPSTRING *d2i_ASN1_BMPSTRING(ASN1_BMPSTRING **a, unsigned char **pp, | |
551 | long length); | |
552 | ||
d02b48c6 RE |
553 | int i2d_ASN1_PRINTABLE(ASN1_STRING *a,unsigned char **pp); |
554 | ASN1_STRING *d2i_ASN1_PRINTABLE(ASN1_STRING **a, | |
555 | unsigned char **pp, long l); | |
556 | ASN1_PRINTABLESTRING *d2i_ASN1_PRINTABLESTRING(ASN1_PRINTABLESTRING **a, | |
557 | unsigned char **pp, long l); | |
558 | ||
c83e523d DSH |
559 | int i2d_DIRECTORYSTRING(ASN1_STRING *a,unsigned char **pp); |
560 | ASN1_STRING *d2i_DIRECTORYSTRING(ASN1_STRING **a, unsigned char **pp, | |
561 | long length); | |
562 | ||
563 | int i2d_DISPLAYTEXT(ASN1_STRING *a,unsigned char **pp); | |
564 | ASN1_STRING *d2i_DISPLAYTEXT(ASN1_STRING **a, unsigned char **pp, long length); | |
565 | ||
d02b48c6 RE |
566 | ASN1_T61STRING *d2i_ASN1_T61STRING(ASN1_T61STRING **a, |
567 | unsigned char **pp, long l); | |
568 | int i2d_ASN1_IA5STRING(ASN1_IA5STRING *a,unsigned char **pp); | |
569 | ASN1_IA5STRING *d2i_ASN1_IA5STRING(ASN1_IA5STRING **a, | |
570 | unsigned char **pp, long l); | |
571 | ||
572 | int i2d_ASN1_UTCTIME(ASN1_UTCTIME *a,unsigned char **pp); | |
573 | ASN1_UTCTIME * d2i_ASN1_UTCTIME(ASN1_UTCTIME **a,unsigned char **pp, | |
574 | long length); | |
575 | ||
f6aed2cd DSH |
576 | int i2d_ASN1_GENERALIZEDTIME(ASN1_GENERALIZEDTIME *a,unsigned char **pp); |
577 | ASN1_GENERALIZEDTIME * d2i_ASN1_GENERALIZEDTIME(ASN1_GENERALIZEDTIME **a,unsigned char **pp, | |
578 | long length); | |
579 | ||
580 | int i2d_ASN1_TIME(ASN1_TIME *a,unsigned char **pp); | |
581 | ASN1_TIME * d2i_ASN1_TIME(ASN1_TIME **a,unsigned char **pp, long length); | |
08853ba8 BL |
582 | ASN1_TIME *ASN1_TIME_set(ASN1_TIME *s,time_t t); |
583 | ||
d02b48c6 | 584 | int i2d_ASN1_SET(STACK *a, unsigned char **pp, |
4098e89c | 585 | int (*func)(), int ex_tag, int ex_class, int is_set); |
d02b48c6 | 586 | STACK * d2i_ASN1_SET(STACK **a, unsigned char **pp, long length, |
dfeab068 RE |
587 | char *(*func)(), void (*free_func)(), |
588 | int ex_tag, int ex_class); | |
d02b48c6 RE |
589 | |
590 | #ifdef HEADER_BIO_H | |
591 | int i2a_ASN1_INTEGER(BIO *bp, ASN1_INTEGER *a); | |
592 | int a2i_ASN1_INTEGER(BIO *bp,ASN1_INTEGER *bs,char *buf,int size); | |
bceacf93 DSH |
593 | int i2a_ASN1_ENUMERATED(BIO *bp, ASN1_ENUMERATED *a); |
594 | int a2i_ASN1_ENUMERATED(BIO *bp,ASN1_ENUMERATED *bs,char *buf,int size); | |
d02b48c6 RE |
595 | int i2a_ASN1_OBJECT(BIO *bp,ASN1_OBJECT *a); |
596 | int a2i_ASN1_STRING(BIO *bp,ASN1_STRING *bs,char *buf,int size); | |
597 | int i2a_ASN1_STRING(BIO *bp, ASN1_STRING *a, int type); | |
598 | #endif | |
58964a49 | 599 | int i2t_ASN1_OBJECT(char *buf,int buf_len,ASN1_OBJECT *a); |
d02b48c6 | 600 | |
e778802f | 601 | int a2d_ASN1_OBJECT(unsigned char *out,int olen, const char *buf, int num); |
d02b48c6 RE |
602 | ASN1_OBJECT *ASN1_OBJECT_create(int nid, unsigned char *data,int len, |
603 | char *sn, char *ln); | |
604 | ||
605 | int ASN1_INTEGER_set(ASN1_INTEGER *a, long v); | |
606 | long ASN1_INTEGER_get(ASN1_INTEGER *a); | |
607 | ASN1_INTEGER *BN_to_ASN1_INTEGER(BIGNUM *bn, ASN1_INTEGER *ai); | |
608 | BIGNUM *ASN1_INTEGER_to_BN(ASN1_INTEGER *ai,BIGNUM *bn); | |
609 | ||
bceacf93 DSH |
610 | int ASN1_ENUMERATED_set(ASN1_ENUMERATED *a, long v); |
611 | long ASN1_ENUMERATED_get(ASN1_ENUMERATED *a); | |
612 | ASN1_ENUMERATED *BN_to_ASN1_ENUMERATED(BIGNUM *bn, ASN1_ENUMERATED *ai); | |
613 | BIGNUM *ASN1_ENUMERATED_to_BN(ASN1_ENUMERATED *ai,BIGNUM *bn); | |
614 | ||
d02b48c6 RE |
615 | /* General */ |
616 | /* given a string, return the correct type, max is the maximum length */ | |
617 | int ASN1_PRINTABLE_type(unsigned char *s, int max); | |
618 | ||
619 | int i2d_ASN1_bytes(ASN1_STRING *a, unsigned char **pp, int tag, int xclass); | |
620 | ASN1_STRING *d2i_ASN1_bytes(ASN1_STRING **a, unsigned char **pp, | |
621 | long length, int Ptag, int Pclass); | |
622 | /* type is one or more of the B_ASN1_ values. */ | |
623 | ASN1_STRING *d2i_ASN1_type_bytes(ASN1_STRING **a,unsigned char **pp, | |
624 | long length,int type); | |
625 | ||
626 | /* PARSING */ | |
627 | int asn1_Finish(ASN1_CTX *c); | |
628 | ||
629 | /* SPECIALS */ | |
630 | int ASN1_get_object(unsigned char **pp, long *plength, int *ptag, | |
631 | int *pclass, long omax); | |
632 | int ASN1_check_infinite_end(unsigned char **p,long len); | |
633 | void ASN1_put_object(unsigned char **pp, int constructed, int length, | |
634 | int tag, int xclass); | |
635 | int ASN1_object_size(int constructed, int length, int tag); | |
636 | ||
637 | /* Used to implement other functions */ | |
638 | char *ASN1_dup(int (*i2d)(),char *(*d2i)(),char *x); | |
639 | ||
58964a49 | 640 | #ifndef NO_FP_API |
d02b48c6 RE |
641 | char *ASN1_d2i_fp(char *(*xnew)(),char *(*d2i)(),FILE *fp,unsigned char **x); |
642 | int ASN1_i2d_fp(int (*i2d)(),FILE *out,unsigned char *x); | |
643 | #endif | |
644 | ||
645 | #ifdef HEADER_BIO_H | |
646 | char *ASN1_d2i_bio(char *(*xnew)(),char *(*d2i)(),BIO *bp,unsigned char **x); | |
647 | int ASN1_i2d_bio(int (*i2d)(),BIO *out,unsigned char *x); | |
648 | int ASN1_UTCTIME_print(BIO *fp,ASN1_UTCTIME *a); | |
f6aed2cd DSH |
649 | int ASN1_GENERALIZEDTIME_print(BIO *fp,ASN1_GENERALIZEDTIME *a); |
650 | int ASN1_TIME_print(BIO *fp,ASN1_TIME *a); | |
d02b48c6 RE |
651 | int ASN1_STRING_print(BIO *bp,ASN1_STRING *v); |
652 | int ASN1_parse(BIO *bp,unsigned char *pp,long len,int indent); | |
653 | #endif | |
654 | ||
655 | /* Used to load and write netscape format cert/key */ | |
656 | int i2d_ASN1_HEADER(ASN1_HEADER *a,unsigned char **pp); | |
657 | ASN1_HEADER *d2i_ASN1_HEADER(ASN1_HEADER **a,unsigned char **pp, long length); | |
658 | ASN1_HEADER *ASN1_HEADER_new(void ); | |
659 | void ASN1_HEADER_free(ASN1_HEADER *a); | |
660 | ||
661 | int ASN1_UNIVERSALSTRING_to_string(ASN1_UNIVERSALSTRING *s); | |
662 | ||
663 | void ERR_load_ASN1_strings(void); | |
664 | ||
665 | /* Not used that much at this point, except for the first two */ | |
666 | ASN1_METHOD *X509_asn1_meth(void); | |
667 | ASN1_METHOD *RSAPrivateKey_asn1_meth(void); | |
668 | ASN1_METHOD *ASN1_IA5STRING_asn1_meth(void); | |
669 | ASN1_METHOD *ASN1_BIT_STRING_asn1_meth(void); | |
670 | ||
58964a49 RE |
671 | int ASN1_TYPE_set_octetstring(ASN1_TYPE *a, |
672 | unsigned char *data, int len); | |
673 | int ASN1_TYPE_get_octetstring(ASN1_TYPE *a, | |
674 | unsigned char *data, int max_len); | |
675 | int ASN1_TYPE_set_int_octetstring(ASN1_TYPE *a, long num, | |
676 | unsigned char *data, int len); | |
677 | int ASN1_TYPE_get_int_octetstring(ASN1_TYPE *a,long *num, | |
678 | unsigned char *data, int max_len); | |
679 | ||
cfcefcbe DSH |
680 | STACK *ASN1_seq_unpack(unsigned char *buf, int len, char *(*d2i)(), |
681 | void (*free_func)() ); | |
682 | unsigned char *ASN1_seq_pack(STACK *safes, int (*i2d)(), unsigned char **buf, | |
683 | int *len ); | |
8e21c146 DSH |
684 | void *ASN1_unpack_string(ASN1_STRING *oct, char *(*d2i)()); |
685 | ASN1_STRING *ASN1_pack_string(void *obj, int (*i2d)(), ASN1_OCTET_STRING **oct); | |
cfcefcbe | 686 | |
d02b48c6 | 687 | /* BEGIN ERROR CODES */ |
6d311938 DSH |
688 | /* The following lines are auto generated by the script mkerr.pl. Any changes |
689 | * made after this point may be overwritten when the script is next run. | |
690 | */ | |
691 | ||
d02b48c6 RE |
692 | /* Error codes for the ASN1 functions. */ |
693 | ||
694 | /* Function codes. */ | |
695 | #define ASN1_F_A2D_ASN1_OBJECT 100 | |
df16c608 | 696 | #define ASN1_F_A2I_ASN1_ENUMERATED 236 |
d02b48c6 RE |
697 | #define ASN1_F_A2I_ASN1_INTEGER 101 |
698 | #define ASN1_F_A2I_ASN1_STRING 102 | |
5d818c30 | 699 | #define ASN1_F_ASN1_COLLATE_PRIMITIVE 103 |
d02b48c6 RE |
700 | #define ASN1_F_ASN1_D2I_BIO 104 |
701 | #define ASN1_F_ASN1_D2I_FP 105 | |
702 | #define ASN1_F_ASN1_DUP 106 | |
bceacf93 DSH |
703 | #define ASN1_F_ASN1_ENUMERATED_SET 232 |
704 | #define ASN1_F_ASN1_ENUMERATED_TO_BN 233 | |
fdc71ecc | 705 | #define ASN1_F_ASN1_GENERALIZEDTIME_NEW 222 |
d02b48c6 RE |
706 | #define ASN1_F_ASN1_GET_OBJECT 107 |
707 | #define ASN1_F_ASN1_HEADER_NEW 108 | |
708 | #define ASN1_F_ASN1_I2D_BIO 109 | |
709 | #define ASN1_F_ASN1_I2D_FP 110 | |
710 | #define ASN1_F_ASN1_INTEGER_SET 111 | |
711 | #define ASN1_F_ASN1_INTEGER_TO_BN 112 | |
712 | #define ASN1_F_ASN1_OBJECT_NEW 113 | |
cfcefcbe | 713 | #define ASN1_F_ASN1_PACK_STRING 245 |
67d5ac03 | 714 | #define ASN1_F_ASN1_PBE_SET 253 |
cfcefcbe DSH |
715 | #define ASN1_F_ASN1_SEQ_PACK 246 |
716 | #define ASN1_F_ASN1_SEQ_UNPACK 247 | |
d02b48c6 RE |
717 | #define ASN1_F_ASN1_SIGN 114 |
718 | #define ASN1_F_ASN1_STRING_NEW 115 | |
719 | #define ASN1_F_ASN1_STRING_TYPE_NEW 116 | |
58964a49 RE |
720 | #define ASN1_F_ASN1_TYPE_GET_INT_OCTETSTRING 117 |
721 | #define ASN1_F_ASN1_TYPE_GET_OCTETSTRING 118 | |
722 | #define ASN1_F_ASN1_TYPE_NEW 119 | |
cfcefcbe | 723 | #define ASN1_F_ASN1_UNPACK_STRING 248 |
58964a49 RE |
724 | #define ASN1_F_ASN1_UTCTIME_NEW 120 |
725 | #define ASN1_F_ASN1_VERIFY 121 | |
df16c608 | 726 | #define ASN1_F_AUTHORITY_KEYID_NEW 237 |
834eeef9 | 727 | #define ASN1_F_BASIC_CONSTRAINTS_NEW 226 |
bceacf93 | 728 | #define ASN1_F_BN_TO_ASN1_ENUMERATED 234 |
58964a49 RE |
729 | #define ASN1_F_BN_TO_ASN1_INTEGER 122 |
730 | #define ASN1_F_D2I_ASN1_BIT_STRING 123 | |
731 | #define ASN1_F_D2I_ASN1_BMPSTRING 124 | |
732 | #define ASN1_F_D2I_ASN1_BOOLEAN 125 | |
733 | #define ASN1_F_D2I_ASN1_BYTES 126 | |
bceacf93 | 734 | #define ASN1_F_D2I_ASN1_ENUMERATED 235 |
fdc71ecc | 735 | #define ASN1_F_D2I_ASN1_GENERALIZEDTIME 223 |
58964a49 RE |
736 | #define ASN1_F_D2I_ASN1_HEADER 127 |
737 | #define ASN1_F_D2I_ASN1_INTEGER 128 | |
738 | #define ASN1_F_D2I_ASN1_OBJECT 129 | |
739 | #define ASN1_F_D2I_ASN1_OCTET_STRING 130 | |
740 | #define ASN1_F_D2I_ASN1_PRINT_TYPE 131 | |
741 | #define ASN1_F_D2I_ASN1_SET 132 | |
fdc71ecc | 742 | #define ASN1_F_D2I_ASN1_TIME 224 |
58964a49 RE |
743 | #define ASN1_F_D2I_ASN1_TYPE 133 |
744 | #define ASN1_F_D2I_ASN1_TYPE_BYTES 134 | |
1ad2ecb6 | 745 | #define ASN1_F_D2I_ASN1_UINTEGER 280 |
58964a49 | 746 | #define ASN1_F_D2I_ASN1_UTCTIME 135 |
d77b3054 DSH |
747 | #define ASN1_F_D2I_ASN1_UTF8STRING 266 |
748 | #define ASN1_F_D2I_ASN1_VISIBLESTRING 267 | |
df16c608 | 749 | #define ASN1_F_D2I_AUTHORITY_KEYID 238 |
834eeef9 | 750 | #define ASN1_F_D2I_BASIC_CONSTRAINTS 227 |
58964a49 | 751 | #define ASN1_F_D2I_DHPARAMS 136 |
d943e372 DSH |
752 | #define ASN1_F_D2I_DIST_POINT 276 |
753 | #define ASN1_F_D2I_DIST_POINT_NAME 277 | |
58964a49 RE |
754 | #define ASN1_F_D2I_DSAPARAMS 137 |
755 | #define ASN1_F_D2I_DSAPRIVATEKEY 138 | |
756 | #define ASN1_F_D2I_DSAPUBLICKEY 139 | |
142fcca8 | 757 | #define ASN1_F_D2I_GENERAL_NAME 230 |
92c046ca | 758 | #define ASN1_F_D2I_NETSCAPE_CERT_SEQUENCE 228 |
58964a49 RE |
759 | #define ASN1_F_D2I_NETSCAPE_PKEY 140 |
760 | #define ASN1_F_D2I_NETSCAPE_RSA 141 | |
761 | #define ASN1_F_D2I_NETSCAPE_RSA_2 142 | |
762 | #define ASN1_F_D2I_NETSCAPE_SPKAC 143 | |
763 | #define ASN1_F_D2I_NETSCAPE_SPKI 144 | |
41b731f2 | 764 | #define ASN1_F_D2I_NOTICEREF 268 |
d2e26dcc | 765 | #define ASN1_F_D2I_PBE2PARAM 262 |
cfcefcbe | 766 | #define ASN1_F_D2I_PBEPARAM 249 |
d2e26dcc | 767 | #define ASN1_F_D2I_PBKDF2PARAM 263 |
67d5ac03 DSH |
768 | #define ASN1_F_D2I_PKCS12 254 |
769 | #define ASN1_F_D2I_PKCS12_BAGS 255 | |
770 | #define ASN1_F_D2I_PKCS12_MAC_DATA 256 | |
771 | #define ASN1_F_D2I_PKCS12_SAFEBAG 257 | |
58964a49 RE |
772 | #define ASN1_F_D2I_PKCS7 145 |
773 | #define ASN1_F_D2I_PKCS7_DIGEST 146 | |
774 | #define ASN1_F_D2I_PKCS7_ENCRYPT 147 | |
775 | #define ASN1_F_D2I_PKCS7_ENC_CONTENT 148 | |
776 | #define ASN1_F_D2I_PKCS7_ENVELOPE 149 | |
777 | #define ASN1_F_D2I_PKCS7_ISSUER_AND_SERIAL 150 | |
778 | #define ASN1_F_D2I_PKCS7_RECIP_INFO 151 | |
779 | #define ASN1_F_D2I_PKCS7_SIGNED 152 | |
780 | #define ASN1_F_D2I_PKCS7_SIGNER_INFO 153 | |
781 | #define ASN1_F_D2I_PKCS7_SIGN_ENVELOPE 154 | |
cfcefcbe | 782 | #define ASN1_F_D2I_PKCS8_PRIV_KEY_INFO 250 |
0be9747b | 783 | #define ASN1_F_D2I_PKEY_USAGE_PERIOD 239 |
41b731f2 DSH |
784 | #define ASN1_F_D2I_POLICYINFO 269 |
785 | #define ASN1_F_D2I_POLICYQUALINFO 270 | |
58964a49 RE |
786 | #define ASN1_F_D2I_PRIVATEKEY 155 |
787 | #define ASN1_F_D2I_PUBLICKEY 156 | |
788 | #define ASN1_F_D2I_RSAPRIVATEKEY 157 | |
789 | #define ASN1_F_D2I_RSAPUBLICKEY 158 | |
785cdf20 DSH |
790 | #define ASN1_F_D2I_SXNET 241 |
791 | #define ASN1_F_D2I_SXNETID 243 | |
41b731f2 | 792 | #define ASN1_F_D2I_USERNOTICE 271 |
58964a49 RE |
793 | #define ASN1_F_D2I_X509 159 |
794 | #define ASN1_F_D2I_X509_ALGOR 160 | |
795 | #define ASN1_F_D2I_X509_ATTRIBUTE 161 | |
796 | #define ASN1_F_D2I_X509_CINF 162 | |
797 | #define ASN1_F_D2I_X509_CRL 163 | |
798 | #define ASN1_F_D2I_X509_CRL_INFO 164 | |
799 | #define ASN1_F_D2I_X509_EXTENSION 165 | |
800 | #define ASN1_F_D2I_X509_KEY 166 | |
801 | #define ASN1_F_D2I_X509_NAME 167 | |
802 | #define ASN1_F_D2I_X509_NAME_ENTRY 168 | |
803 | #define ASN1_F_D2I_X509_PKEY 169 | |
804 | #define ASN1_F_D2I_X509_PUBKEY 170 | |
805 | #define ASN1_F_D2I_X509_REQ 171 | |
806 | #define ASN1_F_D2I_X509_REQ_INFO 172 | |
807 | #define ASN1_F_D2I_X509_REVOKED 173 | |
808 | #define ASN1_F_D2I_X509_SIG 174 | |
809 | #define ASN1_F_D2I_X509_VAL 175 | |
d943e372 DSH |
810 | #define ASN1_F_DIST_POINT_NAME_NEW 278 |
811 | #define ASN1_F_DIST_POINT_NEW 279 | |
142fcca8 | 812 | #define ASN1_F_GENERAL_NAME_NEW 231 |
58964a49 | 813 | #define ASN1_F_I2D_ASN1_HEADER 176 |
fdc71ecc | 814 | #define ASN1_F_I2D_ASN1_TIME 225 |
58964a49 RE |
815 | #define ASN1_F_I2D_DHPARAMS 177 |
816 | #define ASN1_F_I2D_DSAPARAMS 178 | |
817 | #define ASN1_F_I2D_DSAPRIVATEKEY 179 | |
818 | #define ASN1_F_I2D_DSAPUBLICKEY 180 | |
819 | #define ASN1_F_I2D_NETSCAPE_RSA 181 | |
820 | #define ASN1_F_I2D_PKCS7 182 | |
821 | #define ASN1_F_I2D_PRIVATEKEY 183 | |
822 | #define ASN1_F_I2D_PUBLICKEY 184 | |
823 | #define ASN1_F_I2D_RSAPRIVATEKEY 185 | |
824 | #define ASN1_F_I2D_RSAPUBLICKEY 186 | |
825 | #define ASN1_F_I2D_X509_ATTRIBUTE 187 | |
826 | #define ASN1_F_I2T_ASN1_OBJECT 188 | |
92c046ca | 827 | #define ASN1_F_NETSCAPE_CERT_SEQUENCE_NEW 229 |
58964a49 RE |
828 | #define ASN1_F_NETSCAPE_PKEY_NEW 189 |
829 | #define ASN1_F_NETSCAPE_SPKAC_NEW 190 | |
830 | #define ASN1_F_NETSCAPE_SPKI_NEW 191 | |
41b731f2 | 831 | #define ASN1_F_NOTICEREF_NEW 272 |
d2e26dcc | 832 | #define ASN1_F_PBE2PARAM_NEW 264 |
cfcefcbe | 833 | #define ASN1_F_PBEPARAM_NEW 251 |
d2e26dcc | 834 | #define ASN1_F_PBKDF2PARAM_NEW 265 |
67d5ac03 DSH |
835 | #define ASN1_F_PKCS12_BAGS_NEW 258 |
836 | #define ASN1_F_PKCS12_MAC_DATA_NEW 259 | |
837 | #define ASN1_F_PKCS12_NEW 260 | |
838 | #define ASN1_F_PKCS12_SAFEBAG_NEW 261 | |
8e21c146 | 839 | #define ASN1_F_PKCS5_PBE2_SET 281 |
58964a49 RE |
840 | #define ASN1_F_PKCS7_DIGEST_NEW 192 |
841 | #define ASN1_F_PKCS7_ENCRYPT_NEW 193 | |
842 | #define ASN1_F_PKCS7_ENC_CONTENT_NEW 194 | |
843 | #define ASN1_F_PKCS7_ENVELOPE_NEW 195 | |
844 | #define ASN1_F_PKCS7_ISSUER_AND_SERIAL_NEW 196 | |
845 | #define ASN1_F_PKCS7_NEW 197 | |
846 | #define ASN1_F_PKCS7_RECIP_INFO_NEW 198 | |
847 | #define ASN1_F_PKCS7_SIGNED_NEW 199 | |
848 | #define ASN1_F_PKCS7_SIGNER_INFO_NEW 200 | |
849 | #define ASN1_F_PKCS7_SIGN_ENVELOPE_NEW 201 | |
cfcefcbe | 850 | #define ASN1_F_PKCS8_PRIV_KEY_INFO_NEW 252 |
0be9747b | 851 | #define ASN1_F_PKEY_USAGE_PERIOD_NEW 240 |
41b731f2 DSH |
852 | #define ASN1_F_POLICYINFO_NEW 273 |
853 | #define ASN1_F_POLICYQUALINFO_NEW 274 | |
785cdf20 DSH |
854 | #define ASN1_F_SXNETID_NEW 244 |
855 | #define ASN1_F_SXNET_NEW 242 | |
41b731f2 | 856 | #define ASN1_F_USERNOTICE_NEW 275 |
58964a49 RE |
857 | #define ASN1_F_X509_ALGOR_NEW 202 |
858 | #define ASN1_F_X509_ATTRIBUTE_NEW 203 | |
859 | #define ASN1_F_X509_CINF_NEW 204 | |
860 | #define ASN1_F_X509_CRL_INFO_NEW 205 | |
861 | #define ASN1_F_X509_CRL_NEW 206 | |
862 | #define ASN1_F_X509_DHPARAMS_NEW 207 | |
863 | #define ASN1_F_X509_EXTENSION_NEW 208 | |
864 | #define ASN1_F_X509_INFO_NEW 209 | |
865 | #define ASN1_F_X509_KEY_NEW 210 | |
866 | #define ASN1_F_X509_NAME_ENTRY_NEW 211 | |
867 | #define ASN1_F_X509_NAME_NEW 212 | |
868 | #define ASN1_F_X509_NEW 213 | |
869 | #define ASN1_F_X509_PKEY_NEW 214 | |
870 | #define ASN1_F_X509_PUBKEY_NEW 215 | |
871 | #define ASN1_F_X509_REQ_INFO_NEW 216 | |
872 | #define ASN1_F_X509_REQ_NEW 217 | |
873 | #define ASN1_F_X509_REVOKED_NEW 218 | |
874 | #define ASN1_F_X509_SIG_NEW 219 | |
875 | #define ASN1_F_X509_VAL_FREE 220 | |
876 | #define ASN1_F_X509_VAL_NEW 221 | |
d02b48c6 RE |
877 | |
878 | /* Reason codes. */ | |
879 | #define ASN1_R_BAD_CLASS 100 | |
dfeab068 RE |
880 | #define ASN1_R_BAD_OBJECT_HEADER 101 |
881 | #define ASN1_R_BAD_PASSWORD_READ 102 | |
882 | #define ASN1_R_BAD_PKCS7_CONTENT 103 | |
883 | #define ASN1_R_BAD_PKCS7_TYPE 104 | |
884 | #define ASN1_R_BAD_TAG 105 | |
885 | #define ASN1_R_BAD_TYPE 106 | |
886 | #define ASN1_R_BN_LIB 107 | |
887 | #define ASN1_R_BOOLEAN_IS_WRONG_LENGTH 108 | |
888 | #define ASN1_R_BUFFER_TOO_SMALL 109 | |
889 | #define ASN1_R_DATA_IS_WRONG 110 | |
cfcefcbe | 890 | #define ASN1_R_DECODE_ERROR 155 |
dfeab068 | 891 | #define ASN1_R_DECODING_ERROR 111 |
cfcefcbe | 892 | #define ASN1_R_ENCODE_ERROR 156 |
dfeab068 | 893 | #define ASN1_R_ERROR_PARSING_SET_ELEMENT 112 |
8e21c146 | 894 | #define ASN1_R_ERROR_SETTING_CIPHER_PARAMS 157 |
bceacf93 | 895 | #define ASN1_R_EXPECTING_AN_ENUMERATED 154 |
dfeab068 RE |
896 | #define ASN1_R_EXPECTING_AN_INTEGER 113 |
897 | #define ASN1_R_EXPECTING_AN_OBJECT 114 | |
898 | #define ASN1_R_EXPECTING_AN_OCTET_STRING 115 | |
899 | #define ASN1_R_EXPECTING_A_BIT_STRING 116 | |
900 | #define ASN1_R_EXPECTING_A_BOOLEAN 117 | |
fdc71ecc DSH |
901 | #define ASN1_R_EXPECTING_A_GENERALIZEDTIME 151 |
902 | #define ASN1_R_EXPECTING_A_TIME 152 | |
dfeab068 RE |
903 | #define ASN1_R_EXPECTING_A_UTCTIME 118 |
904 | #define ASN1_R_FIRST_NUM_TOO_LARGE 119 | |
fdc71ecc | 905 | #define ASN1_R_GENERALIZEDTIME_TOO_LONG 153 |
dfeab068 RE |
906 | #define ASN1_R_HEADER_TOO_LONG 120 |
907 | #define ASN1_R_INVALID_DIGIT 121 | |
908 | #define ASN1_R_INVALID_SEPARATOR 122 | |
909 | #define ASN1_R_INVALID_TIME_FORMAT 123 | |
910 | #define ASN1_R_IV_TOO_LARGE 124 | |
911 | #define ASN1_R_LENGTH_ERROR 125 | |
912 | #define ASN1_R_MISSING_SECOND_NUMBER 126 | |
913 | #define ASN1_R_NON_HEX_CHARACTERS 127 | |
914 | #define ASN1_R_NOT_ENOUGH_DATA 128 | |
915 | #define ASN1_R_ODD_NUMBER_OF_CHARS 129 | |
916 | #define ASN1_R_PARSING 130 | |
917 | #define ASN1_R_PRIVATE_KEY_HEADER_MISSING 131 | |
918 | #define ASN1_R_SECOND_NUMBER_TOO_LARGE 132 | |
919 | #define ASN1_R_SHORT_LINE 133 | |
920 | #define ASN1_R_STRING_TOO_SHORT 134 | |
921 | #define ASN1_R_TAG_VALUE_TOO_HIGH 135 | |
922 | #define ASN1_R_THE_ASN1_OBJECT_IDENTIFIER_IS_NOT_KNOWN_FOR_THIS_MD 136 | |
923 | #define ASN1_R_TOO_LONG 137 | |
924 | #define ASN1_R_UNABLE_TO_DECODE_RSA_KEY 138 | |
925 | #define ASN1_R_UNABLE_TO_DECODE_RSA_PRIVATE_KEY 139 | |
926 | #define ASN1_R_UNKNOWN_ATTRIBUTE_TYPE 140 | |
927 | #define ASN1_R_UNKNOWN_MESSAGE_DIGEST_ALGORITHM 141 | |
928 | #define ASN1_R_UNKNOWN_OBJECT_TYPE 142 | |
929 | #define ASN1_R_UNKNOWN_PUBLIC_KEY_TYPE 143 | |
930 | #define ASN1_R_UNSUPPORTED_CIPHER 144 | |
931 | #define ASN1_R_UNSUPPORTED_ENCRYPTION_ALGORITHM 145 | |
932 | #define ASN1_R_UNSUPPORTED_PUBLIC_KEY_TYPE 146 | |
933 | #define ASN1_R_UTCTIME_TOO_LONG 147 | |
934 | #define ASN1_R_WRONG_PRINTABLE_TYPE 148 | |
935 | #define ASN1_R_WRONG_TAG 149 | |
936 | #define ASN1_R_WRONG_TYPE 150 | |
6d311938 | 937 | |
d02b48c6 RE |
938 | #ifdef __cplusplus |
939 | } | |
940 | #endif | |
941 | #endif | |
942 |