2 Unix SMB/CIFS implementation.
3 simple kerberos5 routines for active directory
4 Copyright (C) Andrew Tridgell 2001
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
25 we can't use krb5_mk_req because w2k wants the service to be in a particular format
27 static krb5_error_code
krb5_mk_req2(krb5_context context
,
28 krb5_auth_context
*auth_context
,
29 const krb5_flags ap_req_options
,
30 const char *principal
,
34 krb5_error_code retval
;
35 krb5_principal server
;
40 retval
= krb5_parse_name(context
, principal
, &server
);
42 DEBUG(1,("Failed to parse principal %s\n", principal
));
46 /* obtain ticket & session key */
47 memset((char *)&creds
, 0, sizeof(creds
));
48 if ((retval
= krb5_copy_principal(context
, server
, &creds
.server
))) {
49 DEBUG(1,("krb5_copy_principal failed (%s)\n",
50 error_message(retval
)));
54 if ((retval
= krb5_cc_get_principal(context
, ccache
, &creds
.client
))) {
55 DEBUG(1,("krb5_cc_get_principal failed (%s)\n",
56 error_message(retval
)));
60 if ((retval
= krb5_get_credentials(context
, 0,
61 ccache
, &creds
, &credsp
))) {
62 DEBUG(1,("krb5_get_credentials failed for %s (%s)\n",
63 principal
, error_message(retval
)));
68 retval
= krb5_mk_req_extended(context
, auth_context
, ap_req_options
,
69 &in_data
, credsp
, outbuf
);
71 DEBUG(1,("krb5_mk_req_extended failed (%s)\n",
72 error_message(retval
)));
75 krb5_free_creds(context
, credsp
);
78 krb5_free_cred_contents(context
, &creds
);
81 krb5_free_principal(context
, server
);
87 get a kerberos5 ticket for the given service
89 DATA_BLOB
krb5_get_ticket(char *principal
)
91 krb5_error_code retval
;
95 krb5_auth_context auth_context
= NULL
;
97 krb5_enctype enc_types
[] = {ENCTYPE_DES_CBC_MD5
, ENCTYPE_NULL
};
99 retval
= krb5_init_context(&context
);
101 DEBUG(1,("krb5_init_context failed (%s)\n",
102 error_message(retval
)));
106 if ((retval
= krb5_cc_default(context
, &ccdef
))) {
107 DEBUG(1,("krb5_cc_default failed (%s)\n",
108 error_message(retval
)));
112 if ((retval
= krb5_set_default_tgs_ktypes(context
, enc_types
))) {
113 DEBUG(1,("krb5_set_default_tgs_ktypes failed (%s)\n",
114 error_message(retval
)));
118 if ((retval
= krb5_mk_req2(context
,
126 ret
= data_blob(packet
.data
, packet
.length
);
127 /* Hmm, heimdal dooesn't have this - what's the correct call? */
128 /* krb5_free_data_contents(context, &packet); */
129 krb5_free_context(context
);
133 krb5_free_context(context
);
134 return data_blob(NULL
, 0);
138 #else /* HAVE_KRB5 */
139 /* this saves a few linking headaches */
140 DATA_BLOB
krb5_get_ticket(char *principal
)
142 DEBUG(0,("NO KERBEROS SUPPORT\n"));
143 return data_blob(NULL
, 0);