+2001-11-18 Sam Hartman <hartmans@mit.edu>
+
+ * krb5.hin: Add krb5_set_default_tgs_enctypes
+
2001-11-15 Sam Hartman <hartmans@mit.edu>
* krb5.hin: Add krb5_c_random_add_entropy and
krb5_error_code krb5_set_default_tgs_ktypes
(krb5_context,
krb5_const krb5_enctype *);
+krb5_error_code KRB5_CALLCONV
+krb5_set_default_tgs_enctypes
+ (krb5_context,
+ krb5_const krb5_enctype *);
krb5_error_code KRB5_CALLCONV krb5_get_tgs_ktypes
(krb5_context,
krb5_const_principal,
+2001-11-18 Sam Hartman <hartmans@mit.edu>
+
+ * init_sec_context.c (get_credentials): Override
+ default_tgs_enctypes rather than looping over credentials. Avoids
+ hits on the KDC.
+
2001-10-30 Ezra Peisach <epeisach@mit.edu>
* k5unseal.c: Fix whitespace in copyright message.
in_creds.keyblock.enctype = 0;
- /*
- * Initial iteration is necessary to catch a non-matching
- * credential prior to looping through the GSSAPI-supported
- * enctypes, since an enctype mismatch in the loop below will
- * return KRB5_CC_NOTFOUND rather than one of the other error
- * codes.
- */
- code = krb5_get_credentials(context, 0, cred->ccache,
- &in_creds, out_creds);
+ code = krb5_set_default_tgs_enctypes (context, enctypes);
if (code)
- goto cleanup;
- krb5_free_creds(context, *out_creds);
- *out_creds = NULL;
- for (i = 0; enctypes[i]; i++) {
- in_creds.keyblock.enctype = enctypes[i];
- code = krb5_get_credentials(context, 0, cred->ccache,
- &in_creds, out_creds);
- if (code != KRB5_CC_NOT_KTYPE && code != KRB5_CC_NOTFOUND
- && code != KRB5KDC_ERR_ETYPE_NOSUPP)
- break;
- }
- if (enctypes[i] == 0) {
- code = KRB5_CONFIG_ETYPE_NOSUPP;
- goto cleanup;
- }
+ goto cleanup;
+ code = krb5_get_credentials(context, 0, cred->ccache,
+ &in_creds, out_creds);
if (code)
goto cleanup;
+2001-11-16 Sam Hartman <hartmans@mit.edu>
+
+ * init_ctx.c (krb5_set_default_tgs_enctypes): rename from
+ set_default_ktypes; old function provided as APIA
+
2001-11-16 Ezra Peisach <epeisach@mit.edu>
* init_ctx.c (DEFAULT_ETYPE_LIST): Ensure space present after
context->in_tkt_ktypes));
}
-krb5_error_code
-krb5_set_default_tgs_ktypes(context, ktypes)
+krb5_error_code KRB5_CALLCONV
+krb5_set_default_tgs_enctypes (context, ktypes)
krb5_context context;
const krb5_enctype *ktypes;
{
return 0;
}
+krb5_error_code krb5_set_default_tgs_ktypes
+(krb5_context context, const krb5_enctype *etypes)
+{
+ return (krb5_set_default_tgs_enctypes (context, etypes));
+}
+
+
void
KRB5_CALLCONV
krb5_free_ktypes (context, val)