mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
109 lines
2.8 KiB
109 lines
2.8 KiB
//+-------------------------------------------------------------------------
|
|
//
|
|
// Microsoft Windows
|
|
//
|
|
// Copyright (C) Microsoft Corporation, 1996 - 1999
|
|
//
|
|
// File: chains.cpp
|
|
//
|
|
// Contents: Microsoft Internet Security Trust Provider
|
|
//
|
|
// Functions: AddToSignerChain
|
|
// AddToCertChain
|
|
// AddToStoreChain
|
|
// AllocateNewChain
|
|
// DeallocateCertChain
|
|
// DeallocateStoreChain
|
|
//
|
|
// History: 29-May-1997 pberkman created
|
|
//
|
|
//--------------------------------------------------------------------------
|
|
|
|
#include "global.hxx"
|
|
|
|
|
|
BOOL AddToSignerChain(CRYPT_PROVIDER_SGNR *psSgnr2Add, DWORD *pcSgnrs, CRYPT_PROVIDER_SGNR **ppSgnrChain)
|
|
{
|
|
return(AllocateNewChain(sizeof(CRYPT_PROVIDER_SGNR), psSgnr2Add, pcSgnrs, (void **)ppSgnrChain,
|
|
psSgnr2Add->cbStruct));
|
|
}
|
|
|
|
BOOL AddToCertChain(CRYPT_PROVIDER_CERT *pPCert2Add, DWORD *pcPCerts,
|
|
CRYPT_PROVIDER_CERT **ppPCertChain)
|
|
{
|
|
return(AllocateNewChain(sizeof(CRYPT_PROVIDER_CERT), pPCert2Add, pcPCerts, (void **)ppPCertChain,
|
|
pPCert2Add->cbStruct));
|
|
}
|
|
|
|
BOOL AddToStoreChain(HCERTSTORE hStore2Add, DWORD *pcChain, HCERTSTORE **pphStoreChain)
|
|
{
|
|
return(AllocateNewChain(sizeof(HCERTSTORE), (void *)&hStore2Add, pcChain, (void **)pphStoreChain,
|
|
sizeof(HCERTSTORE)));
|
|
}
|
|
|
|
|
|
BOOL AllocateNewChain(DWORD cbMember, void *pNewMember, DWORD *pcChain, void **ppChain, DWORD cbAssumeSize)
|
|
{
|
|
void *pNewChain;
|
|
DWORD cNew;
|
|
|
|
if (cbAssumeSize > cbMember)
|
|
{
|
|
//
|
|
// the client is using structures more current that we are...
|
|
//
|
|
SetLastError(ERROR_INVALID_PARAMETER);
|
|
return(FALSE);
|
|
}
|
|
|
|
cNew = *pcChain + 1;
|
|
|
|
if (!(pNewChain = (void *)WVTNew(cbMember * cNew)))
|
|
{
|
|
return(FALSE);
|
|
}
|
|
|
|
memset(pNewChain, 0x00, cbMember * cNew);
|
|
|
|
for (int i = 0; i < (int)*pcChain; i++)
|
|
{
|
|
memcpy((char *)pNewChain + (i * cbMember), (char *)*ppChain + (i * cbMember), cbMember);
|
|
}
|
|
|
|
DELETE_OBJECT(*ppChain);
|
|
|
|
memcpy((char *)pNewChain + ((cNew - 1) * cbMember), pNewMember, cbAssumeSize);
|
|
|
|
*ppChain = pNewChain;
|
|
*pcChain = cNew;
|
|
|
|
return(TRUE);
|
|
}
|
|
|
|
void DeallocateCertChain(DWORD csPCert, CRYPT_PROVIDER_CERT **pasPCertChain)
|
|
{
|
|
CRYPT_PROVIDER_CERT *pas;
|
|
|
|
pas = *pasPCertChain;
|
|
|
|
for (int i = 0; i < (int)csPCert; i++)
|
|
{
|
|
if (pas[i].pCert)
|
|
{
|
|
CertFreeCertificateContext(pas[i].pCert);
|
|
}
|
|
|
|
if (pas[i].pTrustListContext)
|
|
{
|
|
CertFreeCTLContext(pas[i].pTrustListContext);
|
|
}
|
|
}
|
|
}
|
|
|
|
void DeallocateStoreChain(DWORD csStore, HCERTSTORE *pphStoreChain)
|
|
{
|
|
for (int i = 0; i < (int)csStore; i++)
|
|
{
|
|
CertCloseStore(pphStoreChain[i], 0);
|
|
}
|
|
}
|