diff options
author | Hakan Olsson <ho@cvs.openbsd.org> | 2002-08-29 12:13:20 +0000 |
---|---|---|
committer | Hakan Olsson <ho@cvs.openbsd.org> | 2002-08-29 12:13:20 +0000 |
commit | aa66476eca65abcd7c7db7fb6a360b9307a2b3a1 (patch) | |
tree | 7e4865f49a600a60b7006260b7e5f788af69c92f | |
parent | c9b8b28584f89b977533d3a74c7c7291e0873bba (diff) |
Work around arguably correct OpenSSL behaviour and only ask for CRL
checks when we actually have CRLs to check against. Problem pointed
out by <sturm@sec.informatik.tu-darmstadt.de>.
-rw-r--r-- | sbin/isakmpd/x509.c | 26 |
1 files changed, 21 insertions, 5 deletions
diff --git a/sbin/isakmpd/x509.c b/sbin/isakmpd/x509.c index db314a4708b..87fe812d199 100644 --- a/sbin/isakmpd/x509.c +++ b/sbin/isakmpd/x509.c @@ -1,4 +1,4 @@ -/* $OpenBSD: x509.c,v 1.74 2002/08/07 13:19:20 ho Exp $ */ +/* $OpenBSD: x509.c,v 1.75 2002/08/29 12:13:19 ho Exp $ */ /* $EOM: x509.c,v 1.54 2001/01/16 18:42:16 ho Exp $ */ /* @@ -844,8 +844,20 @@ x509_read_crls_from_dir (X509_STORE *ctx, char *name) } if (!X509_STORE_add_crl (ctx, crl)) - LOG_DBG ((LOG_CRYPTO, 50, "x509_read_crls_from_dir: " - "X509_STORE_add_crl failed for %s", file->d_name)); + { + LOG_DBG ((LOG_CRYPTO, 50, "x509_read_crls_from_dir: " + "X509_STORE_add_crl failed for %s", file->d_name)); + continue; + } + + /* + * XXX This is to make x509_cert_validate set this (and another) flag + * XXX when validating certificates. Currently, OpenSSL defaults to + * XXX reject an otherwise valid certificate (chain) if these flags + * XXX are set but there are no CRLs to check. The current workaround + * XXX is to only set the flags if we actually loaded some CRL data. + */ + X509_STORE_set_flags (ctx, X509_V_FLAG_CRL_CHECK); } closedir (dir); @@ -966,8 +978,12 @@ x509_cert_validate (void *scert) */ X509_STORE_CTX_init (&csc, x509_cas, cert, NULL); #if OPENSSL_VERSION_NUMBER >= 0x00907000L - X509_STORE_CTX_set_flags (&csc, X509_V_FLAG_CRL_CHECK); - X509_STORE_CTX_set_flags (&csc, X509_V_FLAG_CRL_CHECK_ALL); + /* XXX See comment in x509_read_crls_from_dir. */ + if (x509_cas->flags & X509_V_FLAG_CRL_CHECK) + { + X509_STORE_CTX_set_flags (&csc, X509_V_FLAG_CRL_CHECK); + X509_STORE_CTX_set_flags (&csc, X509_V_FLAG_CRL_CHECK_ALL); + } #endif res = X509_verify_cert (&csc); err = csc.error; |