crypt32(3/5): Pass subject's info status when adding an issuer to a
chain
Juan Lang
juan.lang at gmail.com
Tue Sep 11 14:54:14 CDT 2007
--Juan
-------------- next part --------------
From a41a08c9e6a2a88197ae1068c9d133ac6193db1e Mon Sep 17 00:00:00 2001
From: Juan Lang <juan.lang at gmail.com>
Date: Tue, 11 Sep 2007 12:48:24 -0700
Subject: [PATCH] Pass subject's info status when adding an issuer to a chain
---
dlls/crypt32/chain.c | 11 +++++++----
1 files changed, 7 insertions(+), 4 deletions(-)
diff --git a/dlls/crypt32/chain.c b/dlls/crypt32/chain.c
index 41202c2..ee95272 100644
--- a/dlls/crypt32/chain.c
+++ b/dlls/crypt32/chain.c
@@ -279,7 +279,7 @@ static inline void CRYPT_CombineTrustSta
}
static BOOL CRYPT_AddCertToSimpleChain(PCertificateChainEngine engine,
- PCERT_SIMPLE_CHAIN chain, PCCERT_CONTEXT cert)
+ PCERT_SIMPLE_CHAIN chain, PCCERT_CONTEXT cert, DWORD subjectInfoStatus)
{
BOOL ret = FALSE;
PCERT_CHAIN_ELEMENT element = CryptMemAlloc(sizeof(CERT_CHAIN_ELEMENT));
@@ -297,6 +297,9 @@ static BOOL CRYPT_AddCertToSimpleChain(P
memset(element, 0, sizeof(CERT_CHAIN_ELEMENT));
element->cbSize = sizeof(CERT_CHAIN_ELEMENT);
element->pCertContext = CertDuplicateCertificateContext(cert);
+ if (chain->cElement > 1)
+ chain->rgpElement[chain->cElement - 2]->TrustStatus.dwInfoStatus
+ = subjectInfoStatus;
/* FIXME: initialize the rest of element */
if (chain->cElement % engine->CycleDetectionModulus)
CRYPT_CheckSimpleChainForCycles(chain);
@@ -632,7 +635,7 @@ static BOOL CRYPT_BuildSimpleChain(PCert
if (issuer)
{
- ret = CRYPT_AddCertToSimpleChain(engine, chain, issuer);
+ ret = CRYPT_AddCertToSimpleChain(engine, chain, issuer, 0);
cert = issuer;
}
else
@@ -658,7 +661,7 @@ static BOOL CRYPT_GetSimpleChainForCert(
{
memset(chain, 0, sizeof(CERT_SIMPLE_CHAIN));
chain->cbSize = sizeof(CERT_SIMPLE_CHAIN);
- ret = CRYPT_AddCertToSimpleChain(engine, chain, cert);
+ ret = CRYPT_AddCertToSimpleChain(engine, chain, cert, 0);
if (ret)
{
ret = CRYPT_BuildSimpleChain(engine, world, chain);
@@ -909,7 +912,7 @@ static PCertificateChain CRYPT_BuildAlte
if (alternate)
{
BOOL ret = CRYPT_AddCertToSimpleChain(engine,
- alternate->context.rgpChain[i], alternateIssuer);
+ alternate->context.rgpChain[i], alternateIssuer, 0);
if (ret)
{
--
1.4.1
More information about the wine-patches
mailing list