svn rev #24562: branches/krb5-1-7/src/ lib/crypto/ lib/crypto/dk/ lib/gssapi/krb5/ ...
tlyu@MIT.EDU
tlyu at MIT.EDU
Mon Dec 6 18:23:17 EST 2010
http://mv.ezproxy.com.ezproxyberklee.flo.org/fisheye/changelog/krb5/?cs=24562
Commit By: tlyu
Log Message:
ticket: 6837
subject: SA-2010-007 Checksum vulnerabilities (CVE-2010-1324 and others)
target_version: 1.7.2
version_fixed: 1.7.2
status: resolved
Apply patch for MITKRB5-SA-2010-007.
Fix multiple checksum handling bugs, as described in:
CVE-2010-1324
CVE-2010-1323
CVE-2010-4020
CVE-2010-4021
* Return the correct (keyed) checksums as the mandatory checksum type
for DES enctypes.
* Restrict simplified-profile checksums to their corresponding etypes.
* Add internal checks to reduce the risk of stream ciphers being used
with simplified-profile key derivation or other algorithms relying
on the block encryption primitive.
* Use the mandatory checksum type for the PKINIT KDC signature,
instead of the first-listed keyed checksum.
* Use the mandatory checksum type when sending KRB-SAFE messages by
default, instead of the first-listed keyed checksum.
* Use the mandatory checksum type for the t_kperf test program.
* Use the mandatory checksum type (without additional logic) for the
FAST request checksum.
* Preserve the existing checksum choices (unkeyed checksums for DES
enctypes) for the authenticator checksum, using explicit logic.
* Ensure that SAM checksums received from the KDC are keyed.
* Ensure that PAC checksums are keyed.
Changed Files:
U branches/krb5-1-7/src/lib/crypto/dk/derive.c
U branches/krb5-1-7/src/lib/crypto/keyed_checksum_types.c
U branches/krb5-1-7/src/lib/gssapi/krb5/util_crypt.c
U branches/krb5-1-7/src/lib/krb5/krb/mk_safe.c
U branches/krb5-1-7/src/lib/krb5/krb/pac.c
U branches/krb5-1-7/src/lib/krb5/krb/preauth2.c
U branches/krb5-1-7/src/plugins/preauth/pkinit/pkinit_srv.c
Modified: branches/krb5-1-7/src/lib/crypto/dk/derive.c
===================================================================
--- branches/krb5-1-7/src/lib/crypto/dk/derive.c 2010-12-05 20:16:17 UTC (rev 24561)
+++ branches/krb5-1-7/src/lib/crypto/dk/derive.c 2010-12-06 23:23:17 UTC (rev 24562)
@@ -40,6 +40,8 @@
keybytes = enc->keybytes;
keylength = enc->keylength;
+ if (blocksize == 1)
+ return(KRB5_BAD_ENCTYPE);
if ((inkey->length != keylength) ||
(outkey->length != keylength))
return(KRB5_CRYPTO_INTERNAL);
Modified: branches/krb5-1-7/src/lib/crypto/keyed_checksum_types.c
===================================================================
--- branches/krb5-1-7/src/lib/crypto/keyed_checksum_types.c 2010-12-05 20:16:17 UTC (rev 24561)
+++ branches/krb5-1-7/src/lib/crypto/keyed_checksum_types.c 2010-12-06 23:23:17 UTC (rev 24562)
@@ -51,6 +51,16 @@
{
unsigned int i, c;
+ if (enctype == ENCTYPE_ARCFOUR_HMAC ||
+ enctype == ENCTYPE_ARCFOUR_HMAC_EXP) {
+ *count = 2;
+ if ((*cksumtypes = malloc(2*sizeof(krb5_cksumtype))) == NULL)
+ return(ENOMEM);
+ (*cksumtypes)[0] = CKSUMTYPE_HMAC_MD5_ARCFOUR;
+ (*cksumtypes)[1] = CKSUMTYPE_MD5_HMAC_ARCFOUR;
+ return(0);
+ }
+
c = 0;
for (i=0; i<krb5_cksumtypes_length; i++) {
if ((krb5_cksumtypes_list[i].keyhash &&
Modified: branches/krb5-1-7/src/lib/gssapi/krb5/util_crypt.c
===================================================================
--- branches/krb5-1-7/src/lib/gssapi/krb5/util_crypt.c 2010-12-05 20:16:17 UTC (rev 24561)
+++ branches/krb5-1-7/src/lib/gssapi/krb5/util_crypt.c 2010-12-06 23:23:17 UTC (rev 24562)
@@ -109,10 +109,22 @@
if (code != 0)
return code;
- code = (*kaccess.krb5int_c_mandatory_cksumtype)(context, subkey->enctype,
- cksumtype);
- if (code != 0)
- return code;
+ switch (subkey->enctype) {
+ case ENCTYPE_DES_CBC_MD4:
+ *cksumtype = CKSUMTYPE_RSA_MD4_DES;
+ break;
+ case ENCTYPE_DES_CBC_MD5:
+ case ENCTYPE_DES_CBC_CRC:
+ *cksumtype = CKSUMTYPE_RSA_MD5_DES;
+ break;
+ default:
+ code = (*kaccess.krb5int_c_mandatory_cksumtype)(context,
+ subkey->enctype,
+ cksumtype);
+ if (code != 0)
+ return code;
+ break;
+ }
switch (subkey->enctype) {
case ENCTYPE_DES_CBC_MD5:
Modified: branches/krb5-1-7/src/lib/krb5/krb/mk_safe.c
===================================================================
--- branches/krb5-1-7/src/lib/krb5/krb/mk_safe.c 2010-12-05 20:16:17 UTC (rev 24561)
+++ branches/krb5-1-7/src/lib/krb5/krb/mk_safe.c 2010-12-06 23:23:17 UTC (rev 24562)
@@ -213,10 +213,29 @@
for (i = 0; i < nsumtypes; i++)
if (auth_context->safe_cksumtype == sumtypes[i])
break;
- if (i == nsumtypes)
- i = 0;
- sumtype = sumtypes[i];
krb5_free_cksumtypes (context, sumtypes);
+ if (i < nsumtypes)
+ sumtype = auth_context->safe_cksumtype;
+ else {
+ switch (keyblock->enctype) {
+ case ENCTYPE_DES_CBC_MD4:
+ sumtype = CKSUMTYPE_RSA_MD4_DES;
+ break;
+ case ENCTYPE_DES_CBC_MD5:
+ case ENCTYPE_DES_CBC_CRC:
+ sumtype = CKSUMTYPE_RSA_MD5_DES;
+ break;
+ default:
+ retval = krb5int_c_mandatory_cksumtype(context,
+ keyblock->enctype,
+ &sumtype);
+ if (retval) {
+ CLEANUP_DONE();
+ goto error;
+ }
+ break;
+ }
+ }
}
if ((retval = krb5_mk_safe_basic(context, userdata, keyblock, &replaydata,
plocal_fulladdr, premote_fulladdr,
Modified: branches/krb5-1-7/src/lib/krb5/krb/pac.c
===================================================================
--- branches/krb5-1-7/src/lib/krb5/krb/pac.c 2010-12-05 20:16:17 UTC (rev 24561)
+++ branches/krb5-1-7/src/lib/krb5/krb/pac.c 2010-12-06 23:23:17 UTC (rev 24562)
@@ -524,6 +524,8 @@
checksum.checksum_type = load_32_le(p);
checksum.length = checksum_data.length - PAC_SIGNATURE_DATA_LENGTH;
checksum.contents = p + PAC_SIGNATURE_DATA_LENGTH;
+ if (!krb5_c_is_keyed_cksum(checksum.checksum_type))
+ return KRB5KRB_AP_ERR_INAPP_CKSUM;
pac_data.length = pac->data.length;
pac_data.data = malloc(pac->data.length);
Modified: branches/krb5-1-7/src/lib/krb5/krb/preauth2.c
===================================================================
--- branches/krb5-1-7/src/lib/krb5/krb/preauth2.c 2010-12-05 20:16:17 UTC (rev 24561)
+++ branches/krb5-1-7/src/lib/krb5/krb/preauth2.c 2010-12-06 23:23:17 UTC (rev 24562)
@@ -1579,7 +1579,9 @@
cksum = sc2->sam_cksum;
- while (*cksum) {
+ for (; *cksum; cksum++) {
+ if (!krb5_c_is_keyed_cksum((*cksum)->checksum_type))
+ continue;
/* Check this cksum */
retval = krb5_c_verify_checksum(context, as_key,
KRB5_KEYUSAGE_PA_SAM_CHALLENGE_CKSUM,
@@ -1593,7 +1595,6 @@
}
if (valid_cksum)
break;
- cksum++;
}
if (!valid_cksum) {
Modified: branches/krb5-1-7/src/plugins/preauth/pkinit/pkinit_srv.c
===================================================================
--- branches/krb5-1-7/src/plugins/preauth/pkinit/pkinit_srv.c 2010-12-05 20:16:17 UTC (rev 24561)
+++ branches/krb5-1-7/src/plugins/preauth/pkinit/pkinit_srv.c 2010-12-06 23:23:17 UTC (rev 24562)
@@ -664,8 +664,7 @@
krb5_reply_key_pack *key_pack = NULL;
krb5_reply_key_pack_draft9 *key_pack9 = NULL;
krb5_data *encoded_key_pack = NULL;
- unsigned int num_types;
- krb5_cksumtype *cksum_types = NULL;
+ krb5_cksumtype cksum_type;
pkinit_kdc_context plgctx;
pkinit_kdc_req_context reqctx;
@@ -851,14 +850,24 @@
retval = ENOMEM;
goto cleanup;
}
- /* retrieve checksums for a given enctype of the reply key */
- retval = krb5_c_keyed_checksum_types(context,
- encrypting_key->enctype, &num_types, &cksum_types);
- if (retval)
- goto cleanup;
+ switch (encrypting_key->enctype) {
+ case ENCTYPE_DES_CBC_MD4:
+ cksum_type = CKSUMTYPE_RSA_MD4_DES;
+ break;
+ case ENCTYPE_DES_CBC_MD5:
+ case ENCTYPE_DES_CBC_CRC:
+ cksum_type = CKSUMTYPE_RSA_MD5_DES;
+ break;
+ default:
+ retval = krb5int_c_mandatory_cksumtype(context,
+ encrypting_key->enctype,
+ &cksum_type);
+ if (retval)
+ goto cleanup;
+ break;
+ }
- /* pick the first of acceptable enctypes for the checksum */
- retval = krb5_c_make_checksum(context, cksum_types[0],
+ retval = krb5_c_make_checksum(context, cksum_type,
encrypting_key, KRB5_KEYUSAGE_TGS_REQ_AUTH_CKSUM,
req_pkt, &key_pack->asChecksum);
if (retval) {
@@ -1006,8 +1015,6 @@
free(dh_pubkey);
if (server_key != NULL)
free(server_key);
- if (cksum_types != NULL)
- free(cksum_types);
switch ((int)padata->pa_type) {
case KRB5_PADATA_PK_AS_REQ:
More information about the cvs-krb5
mailing list