aklog: Tidy header includes
[openafs.git] / src / aklog / skipwrap.c
1
2 /*
3  * Copyright (c) 2006
4  * The Regents of the University of Michigan
5  * ALL RIGHTS RESERVED
6  *
7  * Permission is granted to use, copy, create derivative works
8  * and redistribute this software and such derivative works
9  * for any purpose, so long as the name of the University of
10  * Michigan is not used in any advertising or publicity
11  * pertaining to the use or distribution of this software
12  * without specific, written prior authorization.  If the
13  * above copyright notice or any other identification of the
14  * University of Michigan is included in any copy of any
15  * portion of this software, then the disclaimer below must
16  * also be included.
17  *
18  * This software is provided as is, without representation
19  * from the University of Michigan as to its fitness for any
20  * purpose, and without warranty by the University of
21  * Michigan of any kind, either express or implied, including
22  * without limitation the implied warranties of
23  * merchantability and fitness for a particular purpose.  The
24  * regents of the University of Michigan shall not be liable
25  * for any damages, including special, indirect, incidental, or
26  * consequential damages, with respect to any claim arising
27  * out of or in connection with the use of the software, even
28  * if it has been or is hereafter advised of the possibility of
29  * such damages.
30  */
31
32 #include <afsconfig.h>
33 #include <afs/param.h>
34
35 #include <roken.h>
36
37 #include "aklog.h"
38 #include <krb5.h>
39 #include "skipwrap.h"
40
41 /* evil hack */
42 #define SEQUENCE 16
43 #define CONSTRUCTED 32
44 #define APPLICATION 64
45 #define CONTEXT_SPECIFIC 128
46 static int skip_get_number(char **pp, size_t *lp, int *np)
47 {
48     unsigned l;
49     int r, n, i;
50     char *p;
51
52     l = *lp;
53     if (l < 1) {
54 #ifdef DEBUG
55         fprintf(stderr, "skip_bad_number: missing number\n");
56 #endif
57         return -1;
58     }
59     p = *pp;
60     r = (unsigned char)*p;
61     ++p; --l;
62     if (r & 0x80) {
63         n = (r&0x7f);
64         if (l < n) {
65 #ifdef DEBUG
66             fprintf(stderr, "skip_bad_number: truncated number\n");
67 #endif
68             return -1;
69         }
70         r = 0;
71         for (i = n; --i >= 0; ) {
72             r <<= 8;
73             r += (unsigned char)*p;
74             ++p; --l;
75         }
76     }
77     *np = r;
78     *pp = p;
79     *lp = l;
80     return 0;
81 }
82
83 int
84 afs_krb5_skip_ticket_wrapper(char *tix, size_t tixlen, char **enc, size_t *enclen)
85 {
86     char *p = tix;
87     size_t l = tixlen;
88     int code;
89     int num;
90
91     if (l < 1) return -1;
92     if (*p != (char) (CONSTRUCTED+APPLICATION+1)) return -1;
93     ++p; --l;
94     if ((code = skip_get_number(&p, &l, &num))) return code;
95     if (l != num) return -1;
96     if (l < 1) return -1;
97     if (*p != (char)(CONSTRUCTED+SEQUENCE)) return -1;
98     ++p; --l;
99     if ((code = skip_get_number(&p, &l, &num))) return code;
100     if (l != num) return -1;
101     if (l < 1) return -1;
102     if (*p != (char)(CONSTRUCTED+CONTEXT_SPECIFIC+0)) return -1;
103     ++p; --l;
104     if ((code = skip_get_number(&p, &l, &num))) return code;
105     if (l < num) return -1;
106     l -= num; p += num;
107     if (l < 1) return -1;
108     if (*p != (char)(CONSTRUCTED+CONTEXT_SPECIFIC+1)) return -1;
109     ++p; --l;
110     if ((code = skip_get_number(&p, &l, &num))) return code;
111     if (l < num) return -1;
112     l -= num; p += num;
113     if (l < 1) return -1;
114     if (*p != (char)(CONSTRUCTED+CONTEXT_SPECIFIC+2)) return -1;
115     ++p; --l;
116     if ((code = skip_get_number(&p, &l, &num))) return code;
117     if (l < num) return -1;
118     l -= num; p += num;
119     if (l < 1) return -1;
120     if (*p != (char)(CONSTRUCTED+CONTEXT_SPECIFIC+3)) return -1;
121     ++p; --l;
122     if ((code = skip_get_number(&p, &l, &num))) return code;
123     if (l != num) return -1;
124     *enc = p;
125     *enclen = l;
126     return 0;
127 }