Don't try and verify signatures if key is NULL (CVE-2013-0166)

Add additional check to catch this in ASN1_item_verify too.
(cherry picked from commit 66e8211c0b)
This commit is contained in:
Dr. Stephen Henson 2013-01-24 13:30:42 +00:00
parent 5a49001bde
commit b48310627d
3 changed files with 16 additions and 3 deletions

View File

@ -2038,6 +2038,10 @@
This fixes a DoS attack. (CVE-2013-0166) This fixes a DoS attack. (CVE-2013-0166)
[Steve Henson] [Steve Henson]
*) Return an error when checking OCSP signatures when key is NULL.
This fixes a DoS attack. (CVE-2013-0166)
[Steve Henson]
*) Call OCSP Stapling callback after ciphersuite has been chosen, so *) Call OCSP Stapling callback after ciphersuite has been chosen, so
the right response is stapled. Also change SSL_get_certificate() the right response is stapled. Also change SSL_get_certificate()
so it returns the certificate actually sent. so it returns the certificate actually sent.

View File

@ -140,6 +140,12 @@ int ASN1_item_verify(const ASN1_ITEM *it, X509_ALGOR *a,
int mdnid, pknid; int mdnid, pknid;
if (!pkey)
{
ASN1err(ASN1_F_ASN1_ITEM_VERIFY, ERR_R_PASSED_NULL_PARAMETER);
return -1;
}
EVP_MD_CTX_init(&ctx); EVP_MD_CTX_init(&ctx);
/* Convert signature OID into digest and public key OIDs */ /* Convert signature OID into digest and public key OIDs */

View File

@ -91,9 +91,12 @@ int OCSP_basic_verify(OCSP_BASICRESP *bs, STACK_OF(X509) *certs,
{ {
EVP_PKEY *skey; EVP_PKEY *skey;
skey = X509_get_pubkey(signer); skey = X509_get_pubkey(signer);
if (skey)
{
ret = OCSP_BASICRESP_verify(bs, skey, 0); ret = OCSP_BASICRESP_verify(bs, skey, 0);
EVP_PKEY_free(skey); EVP_PKEY_free(skey);
if(ret <= 0) }
if(!skey || ret <= 0)
{ {
OCSPerr(OCSP_F_OCSP_BASIC_VERIFY, OCSP_R_SIGNATURE_FAILURE); OCSPerr(OCSP_F_OCSP_BASIC_VERIFY, OCSP_R_SIGNATURE_FAILURE);
goto end; goto end;