Deleted Added
full compact
ticket.c (127808) ticket.c (178825)
1/*
2 * Copyright (c) 1997 - 2001 Kungliga Tekniska H�gskolan
3 * (Royal Institute of Technology, Stockholm, Sweden).
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:

--- 19 unchanged lines hidden (view full) ---

28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 * SUCH DAMAGE.
32 */
33
34#include "krb5_locl.h"
35
1/*
2 * Copyright (c) 1997 - 2001 Kungliga Tekniska H�gskolan
3 * (Royal Institute of Technology, Stockholm, Sweden).
4 * All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:

--- 19 unchanged lines hidden (view full) ---

28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 * SUCH DAMAGE.
32 */
33
34#include "krb5_locl.h"
35
36RCSID("$Id: ticket.c,v 1.5.8.1 2003/09/18 21:01:57 lha Exp $");
36RCSID("$Id: ticket.c 19544 2006-12-28 20:49:18Z lha $");
37
37
38krb5_error_code
38krb5_error_code KRB5_LIB_FUNCTION
39krb5_free_ticket(krb5_context context,
40 krb5_ticket *ticket)
41{
42 free_EncTicketPart(&ticket->ticket);
43 krb5_free_principal(context, ticket->client);
44 krb5_free_principal(context, ticket->server);
39krb5_free_ticket(krb5_context context,
40 krb5_ticket *ticket)
41{
42 free_EncTicketPart(&ticket->ticket);
43 krb5_free_principal(context, ticket->client);
44 krb5_free_principal(context, ticket->server);
45 free(ticket);
45 return 0;
46}
47
46 return 0;
47}
48
48krb5_error_code
49krb5_error_code KRB5_LIB_FUNCTION
49krb5_copy_ticket(krb5_context context,
50 const krb5_ticket *from,
51 krb5_ticket **to)
52{
53 krb5_error_code ret;
54 krb5_ticket *tmp;
55
56 *to = NULL;

--- 17 unchanged lines hidden (view full) ---

74 krb5_free_principal(context, tmp->client);
75 free_EncTicketPart(&tmp->ticket);
76 free(tmp);
77 return ret;
78 }
79 *to = tmp;
80 return 0;
81}
50krb5_copy_ticket(krb5_context context,
51 const krb5_ticket *from,
52 krb5_ticket **to)
53{
54 krb5_error_code ret;
55 krb5_ticket *tmp;
56
57 *to = NULL;

--- 17 unchanged lines hidden (view full) ---

75 krb5_free_principal(context, tmp->client);
76 free_EncTicketPart(&tmp->ticket);
77 free(tmp);
78 return ret;
79 }
80 *to = tmp;
81 return 0;
82}
83
84krb5_error_code KRB5_LIB_FUNCTION
85krb5_ticket_get_client(krb5_context context,
86 const krb5_ticket *ticket,
87 krb5_principal *client)
88{
89 return krb5_copy_principal(context, ticket->client, client);
90}
91
92krb5_error_code KRB5_LIB_FUNCTION
93krb5_ticket_get_server(krb5_context context,
94 const krb5_ticket *ticket,
95 krb5_principal *server)
96{
97 return krb5_copy_principal(context, ticket->server, server);
98}
99
100time_t KRB5_LIB_FUNCTION
101krb5_ticket_get_endtime(krb5_context context,
102 const krb5_ticket *ticket)
103{
104 return ticket->ticket.endtime;
105}
106
107static int
108find_type_in_ad(krb5_context context,
109 int type,
110 krb5_data *data,
111 krb5_boolean *found,
112 krb5_boolean failp,
113 krb5_keyblock *sessionkey,
114 const AuthorizationData *ad,
115 int level)
116{
117 krb5_error_code ret = 0;
118 int i;
119
120 if (level > 9) {
121 krb5_set_error_string(context, "Authorization data nested deeper "
122 "then %d levels, stop searching", level);
123 ret = ENOENT; /* XXX */
124 goto out;
125 }
126
127 /*
128 * Only copy out the element the first time we get to it, we need
129 * to run over the whole authorization data fields to check if
130 * there are any container clases we need to care about.
131 */
132 for (i = 0; i < ad->len; i++) {
133 if (!*found && ad->val[i].ad_type == type) {
134 ret = der_copy_octet_string(&ad->val[i].ad_data, data);
135 if (ret) {
136 krb5_set_error_string(context, "malloc - out of memory");
137 goto out;
138 }
139 *found = TRUE;
140 continue;
141 }
142 switch (ad->val[i].ad_type) {
143 case KRB5_AUTHDATA_IF_RELEVANT: {
144 AuthorizationData child;
145 ret = decode_AuthorizationData(ad->val[i].ad_data.data,
146 ad->val[i].ad_data.length,
147 &child,
148 NULL);
149 if (ret) {
150 krb5_set_error_string(context, "Failed to decode "
151 "IF_RELEVANT with %d", ret);
152 goto out;
153 }
154 ret = find_type_in_ad(context, type, data, found, FALSE,
155 sessionkey, &child, level + 1);
156 free_AuthorizationData(&child);
157 if (ret)
158 goto out;
159 break;
160 }
161#if 0 /* XXX test */
162 case KRB5_AUTHDATA_KDC_ISSUED: {
163 AD_KDCIssued child;
164
165 ret = decode_AD_KDCIssued(ad->val[i].ad_data.data,
166 ad->val[i].ad_data.length,
167 &child,
168 NULL);
169 if (ret) {
170 krb5_set_error_string(context, "Failed to decode "
171 "AD_KDCIssued with %d", ret);
172 goto out;
173 }
174 if (failp) {
175 krb5_boolean valid;
176 krb5_data buf;
177 size_t len;
178
179 ASN1_MALLOC_ENCODE(AuthorizationData, buf.data, buf.length,
180 &child.elements, &len, ret);
181 if (ret) {
182 free_AD_KDCIssued(&child);
183 krb5_clear_error_string(context);
184 goto out;
185 }
186 if(buf.length != len)
187 krb5_abortx(context, "internal error in ASN.1 encoder");
188
189 ret = krb5_c_verify_checksum(context, sessionkey, 19, &buf,
190 &child.ad_checksum, &valid);
191 krb5_data_free(&buf);
192 if (ret) {
193 free_AD_KDCIssued(&child);
194 goto out;
195 }
196 if (!valid) {
197 krb5_clear_error_string(context);
198 ret = ENOENT;
199 free_AD_KDCIssued(&child);
200 goto out;
201 }
202 }
203 ret = find_type_in_ad(context, type, data, found, failp, sessionkey,
204 &child.elements, level + 1);
205 free_AD_KDCIssued(&child);
206 if (ret)
207 goto out;
208 break;
209 }
210#endif
211 case KRB5_AUTHDATA_AND_OR:
212 if (!failp)
213 break;
214 krb5_set_error_string(context, "Authorization data contains "
215 "AND-OR element that is unknown to the "
216 "application");
217 ret = ENOENT; /* XXX */
218 goto out;
219 default:
220 if (!failp)
221 break;
222 krb5_set_error_string(context, "Authorization data contains "
223 "unknown type (%d) ", ad->val[i].ad_type);
224 ret = ENOENT; /* XXX */
225 goto out;
226 }
227 }
228out:
229 if (ret) {
230 if (*found) {
231 krb5_data_free(data);
232 *found = 0;
233 }
234 }
235 return ret;
236}
237
238/*
239 * Extract the authorization data type of `type' from the
240 * 'ticket'. Store the field in `data'. This function is to use for
241 * kerberos applications.
242 */
243
244krb5_error_code KRB5_LIB_FUNCTION
245krb5_ticket_get_authorization_data_type(krb5_context context,
246 krb5_ticket *ticket,
247 int type,
248 krb5_data *data)
249{
250 AuthorizationData *ad;
251 krb5_error_code ret;
252 krb5_boolean found = FALSE;
253
254 krb5_data_zero(data);
255
256 ad = ticket->ticket.authorization_data;
257 if (ticket->ticket.authorization_data == NULL) {
258 krb5_set_error_string(context, "Ticket have not authorization data");
259 return ENOENT; /* XXX */
260 }
261
262 ret = find_type_in_ad(context, type, data, &found, TRUE,
263 &ticket->ticket.key, ad, 0);
264 if (ret)
265 return ret;
266 if (!found) {
267 krb5_set_error_string(context, "Ticket have not authorization "
268 "data of type %d", type);
269 return ENOENT; /* XXX */
270 }
271 return 0;
272}