2020-09-30 17:12:32 +02:00

487 lines
22 KiB
C++

// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1996 - 1999
// File: test.cpp
// Contents: Microsoft Internet Security Authenticode Policy Provider
// Functions: SoftpubDumpStructure
// History: 05-Jun-1997 pberkman created
#include "global.hxx"
#define TEST_POLICY_DUMP_FILE L"C:\\TRUSTPOL.TXT"
void _cdecl FPrintfU(HANDLE hFile, WCHAR *pwszFmt, ...);
void PrintfPFNs(HANDLE hFile, CRYPT_PROVIDER_DATA *pProvData);
void PrintfSignerStruct(HANDLE hFile, CRYPT_PROVIDER_SGNR *pS, int idxSigner, BOOL fCounter, int idxCounter);
void PrintfCertStruct(HANDLE hFile, int cCert, CRYPT_PROVIDER_CERT *pC, int idxCert);
void GetStringDateTime(FILETIME *pFTime, WCHAR *pwszRetTime, WCHAR *pwszRetDate);
WCHAR *GetNameFromBlob(CERT_NAME_BLOB *psNameBlob);
HRESULT WINAPI SoftpubDumpStructure(CRYPT_PROVIDER_DATA *pProvData)
{
HANDLE hFile;
if ((hFile = CreateFileU(TEST_POLICY_DUMP_FILE,
GENERIC_WRITE | GENERIC_READ,
0, // no sharing!!
NULL,
CREATE_ALWAYS,
FILE_ATTRIBUTE_NORMAL,
NULL)) == INVALID_HANDLE_VALUE)
{
return(S_FALSE);
}
WCHAR wszTime[64];
WCHAR wszDate[128];
WCHAR wszGuid[64];
int i, i2, i3;
// CRYPT_PROVIDER_DATA
FPrintfU(hFile, L"CRYPT_PROVIDER_DATA:\r\n");
// WINTRUST_DATA
WINTRUST_DATA *pWT;
pWT = pProvData->pWintrustData;
FPrintfU(hFile, L"+======================================================\r\n");
FPrintfU(hFile, L"+-- pWintrustData:\r\n");
FPrintfU(hFile, L"| |.. cbStruct: %ld\r\n", pWT->cbStruct);
FPrintfU(hFile, L"| |.. pPolicyCallbackData: %p\r\n", pWT->pPolicyCallbackData);
FPrintfU(hFile, L"| |.. dwUIChoice: %ld\r\n", pWT->dwUIChoice);
FPrintfU(hFile, L"| |.. fdRevocationChecks: %ld\r\n", pWT->fdwRevocationChecks);
FPrintfU(hFile, L"| |.. dwUnionChoice: %ld\r\n", pWT->dwUnionChoice);
switch (pWT->dwUnionChoice)
{
case WTD_CHOICE_FILE:
if (!(pWT->pFile) || !(WVT_IS_CBSTRUCT_GT_MEMBEROFFSET(WINTRUST_FILE_INFO, pWT->pFile->cbStruct, hFile)))
{
FPrintfU(hFile, L"| +-- pFile: <<< bad parameter! >>>\r\n");
break;
}
FPrintfU(hFile, L"| +-- pFile:\r\n");
FPrintfU(hFile, L"| |.. cbStruct: %ld\r\n", pWT->pFile->cbStruct);
FPrintfU(hFile, L"| |.. pcwszFilePath: %s\r\n", pWT->pFile->pcwszFilePath);
FPrintfU(hFile, L"| |.. hFile: 0x%p\r\n", pWT->pFile->hFile);
wszGuid[0] = NULL;
if (WVT_IS_CBSTRUCT_GT_MEMBEROFFSET(WINTRUST_FILE_INFO, pWT->pFile->cbStruct, pgKnownSubject) && pWT->pFile->pgKnownSubject)
{
guid2wstr(pWT->pFile->pgKnownSubject, &wszGuid[0]);
}
FPrintfU(hFile, L"| +-- pgKnownSubject: %s\r\n", &wszGuid[0]);
break;
case WTD_CHOICE_CATALOG:
if (!(pWT->pCatalog) || !(WVT_IS_CBSTRUCT_GT_MEMBEROFFSET(WINTRUST_CATALOG_INFO, pWT->pCatalog->cbStruct, hMemberFile)))
{
FPrintfU(hFile, L"| +-- pCatalog: <<< bad parameter! >>>\r\n");
break;
}
FPrintfU(hFile, L"| +-- pCatalog:\r\n");
FPrintfU(hFile, L"| |.. cbStruct: %ld\r\n", pWT->pCatalog->cbStruct);
FPrintfU(hFile, L"| |.. dwCatalogVersion: 0x%lx\r\n", pWT->pCatalog->dwCatalogVersion);
FPrintfU(hFile, L"| |.. pcwszCatalogFilePath: %s\r\n", pWT->pCatalog->pcwszCatalogFilePath);
FPrintfU(hFile, L"| |.. pcwszMemberTag: %s\r\n", pWT->pCatalog->pcwszMemberTag);
FPrintfU(hFile, L"| |.. pcwszMemberFilePath: %s\r\n", pWT->pCatalog->pcwszMemberFilePath);
FPrintfU(hFile, L"| |.. hMemberFile: 0x%p\r\n", pWT->pCatalog->hMemberFile);
FPrintfU(hFile, L"| |.. pbCaclulatedFileHash: ");
for (i = 0; i < (int)pWT->pCatalog->cbCalculatedFileHash; i++)
{
FPrintfU(hFile, L"%02.2X", pWT->pCatalog->pbCalculatedFileHash[i]);
}
FPrintfU(hFile, L"\r\n");
FPrintfU(hFile, L"| +-- cbCaclulatedFileHash: %ld\r\n", pWT->pCatalog->cbCalculatedFileHash);
break;
case WTD_CHOICE_BLOB:
if (!(pWT->pBlob) || !(WVT_IS_CBSTRUCT_GT_MEMBEROFFSET(WINTRUST_BLOB_INFO, pWT->pBlob->cbStruct, pbMemSignedMsg)))
{
FPrintfU(hFile, L"| +-- pBlob: <<< bad parameter! >>>\r\n");
break;
}
FPrintfU(hFile, L"| +-- pBlob:\r\n");
FPrintfU(hFile, L"| |.. cbStruct: %ld\r\n", pWT->pBlob->cbStruct);
wszGuid[0] = NULL;
guid2wstr(&pWT->pBlob->gSubject, &wszGuid[0]);
FPrintfU(hFile, L" |.. gSubject: %s\r\n", &wszGuid[0]);
FPrintfU(hFile, L"| |.. pcwszDisplayName: %s\r\n", pWT->pBlob->pcwszDisplayName);
FPrintfU(hFile, L"| |.. cbMemObject: %ld\r\n", pWT->pBlob->cbMemObject);
FPrintfU(hFile, L"| |.. pbMemObject: 0x%p\r\n", pWT->pBlob->pbMemObject);
FPrintfU(hFile, L"| |.. cbMemSignedMsg: %ld\r\n", pWT->pBlob->cbMemSignedMsg);
FPrintfU(hFile, L"| +.. pbMemSignedMsg: 0x%p\r\n", pWT->pBlob->pbMemSignedMsg);
break;
case WTD_CHOICE_SIGNER:
if (!(pWT->pSgnr) || !(WVT_IS_CBSTRUCT_GT_MEMBEROFFSET(WINTRUST_SGNR_INFO, pWT->pSgnr->cbStruct, pahStores)))
{
FPrintfU(hFile, L"| +-- pSgnr: <<< bad parameter! >>>\r\n");
break;
}
FPrintfU(hFile, L"| +-- pSgnr:\r\n");
FPrintfU(hFile, L"| |.. cbStruct: %ld\r\n", pWT->pSgnr->cbStruct);
FPrintfU(hFile, L"| |.. pcwszDisplayName: %s\r\n", pWT->pSgnr->pcwszDisplayName);
FPrintfU(hFile, L"| |.. psSignerInfo: 0x%p\r\n", pWT->pSgnr->psSignerInfo);
FPrintfU(hFile, L"| |.. chStores: %ld\r\n", pWT->pSgnr->chStores);
for (i = 0; i < (int)pWT->pSgnr->chStores; i++)
{
if (i == (int)(pWT->pSgnr->chStores - 1))
{
FPrintfU(hFile, L"| +.. pahStores[%02.2d]: 0x%p\r\n", i, pWT->pSgnr->pahStores[i]);
}
else
{
FPrintfU(hFile, L"| |.. pahStores[%02.2d]: 0x%p\r\n", i, pWT->pSgnr->pahStores[i]);
}
}
break;
case WTD_CHOICE_CERT:
if (!(pWT->pCert) || !(WVT_IS_CBSTRUCT_GT_MEMBEROFFSET(WINTRUST_CERT_INFO, pWT->pCert->cbStruct, psftVerifyAsOf)))
{
FPrintfU(hFile, L"| +-- pCert: <<< bad parameter! >>>\r\n");
break;
}
FPrintfU(hFile, L"| +-- pCert:\r\n");
FPrintfU(hFile, L"| |.. cbStruct: %ld\r\n", pWT->pCert->cbStruct);
FPrintfU(hFile, L"| |.. pcwszDisplayName: %s\r\n", pWT->pCert->pcwszDisplayName);
FPrintfU(hFile, L"| |.. psCertContext: 0x%p\r\n", pWT->pCert->psCertContext);
FPrintfU(hFile, L"| |.. chStores: %ld\r\n", pWT->pCert->chStores);
for (i = 0; i < (int)pWT->pCert->chStores; i++)
{
FPrintfU(hFile, L"| |.. pahStores[%02.2d]: 0x%p\r\n", i, pWT->pCert->pahStores[i]);
}
FPrintfU(hFile, L"| |.. dwFlags: 0x%08.8lX\r\n", pWT->pCert->dwFlags);
wszTime[0] = NULL;
wszDate[0] = NULL;
if (pWT->pCert->psftVerifyAsOf)
{
GetStringDateTime(pWT->pCert->psftVerifyAsOf, &wszTime[0], &wszDate[0]);
}
FPrintfU(hFile, L"| |-- psftVerifyAsOf: %s - %s\r\n", &wszDate[0], &wszTime[0]);
break;
default:
FPrintfU(hFile, L"| +.. ***Unknown structure type***\r\n");
break;
}
FPrintfU(hFile, L"|.. WndParent: 0x%p\r\n", pProvData->hWndParent);
wszGuid[0] = NULL;
guid2wstr(pProvData->pgActionID, &wszGuid[0]);
FPrintfU(hFile, L"|.. pgActionID: %s\r\n", &wszGuid[0]);
FPrintfU(hFile, L"|.. hProv: 0x%p\r\n", pProvData->hProv);
FPrintfU(hFile, L"|.. dwError: 0x%08.8lx\r\n", pProvData->dwError);
FPrintfU(hFile, L"|.. dwRegSecuritySettings: 0x%08.8lx\r\n", pProvData->dwRegSecuritySettings);
FPrintfU(hFile, L"|.. dwRegPolicySettings: 0x%08.8lx\r\n", pProvData->dwRegPolicySettings);
FPrintfU(hFile, L"|.. dwEncoding: 0x%08.8lx\r\n", pProvData->dwEncoding);
PrintfPFNs(hFile, pProvData);
FPrintfU(hFile, L"|.. padwTrustStepErrors:\r\n");
for (i = 0; i < (int)pProvData->cdwTrustStepErrors; i++)
{
if (i == (int)(pProvData->cdwTrustStepErrors - 1))
{
FPrintfU(hFile, L"| +.. Step[%02.2d]: 0x%08.8lx\r\n", i, pProvData->padwTrustStepErrors[i]);
}
else
{
FPrintfU(hFile, L"| |.. Step[%02.2d]: 0x%08.8lx\r\n", i, pProvData->padwTrustStepErrors[i]);
}
}
FPrintfU(hFile, L"|.. pahStores:\r\n");
for (i = 0; i < (int)pProvData->chStores; i++)
{
if (i == (int)(pProvData->chStores - 1))
{
FPrintfU(hFile, L"| +.. Store[%02.2d]: 0x%lx\r\n", i, pProvData->pahStores[i]);
}
else
{
FPrintfU(hFile, L"| |.. Store[%02.2d]: 0x%lx\r\n", i, pProvData->pahStores[i]);
}
}
FPrintfU(hFile, L"|.. hMsg: 0x%p\r\n", pProvData->hMsg);
if (pProvData->dwSubjectChoice == CPD_CHOICE_SIP)
{
wszGuid[0] = NULL;
guid2wstr(&pProvData->pPDSip->gSubject, &wszGuid[0]);
FPrintfU(hFile, L"|.. pPDSip:\r\n");
FPrintfU(hFile, L"| |.. gSubject: %s\r\n", &wszGuid[0]);
FPrintfU(hFile, L"| |.. pSip: 0x%p\r\n", pProvData->pPDSip->pSip);
FPrintfU(hFile, L"| |.. pCATSip: 0x%p\r\n", pProvData->pPDSip->pCATSip);
// TBDTBD: break it out!
FPrintfU(hFile, L"| |.. psSipSubjectInfo: 0x%p\r\n", pProvData->pPDSip->psSipSubjectInfo);
// TBDTBD: break it out!
FPrintfU(hFile, L"| |.. psSipCATSubjectInfo: 0x%p\r\n", pProvData->pPDSip->psSipCATSubjectInfo);
// TBDTBD: break it out!
FPrintfU(hFile, L"| +.. psIndirectData: 0x%p\r\n", pProvData->pPDSip->psIndirectData);
}
FPrintfU(hFile, L"|.. csSigners: %lu\r\n", pProvData->csSigners);
CRYPT_PROVIDER_SGNR *pSgnr;
CRYPT_PROVIDER_SGNR *pCounterSgnr;
for (i = 0; i < (int)pProvData->csSigners; i++)
{
pSgnr = WTHelperGetProvSignerFromChain(pProvData, i, FALSE, 0);
PrintfSignerStruct(hFile, pSgnr, i, FALSE, 0);
if (pSgnr->csCounterSigners > 0)
{
for (int i2 = 0; i2 < (int)pSgnr->csCounterSigners; i2++)
{
pCounterSgnr = WTHelperGetProvSignerFromChain(pProvData, i, TRUE, i2);
PrintfSignerStruct(hFile, pCounterSgnr, i, TRUE, i2);
}
}
}
FPrintfU(hFile, L"|.. pszUsageOID: %p\r\n", pProvData->pszUsageOID);
FPrintfU(hFile, L"|.. fRecallWithState: %s\r\n", (pProvData->fRecallWithState) ? "TRUE" : "FALSE");
GetStringDateTime(&pProvData->sftSystemTime, &wszTime[0], &wszDate[0]);
FPrintfU(hFile, L"|.. sftSystemTime: %s - %s\r\n", &wszDate[0], &wszTime[0]);
FPrintfU(hFile, L"+======================================================\r\n");
CloseHandle(hFile);
return(S_OK);
}
void PrintfPFNs(HANDLE hFile, CRYPT_PROVIDER_DATA *pPD)
{
FPrintfU(hFile, L"|.. psPfns:\r\n");
if (!(pPD->psPfns) ||
!(WVT_IS_CBSTRUCT_GT_MEMBEROFFSET(CRYPT_PROVIDER_FUNCTIONS, pPD->psPfns->cbStruct, pfnTestFinalPolicy)))
{
FPrintfU(hFile, L"| +.. *** invalid parameter ***\r\n");
return;
}
FPrintfU(hFile, L"| |.. cbStruct: %lu\r\n", pPD->psPfns->cbStruct);
FPrintfU(hFile, L"| |.. pfnAlloc: 0x%p\r\n", pPD->psPfns->pfnAlloc);
FPrintfU(hFile, L"| |.. pfnFree: 0x%p\r\n", pPD->psPfns->pfnFree);
FPrintfU(hFile, L"| |.. pfnAddStore2Chain: 0x%p\r\n", pPD->psPfns->pfnAddStore2Chain);
FPrintfU(hFile, L"| |.. pfnAddSgnr2Chain: 0x%p\r\n", pPD->psPfns->pfnAddSgnr2Chain);
FPrintfU(hFile, L"| |.. pfnAddCert2Chain: 0x%p\r\n", pPD->psPfns->pfnAddCert2Chain);
FPrintfU(hFile, L"| |.. pfnAddPrivData2Chain: 0x%p\r\n", pPD->psPfns->pfnAddPrivData2Chain);
FPrintfU(hFile, L"| |.. pfnInitialize: 0x%p\r\n", pPD->psPfns->pfnInitialize);
FPrintfU(hFile, L"| |.. pfnObjectTrust: 0x%p\r\n", pPD->psPfns->pfnObjectTrust);
FPrintfU(hFile, L"| |.. pfnSignatureTrust: 0x%p\r\n", pPD->psPfns->pfnSignatureTrust);
FPrintfU(hFile, L"| |.. pfnCertificateTrust: 0x%p\r\n", pPD->psPfns->pfnCertificateTrust);
FPrintfU(hFile, L"| |.. pfnFinalPolicy: 0x%p\r\n", pPD->psPfns->pfnFinalPolicy);
FPrintfU(hFile, L"| |.. pfnCertCheckPolicy: 0x%p\r\n", pPD->psPfns->pfnCertCheckPolicy);
FPrintfU(hFile, L"| |.. pfnTestFinalPolicy: 0x%p\r\n", pPD->psPfns->pfnTestFinalPolicy);
if (WVT_IS_CBSTRUCT_GT_MEMBEROFFSET(CRYPT_PROVIDER_FUNCTIONS, pPD->psPfns->cbStruct, pfnCleanupPolicy))
{
FPrintfU(hFile, L"| |.. pfnCleanupPolicy: 0x%p\r\n", pPD->psPfns->pfnCleanupPolicy);
}
FPrintfU(hFile, L"| +.. psUIpfns:\r\n");
if (!(pPD->psPfns->psUIpfns) || !(WVT_IS_CBSTRUCT_GT_MEMBEROFFSET(CRYPT_PROVUI_FUNCS, pPD->psPfns->psUIpfns->cbStruct, pfnOnAdvancedClickDefault)))
{
FPrintfU(hFile, L"| +.. *** invalid parameter ***\r\n");
return;
}
FPrintfU(hFile, L"| |.. cbStruct: %lu\r\n", pPD->psPfns->psUIpfns->cbStruct);
FPrintfU(hFile, L"| |.. psUIData:\r\n");
if (!(pPD->psPfns->psUIpfns->psUIData) || !(WVT_IS_CBSTRUCT_GT_MEMBEROFFSET(CRYPT_PROVUI_DATA, pPD->psPfns->psUIpfns->psUIData->cbStruct, pCopyActionTextNotSigned)))
{
FPrintfU(hFile, L"| | +.. *** invalid parameter ***\r\n");
}
else
{
FPrintfU(hFile, L"| | |.. cbStruct: %lu\r\n", pPD->psPfns->psUIpfns->psUIData->cbStruct);
FPrintfU(hFile, L"| | |.. dwFinalError: 0x%08.8lx\r\n", pPD->psPfns->psUIpfns->psUIData->dwFinalError);
FPrintfU(hFile, L"| | |.. pYesButtonText: %s\r\n", pPD->psPfns->psUIpfns->psUIData->pYesButtonText);
FPrintfU(hFile, L"| | |.. pNoButtonText: %s\r\n", pPD->psPfns->psUIpfns->psUIData->pNoButtonText);
FPrintfU(hFile, L"| | |.. pMoreInfoButtonText: %s\r\n", pPD->psPfns->psUIpfns->psUIData->pMoreInfoButtonText);
FPrintfU(hFile, L"| | |.. pAdvancedLinkText: %s\r\n", pPD->psPfns->psUIpfns->psUIData->pAdvancedLinkText);
FPrintfU(hFile, L"| | |.. pCopyActionText: %s\r\n", pPD->psPfns->psUIpfns->psUIData->pCopyActionText);
FPrintfU(hFile, L"| | |.. pCopyActionTextNoTS: %s\r\n", pPD->psPfns->psUIpfns->psUIData->pCopyActionTextNoTS);
FPrintfU(hFile, L"| | |.. pCopyActionTextNotSigned: %s\r\n", pPD->psPfns->psUIpfns->psUIData->pCopyActionTextNotSigned);
}
FPrintfU(hFile, L"| |.. pfnOnMoreInfoClick: 0x%p\r\n", pPD->psPfns->psUIpfns->pfnOnMoreInfoClick);
FPrintfU(hFile, L"| |.. pfnOnMoreInfoClickDefault:0x%p\r\n", pPD->psPfns->psUIpfns->pfnOnMoreInfoClickDefault);
FPrintfU(hFile, L"| |.. pfnOnAdvancedClick: 0x%p\r\n", pPD->psPfns->psUIpfns->pfnOnAdvancedClick);
FPrintfU(hFile, L"| +.. pfnOnAdvancedClickDefault:0x%p\r\n", pPD->psPfns->psUIpfns->pfnOnAdvancedClickDefault);
}
void PrintfSignerStruct(HANDLE hFile, CRYPT_PROVIDER_SGNR *pS, int idxSigner, BOOL fCounter, int idxCounter)
{
if (!(fCounter))
{
FPrintfU(hFile, L"|.. pasSigners[%d]:\r\n", idxSigner);
}
else
{
FPrintfU(hFile, L"|.. pasSigners[%d] - CounterSigner[%d]:\r\n", idxSigner, idxCounter);
}
FPrintfU(hFile, L"| |.. cbStruct: %lu\r\n", pS->cbStruct);
WCHAR wszTime[64];
WCHAR wszDate[128];
GetStringDateTime(&pS->sftVerifyAsOf, &wszTime[0], &wszDate[0]);
FPrintfU(hFile, L"| |.. sftVerifyAsOf: %s - %s\r\n", &wszDate[0], &wszTime[0]);
FPrintfU(hFile, L"| |.. dwSignerType: 0x%08.8lX\r\n", pS->dwSignerType);
FPrintfU(hFile, L"| |.. csCertChain: %lu\r\n", pS->csCertChain);
CRYPT_PROVIDER_CERT *pCert;
for (int i = 0; i < (int)pS->csCertChain; i++)
{
pCert = WTHelperGetProvCertFromChain(pS, i);
PrintfCertStruct(hFile, pS->csCertChain, pCert, i);
}
FPrintfU(hFile, L"| |.. psSigner: 0x%p\r\n", pS->psSigner);
FPrintfU(hFile, L"| |.. dwError: 0x%08.8lx\r\n", pS->dwError);
FPrintfU(hFile, L"| +.. csCounterSigners: %ld\r\n", pS->csCounterSigners);
}
void PrintfCertStruct(HANDLE hFile, int cCert, CRYPT_PROVIDER_CERT *pC, int idxCert)
{
WCHAR wszTime[64];
WCHAR wszDate[128];
if (idxCert < (cCert - 1))
{
FPrintfU(hFile, L"| | |.. casCertChain[%d]:\r\n", idxCert);
}
else
{
FPrintfU(hFile, L"| | +.. casCertChain[%d]:\r\n", idxCert);
}
FPrintfU(hFile, L"| | | |.. cbStruct: %ld\r\n", pC->cbStruct);
FPrintfU(hFile, L"| | | |.. pCert: 0x%p\r\n", pC->pCert);
FPrintfU(hFile, L"| | | | |.. dwCertEncoding: 0x%08.8lx\r\n", pC->pCert->dwCertEncodingType);
FPrintfU(hFile, L"| | | | |.. pCertInfo:\r\n");
FPrintfU(hFile, L"| | | | | |.. Issuer: %s\r\n", GetNameFromBlob(&pC->pCert->pCertInfo->Issuer));
GetStringDateTime(&pC->pCert->pCertInfo->NotBefore, &wszTime[0], &wszDate[0]);
FPrintfU(hFile, L"| | | | | |.. NotBefore: %s - %s\r\n", &wszDate[0], &wszTime[0]);
GetStringDateTime(&pC->pCert->pCertInfo->NotAfter, &wszTime[0], &wszDate[0]);
FPrintfU(hFile, L"| | | | | |.. NotAfter: %s - %s\r\n", &wszDate[0], &wszTime[0]);
FPrintfU(hFile, L"| | | | | +.. Subject: %s\r\n", GetNameFromBlob(&pC->pCert->pCertInfo->Subject));
FPrintfU(hFile, L"| | | | +.. hCertStore: 0x%p\r\n", pC->pCert->hCertStore);
FPrintfU(hFile, L"| | | |.. fCommercial: %s\r\n", (pC->fCommercial) ? L"True" : L"False");
FPrintfU(hFile, L"| | | |.. fTrustedRoot: %s\r\n", (pC->fTrustedRoot) ? L"True" : L"False");
FPrintfU(hFile, L"| | | |.. fSelfSigned: %s\r\n", (pC->fSelfSigned) ? L"True" : L"False");
FPrintfU(hFile, L"| | | |.. fTestCert: %s\r\n", (pC->fTestCert) ? L"True" : L"False");
FPrintfU(hFile, L"| | | |.. dwRevokedReason: 0x%08.8lx\r\n", pC->dwRevokedReason);
FPrintfU(hFile, L"| | | |.. dwConfidence: 0x%08.8lx\r\n", pC->dwConfidence);
FPrintfU(hFile, L"| | | |.. pTrustListContext: 0x%p\r\n", pC->pTrustListContext);
if (idxCert == (cCert - 1))
{
FPrintfU(hFile, L"| | +-- +.. dwError: 0x%08.8lx\r\n", pC->dwError);
}
else
{
FPrintfU(hFile, L"| | | +.. dwError: 0x%08.8lx\r\n", pC->dwError);
}
}
void _cdecl FPrintfU(HANDLE hFile, WCHAR *pwszFmt, ...)
{
va_list vaArgs;
WCHAR wsz[2048];
char sz[2048];
DWORD cbWritten;
DWORD cbConv;
va_start(vaArgs, pwszFmt);
vswprintf(&wsz[0], pwszFmt, vaArgs);
va_end(vaArgs);
cbConv = 2048;
cbConv = WideCharToMultiByte(0, 0, &wsz[0], wcslen(&wsz[0]) + 1, &sz[0], cbConv, NULL, NULL);
sz[cbConv] = NULL;
cbWritten = 0;
WriteFile(hFile, &sz[0], cbConv, &cbWritten, NULL);
}
void GetStringDateTime(FILETIME *pFTime, WCHAR *pwszRetTime, WCHAR *pwszRetDate)
{
SYSTEMTIME sSysTime;
char szTime[128];
char szDate[128];
memset(&sSysTime, 0x00, sizeof(SYSTEMTIME));
FileTimeToSystemTime(pFTime, &sSysTime);
szTime[0] = 0;
GetTimeFormat(LOCALE_USER_DEFAULT, TIME_FORCE24HOURFORMAT, &sSysTime, NULL, &szTime[0], 64);
MultiByteToWideChar(CP_ACP, 0, (const char *)&szTime[0], -1, pwszRetTime, 64);
szDate[0] = 0;
GetDateFormat(LOCALE_USER_DEFAULT, 0, &sSysTime, TEXT("dd'-'MMM'-'yyyy"), &szDate[0], 128);
MultiByteToWideChar(CP_ACP, 0, (const char *)&szDate[0], -1, pwszRetDate, 128);
}
WCHAR *GetNameFromBlob(CERT_NAME_BLOB *psNameBlob)
{
static WCHAR wsz[256];
PCERT_NAME_INFO pNameInfo;
PCERT_RDN_ATTR pRDNAttr;
DWORD cbInfo;
cbInfo = 0;
wsz[0] = NULL;
CryptDecodeObject(X509_ASN_ENCODING, X509_NAME, psNameBlob->pbData, psNameBlob->cbData, 0, NULL, &cbInfo);
if (cbInfo > 0)
{
if (pNameInfo = (PCERT_NAME_INFO)new BYTE[cbInfo])
{
if (CryptDecodeObject(X509_ASN_ENCODING, X509_NAME, psNameBlob->pbData, psNameBlob->cbData, 0, pNameInfo, &cbInfo))
{
if (pRDNAttr = CertFindRDNAttr(szOID_COMMON_NAME, pNameInfo))
{
CertRDNValueToStrW(pRDNAttr->dwValueType, &pRDNAttr->Value, wsz, 256);;
}
}
delete pNameInfo;
}
}
return(&wsz[0]);
}