Fix alternate chains certificate forgery issue
authorMatt Caswell <matt@openssl.org>
Wed, 24 Jun 2015 14:55:36 +0000 (15:55 +0100)
committerMatt Caswell <matt@openssl.org>
Tue, 7 Jul 2015 20:57:11 +0000 (21:57 +0100)
During certificate verfification, OpenSSL will attempt to find an
alternative certificate chain if the first attempt to build such a chain
fails. An error in the implementation of this logic can mean that an
attacker could cause certain checks on untrusted certificates to be
bypassed, such as the CA flag, enabling them to use a valid leaf
certificate to act as a CA and "issue" an invalid certificate.

This occurs where at least one cert is added to the first chain from the
trust store, but that chain still ends up being untrusted. In that case
ctx->last_untrusted is decremented in error.

Patch provided by the BoringSSL project.

CVE-2015-1793

Reviewed-by: Stephen Henson <steve@openssl.org>
crypto/x509/x509_vfy.c

index a920ea70b1500a59a355a5e52cdaad48fd40fa25..7a7fc59e779514e951f25e9e7f80099ba417535d 100644 (file)
@@ -392,8 +392,8 @@ int X509_verify_cert(X509_STORE_CTX *ctx)
                         xtmp = sk_X509_pop(ctx->chain);
                         X509_free(xtmp);
                         num--;
-                        ctx->last_untrusted--;
                     }
+                    ctx->last_untrusted = sk_X509_num(ctx->chain);
                     retry = 1;
                     break;
                 }