aboutsummaryrefslogtreecommitdiff
path: root/src/kdc/kdc_authdata.c
diff options
context:
space:
mode:
authorGreg Hudson <ghudson@mit.edu>2010-02-05 03:43:54 +0000
committerGreg Hudson <ghudson@mit.edu>2010-02-05 03:43:54 +0000
commit6581735ddea7215935e91c34a2103de1acfe3952 (patch)
tree4903c4e428d912a25124525c7fe8a0e5a9250f25 /src/kdc/kdc_authdata.c
parentbebdddf413bc4edbe6a738f6f01aa3428d2e8381 (diff)
downloadkrb5-6581735ddea7215935e91c34a2103de1acfe3952.zip
krb5-6581735ddea7215935e91c34a2103de1acfe3952.tar.gz
krb5-6581735ddea7215935e91c34a2103de1acfe3952.tar.bz2
Fix cross-realm handling of AD-SIGNEDPATH
Avoid setting AD-SIGNEDPATH when returning a cross-realm TGT. Previously we were avoiding it when answering a cross-realm client, which was wrong. Don't fail out on an invalid AD-SIGNEDPATH checksum; just don't trust the ticket for S4U2Proxy (as if AD-SIGNEDPATH weren't present). ticket: 6655 target_version: 1.8 tags: pullup git-svn-id: svn://anonsvn.mit.edu/krb5/trunk@23697 dc483132-0cff-0310-8789-dd5450dbe970
Diffstat (limited to 'src/kdc/kdc_authdata.c')
-rw-r--r--src/kdc/kdc_authdata.c14
1 files changed, 7 insertions, 7 deletions
diff --git a/src/kdc/kdc_authdata.c b/src/kdc/kdc_authdata.c
index 8b01ad3..5097558 100644
--- a/src/kdc/kdc_authdata.c
+++ b/src/kdc/kdc_authdata.c
@@ -897,10 +897,6 @@ verify_ad_signedpath_checksum(krb5_context context,
valid);
krb5_free_data(context, data);
-
- if (code == 0 && *valid == FALSE)
- code = KRB5KRB_AP_ERR_MODIFIED;
-
return code;
}
@@ -952,8 +948,10 @@ verify_ad_signedpath(krb5_context context,
if (code != 0)
goto cleanup;
- *pdelegated = sp->delegated;
- sp->delegated = NULL;
+ if (*path_is_signed) {
+ *pdelegated = sp->delegated;
+ sp->delegated = NULL;
+ }
cleanup:
krb5_free_ad_signedpath(context, sp);
@@ -1179,7 +1177,9 @@ handle_signedpath_authdata (krb5_context context,
}
}
- if (!isflagset(flags, KRB5_KDB_FLAG_CROSS_REALM) &&
+ /* No point in including signedpath authdata for a cross-realm TGT, since
+ * it will be presented to a different KDC. */
+ if (!is_cross_tgs_principal(server->princ) &&
!only_pac_p(context, enc_tkt_reply->authorization_data)) {
code = make_ad_signedpath(context,
for_user_princ,