Windows global stuff:
[krb5.git] / src / lib / krb5 / krb / decode_kdc.c
1 /*
2  * lib/krb5/krb/decode_kdc.c
3  *
4  * Copyright 1990 by the Massachusetts Institute of Technology.
5  * All Rights Reserved.
6  *
7  * Export of this software from the United States of America may
8  *   require a specific license from the United States Government.
9  *   It is the responsibility of any person or organization contemplating
10  *   export to obtain such a license before exporting.
11  * 
12  * WITHIN THAT CONSTRAINT, permission to use, copy, modify, and
13  * distribute this software and its documentation for any purpose and
14  * without fee is hereby granted, provided that the above copyright
15  * notice appear in all copies and that both that copyright notice and
16  * this permission notice appear in supporting documentation, and that
17  * the name of M.I.T. not be used in advertising or publicity pertaining
18  * to distribution of the software without specific, written prior
19  * permission.  M.I.T. makes no representations about the suitability of
20  * this software for any purpose.  It is provided "as is" without express
21  * or implied warranty.
22  * 
23  *
24  * krb5_decode_kdc_rep() function.
25  */
26
27 #include "k5-int.h"
28
29 /*
30  Takes a KDC_REP message and decrypts encrypted part using etype and
31  *key, putting result in *rep.
32  dec_rep->client,ticket,session,last_req,server,caddrs
33  are all set to allocated storage which should be freed by the caller
34  when finished with the response.
35
36  If the response isn't a KDC_REP (tgs or as), it returns an error from
37  the decoding routines.
38
39  returns errors from encryption routines, system errors
40  */
41
42 krb5_error_code
43 krb5_decode_kdc_rep(context, enc_rep, key, etype, dec_rep)
44     krb5_context context;
45     krb5_data * enc_rep;
46     const krb5_keyblock * key;
47     const krb5_enctype etype;
48     krb5_kdc_rep ** dec_rep;
49 {
50     krb5_error_code retval;
51     krb5_kdc_rep *local_dec_rep;
52
53     if (krb5_is_as_rep(enc_rep))
54         retval = decode_krb5_as_rep(enc_rep, &local_dec_rep);
55     else if (krb5_is_tgs_rep(enc_rep))
56         retval = decode_krb5_tgs_rep(enc_rep, &local_dec_rep);
57     else
58         return KRB5KRB_AP_ERR_MSG_TYPE;
59
60     if (retval)
61         return retval;
62
63     if (local_dec_rep->enc_part.etype != etype) {
64         krb5_free_kdc_rep(context, local_dec_rep);
65         return KRB5_WRONG_ETYPE;
66     }
67     retval = krb5_kdc_rep_decrypt_proc(context, key, 0, local_dec_rep);
68     if (retval) {
69         krb5_free_kdc_rep(context, local_dec_rep);
70         return(retval);
71     }
72     *dec_rep = local_dec_rep;
73     return 0;
74 }
75