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