summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorStef Walter <stefw@gnome.org>2012-04-11 12:12:57 +0200
committerStephen Gallagher <sgallagh@redhat.com>2012-05-22 09:13:17 -0400
commite413168d70c3ac08dc367d9889076e3f32701221 (patch)
tree5b835b57558cec852bf875a41b7d884040638f53 /src
parent6da9b3bcbee97fbfdb02c652ddcd0ab048224997 (diff)
downloadsssd-e413168d70c3ac08dc367d9889076e3f32701221.tar.gz
sssd-e413168d70c3ac08dc367d9889076e3f32701221.tar.xz
sssd-e413168d70c3ac08dc367d9889076e3f32701221.zip
If canon'ing principals, write ccache with updated default principal
* When calling krb5_get_init_creds_keytab() with krb5_get_init_creds_opt_set_canonicalize() the credential principal can get updated. * Create the cache file with the correct default credential. * LDAP GSSAPI SASL would fail due to the mismatched credentials before this patch. https://bugzilla.redhat.com/show_bug.cgi?id=811518
Diffstat (limited to 'src')
-rw-r--r--src/providers/krb5/krb5_child.c8
-rw-r--r--src/providers/ldap/ldap_child.c3
2 files changed, 8 insertions, 3 deletions
diff --git a/src/providers/krb5/krb5_child.c b/src/providers/krb5/krb5_child.c
index 9a84684fa..56b2ac945 100644
--- a/src/providers/krb5/krb5_child.c
+++ b/src/providers/krb5/krb5_child.c
@@ -646,7 +646,8 @@ static krb5_error_code get_and_save_tgt_with_keytab(krb5_context ctx,
return kerr;
}
- kerr = create_ccache_file(ctx, princ, ccname, &creds);
+ /* Use the updated principal in the creds in case canonicalized */
+ kerr = create_ccache_file(ctx, creds.client, ccname, &creds);
if (kerr != 0) {
KRB5_DEBUG(1, kerr);
goto done;
@@ -704,7 +705,10 @@ static krb5_error_code get_and_save_tgt(struct krb5_req *kr,
}
}
- kerr = create_ccache_file(kr->ctx, kr->princ, kr->ccname, kr->creds);
+ /* Use the updated principal in the creds in case canonicalized */
+ kerr = create_ccache_file(kr->ctx,
+ kr->creds ? kr->creds->client : kr->princ,
+ kr->ccname, kr->creds);
if (kerr != 0) {
KRB5_DEBUG(1, kerr);
goto done;
diff --git a/src/providers/ldap/ldap_child.c b/src/providers/ldap/ldap_child.c
index 0679dbfdf..00c447489 100644
--- a/src/providers/ldap/ldap_child.c
+++ b/src/providers/ldap/ldap_child.c
@@ -300,7 +300,8 @@ static krb5_error_code ldap_child_get_tgt_sync(TALLOC_CTX *memctx,
goto done;
}
- krberr = krb5_cc_initialize(context, ccache, kprinc);
+ /* Use updated principal if changed due to canonicalization. */
+ krberr = krb5_cc_initialize(context, ccache, my_creds.client);
if (krberr) {
DEBUG(2, ("Failed to init ccache: %s\n",
sss_krb5_get_error_message(context, krberr)));