summaryrefslogtreecommitdiff
path: root/src/lib/libcrypto/krb5
diff options
context:
space:
mode:
Diffstat (limited to 'src/lib/libcrypto/krb5')
-rw-r--r--src/lib/libcrypto/krb5/krb5_asn.c431
-rw-r--r--src/lib/libcrypto/krb5/krb5_asn.h256
2 files changed, 0 insertions, 687 deletions
diff --git a/src/lib/libcrypto/krb5/krb5_asn.c b/src/lib/libcrypto/krb5/krb5_asn.c
deleted file mode 100644
index 1a95e62935..0000000000
--- a/src/lib/libcrypto/krb5/krb5_asn.c
+++ /dev/null
@@ -1,431 +0,0 @@
1/* $OpenBSD: krb5_asn.c,v 1.3 2015/02/09 16:04:46 jsing Exp $ */
2/* Written by Vern Staats <staatsvr@asc.hpc.mil> for the OpenSSL project,
3** using ocsp/{*.h,*asn*.c} as a starting point
4*/
5/* ====================================================================
6 * Copyright (c) 2000 The OpenSSL Project. All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
10 * are met:
11 *
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 *
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in
17 * the documentation and/or other materials provided with the
18 * distribution.
19 *
20 * 3. All advertising materials mentioning features or use of this
21 * software must display the following acknowledgment:
22 * "This product includes software developed by the OpenSSL Project
23 * for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"
24 *
25 * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
26 * endorse or promote products derived from this software without
27 * prior written permission. For written permission, please contact
28 * licensing@OpenSSL.org.
29 *
30 * 5. Products derived from this software may not be called "OpenSSL"
31 * nor may "OpenSSL" appear in their names without prior written
32 * permission of the OpenSSL Project.
33 *
34 * 6. Redistributions of any form whatsoever must retain the following
35 * acknowledgment:
36 * "This product includes software developed by the OpenSSL Project
37 * for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"
38 *
39 * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
40 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
41 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
42 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
43 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
44 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
45 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
46 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
47 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
48 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
49 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
50 * OF THE POSSIBILITY OF SUCH DAMAGE.
51 * ====================================================================
52 *
53 * This product includes cryptographic software written by Eric Young
54 * (eay@cryptsoft.com). This product includes software written by Tim
55 * Hudson (tjh@cryptsoft.com).
56 *
57 */
58#include <openssl/asn1.h>
59#include <openssl/asn1t.h>
60#include <openssl/krb5_asn.h>
61
62
63ASN1_SEQUENCE(KRB5_ENCDATA) = {
64 ASN1_EXP(KRB5_ENCDATA, etype, ASN1_INTEGER, 0),
65 ASN1_EXP_OPT(KRB5_ENCDATA, kvno, ASN1_INTEGER, 1),
66 ASN1_EXP(KRB5_ENCDATA, cipher, ASN1_OCTET_STRING,2)
67} ASN1_SEQUENCE_END(KRB5_ENCDATA)
68
69
70KRB5_ENCDATA *
71d2i_KRB5_ENCDATA(KRB5_ENCDATA **a, const unsigned char **in, long len)
72{
73 return (KRB5_ENCDATA *)ASN1_item_d2i((ASN1_VALUE **)a, in, len,
74 &KRB5_ENCDATA_it);
75}
76
77int
78i2d_KRB5_ENCDATA(KRB5_ENCDATA *a, unsigned char **out)
79{
80 return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_ENCDATA_it);
81}
82
83KRB5_ENCDATA *
84KRB5_ENCDATA_new(void)
85{
86 return (KRB5_ENCDATA *)ASN1_item_new(&KRB5_ENCDATA_it);
87}
88
89void
90KRB5_ENCDATA_free(KRB5_ENCDATA *a)
91{
92 ASN1_item_free((ASN1_VALUE *)a, &KRB5_ENCDATA_it);
93}
94
95
96ASN1_SEQUENCE(KRB5_PRINCNAME) = {
97 ASN1_EXP(KRB5_PRINCNAME, nametype, ASN1_INTEGER, 0),
98 ASN1_EXP_SEQUENCE_OF(KRB5_PRINCNAME, namestring, ASN1_GENERALSTRING, 1)
99} ASN1_SEQUENCE_END(KRB5_PRINCNAME)
100
101
102KRB5_PRINCNAME *
103d2i_KRB5_PRINCNAME(KRB5_PRINCNAME **a, const unsigned char **in, long len)
104{
105 return (KRB5_PRINCNAME *)ASN1_item_d2i((ASN1_VALUE **)a, in, len,
106 &KRB5_PRINCNAME_it);
107}
108
109int
110i2d_KRB5_PRINCNAME(KRB5_PRINCNAME *a, unsigned char **out)
111{
112 return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_PRINCNAME_it);
113}
114
115KRB5_PRINCNAME *
116KRB5_PRINCNAME_new(void)
117{
118 return (KRB5_PRINCNAME *)ASN1_item_new(&KRB5_PRINCNAME_it);
119}
120
121void
122KRB5_PRINCNAME_free(KRB5_PRINCNAME *a)
123{
124 ASN1_item_free((ASN1_VALUE *)a, &KRB5_PRINCNAME_it);
125}
126
127
128/* [APPLICATION 1] = 0x61 */
129ASN1_SEQUENCE(KRB5_TKTBODY) = {
130 ASN1_EXP(KRB5_TKTBODY, tktvno, ASN1_INTEGER, 0),
131 ASN1_EXP(KRB5_TKTBODY, realm, ASN1_GENERALSTRING, 1),
132 ASN1_EXP(KRB5_TKTBODY, sname, KRB5_PRINCNAME, 2),
133 ASN1_EXP(KRB5_TKTBODY, encdata, KRB5_ENCDATA, 3)
134} ASN1_SEQUENCE_END(KRB5_TKTBODY)
135
136
137KRB5_TKTBODY *
138d2i_KRB5_TKTBODY(KRB5_TKTBODY **a, const unsigned char **in, long len)
139{
140 return (KRB5_TKTBODY *)ASN1_item_d2i((ASN1_VALUE **)a, in, len,
141 &KRB5_TKTBODY_it);
142}
143
144int
145i2d_KRB5_TKTBODY(KRB5_TKTBODY *a, unsigned char **out)
146{
147 return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_TKTBODY_it);
148}
149
150KRB5_TKTBODY *
151KRB5_TKTBODY_new(void)
152{
153 return (KRB5_TKTBODY *)ASN1_item_new(&KRB5_TKTBODY_it);
154}
155
156void
157KRB5_TKTBODY_free(KRB5_TKTBODY *a)
158{
159 ASN1_item_free((ASN1_VALUE *)a, &KRB5_TKTBODY_it);
160}
161
162
163ASN1_ITEM_TEMPLATE(KRB5_TICKET) =
164 ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_EXPTAG|ASN1_TFLG_APPLICATION, 1,
165 KRB5_TICKET, KRB5_TKTBODY)
166ASN1_ITEM_TEMPLATE_END(KRB5_TICKET)
167
168
169KRB5_TICKET *
170d2i_KRB5_TICKET(KRB5_TICKET **a, const unsigned char **in, long len)
171{
172 return (KRB5_TICKET *)ASN1_item_d2i((ASN1_VALUE **)a, in, len,
173 &KRB5_TICKET_it);
174}
175
176int
177i2d_KRB5_TICKET(KRB5_TICKET *a, unsigned char **out)
178{
179 return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_TICKET_it);
180}
181
182KRB5_TICKET *
183KRB5_TICKET_new(void)
184{
185 return (KRB5_TICKET *)ASN1_item_new(&KRB5_TICKET_it);
186}
187
188void
189KRB5_TICKET_free(KRB5_TICKET *a)
190{
191 ASN1_item_free((ASN1_VALUE *)a, &KRB5_TICKET_it);
192}
193
194
195/* [APPLICATION 14] = 0x6e */
196ASN1_SEQUENCE(KRB5_APREQBODY) = {
197 ASN1_EXP(KRB5_APREQBODY, pvno, ASN1_INTEGER, 0),
198 ASN1_EXP(KRB5_APREQBODY, msgtype, ASN1_INTEGER, 1),
199 ASN1_EXP(KRB5_APREQBODY, apoptions, ASN1_BIT_STRING, 2),
200 ASN1_EXP(KRB5_APREQBODY, ticket, KRB5_TICKET, 3),
201 ASN1_EXP(KRB5_APREQBODY, authenticator, KRB5_ENCDATA, 4),
202} ASN1_SEQUENCE_END(KRB5_APREQBODY)
203
204
205KRB5_APREQBODY *
206d2i_KRB5_APREQBODY(KRB5_APREQBODY **a, const unsigned char **in, long len)
207{
208 return (KRB5_APREQBODY *)ASN1_item_d2i((ASN1_VALUE **)a, in, len,
209 &KRB5_APREQBODY_it);
210}
211
212int
213i2d_KRB5_APREQBODY(KRB5_APREQBODY *a, unsigned char **out)
214{
215 return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_APREQBODY_it);
216}
217
218KRB5_APREQBODY *
219KRB5_APREQBODY_new(void)
220{
221 return (KRB5_APREQBODY *)ASN1_item_new(&KRB5_APREQBODY_it);
222}
223
224void
225KRB5_APREQBODY_free(KRB5_APREQBODY *a)
226{
227 ASN1_item_free((ASN1_VALUE *)a, &KRB5_APREQBODY_it);
228}
229
230ASN1_ITEM_TEMPLATE(KRB5_APREQ) =
231 ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_EXPTAG|ASN1_TFLG_APPLICATION, 14,
232 KRB5_APREQ, KRB5_APREQBODY)
233ASN1_ITEM_TEMPLATE_END(KRB5_APREQ)
234
235
236KRB5_APREQ *
237d2i_KRB5_APREQ(KRB5_APREQ **a, const unsigned char **in, long len)
238{
239 return (KRB5_APREQ *)ASN1_item_d2i((ASN1_VALUE **)a, in, len,
240 &KRB5_APREQ_it);
241}
242
243int
244i2d_KRB5_APREQ(KRB5_APREQ *a, unsigned char **out)
245{
246 return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_APREQ_it);
247}
248
249KRB5_APREQ *
250KRB5_APREQ_new(void)
251{
252 return (KRB5_APREQ *)ASN1_item_new(&KRB5_APREQ_it);
253}
254
255void
256KRB5_APREQ_free(KRB5_APREQ *a)
257{
258 ASN1_item_free((ASN1_VALUE *)a, &KRB5_APREQ_it);
259}
260
261
262/* Authenticator stuff */
263
264ASN1_SEQUENCE(KRB5_CHECKSUM) = {
265 ASN1_EXP(KRB5_CHECKSUM, ctype, ASN1_INTEGER, 0),
266 ASN1_EXP(KRB5_CHECKSUM, checksum, ASN1_OCTET_STRING,1)
267} ASN1_SEQUENCE_END(KRB5_CHECKSUM)
268
269
270KRB5_CHECKSUM *
271d2i_KRB5_CHECKSUM(KRB5_CHECKSUM **a, const unsigned char **in, long len)
272{
273 return (KRB5_CHECKSUM *)ASN1_item_d2i((ASN1_VALUE **)a, in, len,
274 &KRB5_CHECKSUM_it);
275}
276
277int
278i2d_KRB5_CHECKSUM(KRB5_CHECKSUM *a, unsigned char **out)
279{
280 return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_CHECKSUM_it);
281}
282
283KRB5_CHECKSUM *
284KRB5_CHECKSUM_new(void)
285{
286 return (KRB5_CHECKSUM *)ASN1_item_new(&KRB5_CHECKSUM_it);
287}
288
289void
290KRB5_CHECKSUM_free(KRB5_CHECKSUM *a)
291{
292 ASN1_item_free((ASN1_VALUE *)a, &KRB5_CHECKSUM_it);
293}
294
295
296ASN1_SEQUENCE(KRB5_ENCKEY) = {
297 ASN1_EXP(KRB5_ENCKEY, ktype, ASN1_INTEGER, 0),
298 ASN1_EXP(KRB5_ENCKEY, keyvalue, ASN1_OCTET_STRING,1)
299} ASN1_SEQUENCE_END(KRB5_ENCKEY)
300
301
302KRB5_ENCKEY *
303d2i_KRB5_ENCKEY(KRB5_ENCKEY **a, const unsigned char **in, long len)
304{
305 return (KRB5_ENCKEY *)ASN1_item_d2i((ASN1_VALUE **)a, in, len,
306 &KRB5_ENCKEY_it);
307}
308
309int
310i2d_KRB5_ENCKEY(KRB5_ENCKEY *a, unsigned char **out)
311{
312 return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_ENCKEY_it);
313}
314
315KRB5_ENCKEY *
316KRB5_ENCKEY_new(void)
317{
318 return (KRB5_ENCKEY *)ASN1_item_new(&KRB5_ENCKEY_it);
319}
320
321void
322KRB5_ENCKEY_free(KRB5_ENCKEY *a)
323{
324 ASN1_item_free((ASN1_VALUE *)a, &KRB5_ENCKEY_it);
325}
326
327
328/* SEQ OF SEQ; see ASN1_EXP_SEQUENCE_OF_OPT() below */
329ASN1_SEQUENCE(KRB5_AUTHDATA) = {
330 ASN1_EXP(KRB5_AUTHDATA, adtype, ASN1_INTEGER, 0),
331 ASN1_EXP(KRB5_AUTHDATA, addata, ASN1_OCTET_STRING,1)
332} ASN1_SEQUENCE_END(KRB5_AUTHDATA)
333
334
335KRB5_AUTHDATA *
336d2i_KRB5_AUTHDATA(KRB5_AUTHDATA **a, const unsigned char **in, long len)
337{
338 return (KRB5_AUTHDATA *)ASN1_item_d2i((ASN1_VALUE **)a, in, len,
339 &KRB5_AUTHDATA_it);
340}
341
342int
343i2d_KRB5_AUTHDATA(KRB5_AUTHDATA *a, unsigned char **out)
344{
345 return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_AUTHDATA_it);
346}
347
348KRB5_AUTHDATA *
349KRB5_AUTHDATA_new(void)
350{
351 return (KRB5_AUTHDATA *)ASN1_item_new(&KRB5_AUTHDATA_it);
352}
353
354void
355KRB5_AUTHDATA_free(KRB5_AUTHDATA *a)
356{
357 ASN1_item_free((ASN1_VALUE *)a, &KRB5_AUTHDATA_it);
358}
359
360
361/* [APPLICATION 2] = 0x62 */
362ASN1_SEQUENCE(KRB5_AUTHENTBODY) = {
363 ASN1_EXP(KRB5_AUTHENTBODY, avno, ASN1_INTEGER, 0),
364 ASN1_EXP(KRB5_AUTHENTBODY, crealm, ASN1_GENERALSTRING, 1),
365 ASN1_EXP(KRB5_AUTHENTBODY, cname, KRB5_PRINCNAME, 2),
366 ASN1_EXP_OPT(KRB5_AUTHENTBODY, cksum, KRB5_CHECKSUM, 3),
367 ASN1_EXP(KRB5_AUTHENTBODY, cusec, ASN1_INTEGER, 4),
368 ASN1_EXP(KRB5_AUTHENTBODY, ctime, ASN1_GENERALIZEDTIME, 5),
369 ASN1_EXP_OPT(KRB5_AUTHENTBODY, subkey, KRB5_ENCKEY, 6),
370 ASN1_EXP_OPT(KRB5_AUTHENTBODY, seqnum, ASN1_INTEGER, 7),
371 ASN1_EXP_SEQUENCE_OF_OPT
372 (KRB5_AUTHENTBODY, authorization, KRB5_AUTHDATA, 8),
373} ASN1_SEQUENCE_END(KRB5_AUTHENTBODY)
374
375
376KRB5_AUTHENTBODY *
377d2i_KRB5_AUTHENTBODY(KRB5_AUTHENTBODY **a, const unsigned char **in, long len)
378{
379 return (KRB5_AUTHENTBODY *)ASN1_item_d2i((ASN1_VALUE **)a, in, len,
380 &KRB5_AUTHENTBODY_it);
381}
382
383int
384i2d_KRB5_AUTHENTBODY(KRB5_AUTHENTBODY *a, unsigned char **out)
385{
386 return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_AUTHENTBODY_it);
387}
388
389KRB5_AUTHENTBODY *
390KRB5_AUTHENTBODY_new(void)
391{
392 return (KRB5_AUTHENTBODY *)ASN1_item_new(&KRB5_AUTHENTBODY_it);
393}
394
395void
396KRB5_AUTHENTBODY_free(KRB5_AUTHENTBODY *a)
397{
398 ASN1_item_free((ASN1_VALUE *)a, &KRB5_AUTHENTBODY_it);
399}
400
401ASN1_ITEM_TEMPLATE(KRB5_AUTHENT) =
402 ASN1_EX_TEMPLATE_TYPE(ASN1_TFLG_EXPTAG|ASN1_TFLG_APPLICATION, 2,
403 KRB5_AUTHENT, KRB5_AUTHENTBODY)
404ASN1_ITEM_TEMPLATE_END(KRB5_AUTHENT)
405
406
407KRB5_AUTHENT *
408d2i_KRB5_AUTHENT(KRB5_AUTHENT **a, const unsigned char **in, long len)
409{
410 return (KRB5_AUTHENT *)ASN1_item_d2i((ASN1_VALUE **)a, in, len,
411 &KRB5_AUTHENT_it);
412}
413
414int
415i2d_KRB5_AUTHENT(KRB5_AUTHENT *a, unsigned char **out)
416{
417 return ASN1_item_i2d((ASN1_VALUE *)a, out, &KRB5_AUTHENT_it);
418}
419
420KRB5_AUTHENT *
421KRB5_AUTHENT_new(void)
422{
423 return (KRB5_AUTHENT *)ASN1_item_new(&KRB5_AUTHENT_it);
424}
425
426void
427KRB5_AUTHENT_free(KRB5_AUTHENT *a)
428{
429 ASN1_item_free((ASN1_VALUE *)a, &KRB5_AUTHENT_it);
430}
431
diff --git a/src/lib/libcrypto/krb5/krb5_asn.h b/src/lib/libcrypto/krb5/krb5_asn.h
deleted file mode 100644
index a5326e1057..0000000000
--- a/src/lib/libcrypto/krb5/krb5_asn.h
+++ /dev/null
@@ -1,256 +0,0 @@
1/* $OpenBSD: krb5_asn.h,v 1.4 2014/06/12 15:49:29 deraadt Exp $ */
2/* Written by Vern Staats <staatsvr@asc.hpc.mil> for the OpenSSL project,
3** using ocsp/{*.h,*asn*.c} as a starting point
4*/
5
6/* ====================================================================
7 * Copyright (c) 1998-2000 The OpenSSL Project. All rights reserved.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
11 * are met:
12 *
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 *
16 * 2. Redistributions in binary form must reproduce the above copyright
17 * notice, this list of conditions and the following disclaimer in
18 * the documentation and/or other materials provided with the
19 * distribution.
20 *
21 * 3. All advertising materials mentioning features or use of this
22 * software must display the following acknowledgment:
23 * "This product includes software developed by the OpenSSL Project
24 * for use in the OpenSSL Toolkit. (http://www.openssl.org/)"
25 *
26 * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
27 * endorse or promote products derived from this software without
28 * prior written permission. For written permission, please contact
29 * openssl-core@openssl.org.
30 *
31 * 5. Products derived from this software may not be called "OpenSSL"
32 * nor may "OpenSSL" appear in their names without prior written
33 * permission of the OpenSSL Project.
34 *
35 * 6. Redistributions of any form whatsoever must retain the following
36 * acknowledgment:
37 * "This product includes software developed by the OpenSSL Project
38 * for use in the OpenSSL Toolkit (http://www.openssl.org/)"
39 *
40 * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
41 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
42 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
43 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
44 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
45 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
46 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
47 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
48 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
49 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
50 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
51 * OF THE POSSIBILITY OF SUCH DAMAGE.
52 * ====================================================================
53 *
54 * This product includes cryptographic software written by Eric Young
55 * (eay@cryptsoft.com). This product includes software written by Tim
56 * Hudson (tjh@cryptsoft.com).
57 *
58 */
59
60#ifndef HEADER_KRB5_ASN_H
61#define HEADER_KRB5_ASN_H
62
63/*
64#include <krb5.h>
65*/
66#include <openssl/safestack.h>
67
68#ifdef __cplusplus
69extern "C" {
70#endif
71
72
73/* ASN.1 from Kerberos RFC 1510
74*/
75
76/* EncryptedData ::= SEQUENCE {
77** etype[0] INTEGER, -- EncryptionType
78** kvno[1] INTEGER OPTIONAL,
79** cipher[2] OCTET STRING -- ciphertext
80** }
81*/
82typedef struct krb5_encdata_st
83 {
84 ASN1_INTEGER *etype;
85 ASN1_INTEGER *kvno;
86 ASN1_OCTET_STRING *cipher;
87 } KRB5_ENCDATA;
88
89DECLARE_STACK_OF(KRB5_ENCDATA)
90
91/* PrincipalName ::= SEQUENCE {
92** name-type[0] INTEGER,
93** name-string[1] SEQUENCE OF GeneralString
94** }
95*/
96typedef struct krb5_princname_st
97 {
98 ASN1_INTEGER *nametype;
99 STACK_OF(ASN1_GENERALSTRING) *namestring;
100 } KRB5_PRINCNAME;
101
102DECLARE_STACK_OF(KRB5_PRINCNAME)
103
104
105/* Ticket ::= [APPLICATION 1] SEQUENCE {
106** tkt-vno[0] INTEGER,
107** realm[1] Realm,
108** sname[2] PrincipalName,
109** enc-part[3] EncryptedData
110** }
111*/
112typedef struct krb5_tktbody_st
113 {
114 ASN1_INTEGER *tktvno;
115 ASN1_GENERALSTRING *realm;
116 KRB5_PRINCNAME *sname;
117 KRB5_ENCDATA *encdata;
118 } KRB5_TKTBODY;
119
120typedef STACK_OF(KRB5_TKTBODY) KRB5_TICKET;
121DECLARE_STACK_OF(KRB5_TKTBODY)
122
123
124/* AP-REQ ::= [APPLICATION 14] SEQUENCE {
125** pvno[0] INTEGER,
126** msg-type[1] INTEGER,
127** ap-options[2] APOptions,
128** ticket[3] Ticket,
129** authenticator[4] EncryptedData
130** }
131**
132** APOptions ::= BIT STRING {
133** reserved(0), use-session-key(1), mutual-required(2) }
134*/
135typedef struct krb5_ap_req_st
136 {
137 ASN1_INTEGER *pvno;
138 ASN1_INTEGER *msgtype;
139 ASN1_BIT_STRING *apoptions;
140 KRB5_TICKET *ticket;
141 KRB5_ENCDATA *authenticator;
142 } KRB5_APREQBODY;
143
144typedef STACK_OF(KRB5_APREQBODY) KRB5_APREQ;
145DECLARE_STACK_OF(KRB5_APREQBODY)
146
147
148/* Authenticator Stuff */
149
150
151/* Checksum ::= SEQUENCE {
152** cksumtype[0] INTEGER,
153** checksum[1] OCTET STRING
154** }
155*/
156typedef struct krb5_checksum_st
157 {
158 ASN1_INTEGER *ctype;
159 ASN1_OCTET_STRING *checksum;
160 } KRB5_CHECKSUM;
161
162DECLARE_STACK_OF(KRB5_CHECKSUM)
163
164
165/* EncryptionKey ::= SEQUENCE {
166** keytype[0] INTEGER,
167** keyvalue[1] OCTET STRING
168** }
169*/
170typedef struct krb5_encryptionkey_st
171 {
172 ASN1_INTEGER *ktype;
173 ASN1_OCTET_STRING *keyvalue;
174 } KRB5_ENCKEY;
175
176DECLARE_STACK_OF(KRB5_ENCKEY)
177
178
179/* AuthorizationData ::= SEQUENCE OF SEQUENCE {
180** ad-type[0] INTEGER,
181** ad-data[1] OCTET STRING
182** }
183*/
184typedef struct krb5_authorization_st
185 {
186 ASN1_INTEGER *adtype;
187 ASN1_OCTET_STRING *addata;
188 } KRB5_AUTHDATA;
189
190DECLARE_STACK_OF(KRB5_AUTHDATA)
191
192
193/* -- Unencrypted authenticator
194** Authenticator ::= [APPLICATION 2] SEQUENCE {
195** authenticator-vno[0] INTEGER,
196** crealm[1] Realm,
197** cname[2] PrincipalName,
198** cksum[3] Checksum OPTIONAL,
199** cusec[4] INTEGER,
200** ctime[5] KerberosTime,
201** subkey[6] EncryptionKey OPTIONAL,
202** seq-number[7] INTEGER OPTIONAL,
203** authorization-data[8] AuthorizationData OPTIONAL
204** }
205*/
206typedef struct krb5_authenticator_st
207 {
208 ASN1_INTEGER *avno;
209 ASN1_GENERALSTRING *crealm;
210 KRB5_PRINCNAME *cname;
211 KRB5_CHECKSUM *cksum;
212 ASN1_INTEGER *cusec;
213 ASN1_GENERALIZEDTIME *ctime;
214 KRB5_ENCKEY *subkey;
215 ASN1_INTEGER *seqnum;
216 KRB5_AUTHDATA *authorization;
217 } KRB5_AUTHENTBODY;
218
219typedef STACK_OF(KRB5_AUTHENTBODY) KRB5_AUTHENT;
220DECLARE_STACK_OF(KRB5_AUTHENTBODY)
221
222
223/* DECLARE_ASN1_FUNCTIONS(type) = DECLARE_ASN1_FUNCTIONS_name(type, type) =
224** type *name##_new(void);
225** void name##_free(type *a);
226** DECLARE_ASN1_ENCODE_FUNCTIONS(type, name, name) =
227** DECLARE_ASN1_ENCODE_FUNCTIONS(type, itname, name) =
228** type *d2i_##name(type **a, const unsigned char **in, long len);
229** int i2d_##name(type *a, unsigned char **out);
230** DECLARE_ASN1_ITEM(itname) = extern const ASN1_ITEM itname##_it
231*/
232
233DECLARE_ASN1_FUNCTIONS(KRB5_ENCDATA)
234DECLARE_ASN1_FUNCTIONS(KRB5_PRINCNAME)
235DECLARE_ASN1_FUNCTIONS(KRB5_TKTBODY)
236DECLARE_ASN1_FUNCTIONS(KRB5_APREQBODY)
237DECLARE_ASN1_FUNCTIONS(KRB5_TICKET)
238DECLARE_ASN1_FUNCTIONS(KRB5_APREQ)
239
240DECLARE_ASN1_FUNCTIONS(KRB5_CHECKSUM)
241DECLARE_ASN1_FUNCTIONS(KRB5_ENCKEY)
242DECLARE_ASN1_FUNCTIONS(KRB5_AUTHDATA)
243DECLARE_ASN1_FUNCTIONS(KRB5_AUTHENTBODY)
244DECLARE_ASN1_FUNCTIONS(KRB5_AUTHENT)
245
246
247/* BEGIN ERROR CODES */
248/* The following lines are auto generated by the script mkerr.pl. Any changes
249 * made after this point may be overwritten when the script is next run.
250 */
251
252#ifdef __cplusplus
253}
254#endif
255#endif
256