From 2e652776953243c5ca8435f5be0bfe56147cc8c8 Mon Sep 17 00:00:00 2001 From: "Dr. Stephen Henson" Date: Fri, 14 Dec 2012 14:31:16 +0000 Subject: [PATCH] Use new partial chain flag instead of modifying input parameters. (backport from HEAD) --- crypto/ocsp/ocsp_vfy.c | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/crypto/ocsp/ocsp_vfy.c b/crypto/ocsp/ocsp_vfy.c index 214b4020fe..2f7f59c59a 100644 --- a/crypto/ocsp/ocsp_vfy.c +++ b/crypto/ocsp/ocsp_vfy.c @@ -111,14 +111,13 @@ int OCSP_basic_verify(OCSP_BASICRESP *bs, STACK_OF(X509) *certs, */ if (chain == certs) goto verified_chain; - /* If we trust some "other" certificates, mark them as - * explicitly trusted (because some of them might be + /* If we trust some "other" certificates, allow partial + * chains (because some of them might be * Intermediate CA Certificates), put them in a store and * attempt to build a trusted chain. */ if ((flags & OCSP_TRUSTOTHER) && (certs != NULL)) { - ASN1_OBJECT *objtmp = OBJ_nid2obj(NID_OCSP_sign); tmpstore = X509_STORE_new(); if (!tmpstore) { @@ -129,7 +128,6 @@ int OCSP_basic_verify(OCSP_BASICRESP *bs, STACK_OF(X509) *certs, for (i = 0; i < sk_X509_num(certs); i++) { X509 *xother = sk_X509_value(certs, i); - X509_add1_trust_object(xother, objtmp); if (!X509_STORE_add_cert(tmpstore, xother)) { ret = -1; @@ -145,6 +143,7 @@ int OCSP_basic_verify(OCSP_BASICRESP *bs, STACK_OF(X509) *certs, goto end; } X509_STORE_CTX_set_purpose(&ctx, X509_PURPOSE_OCSP_HELPER); + X509_STORE_CTX_set_flags(&ctx, X509_V_FLAG_PARTIAL_CHAIN); ret = X509_verify_cert(&ctx); if (ret == 1) { -- 2.40.0