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.
200 lines
4.6 KiB
200 lines
4.6 KiB
//+-------------------------------------------------------------------------
|
|
//
|
|
// Microsoft Windows
|
|
//
|
|
// Copyright (C) Microsoft Corporation, 1999 - 1999
|
|
//
|
|
// File: cspelog.cpp
|
|
//
|
|
// Contents: implements policy and exit module logging routines.
|
|
//
|
|
//--------------------------------------------------------------------------
|
|
|
|
#include <pch.cpp>
|
|
|
|
#pragma hdrstop
|
|
|
|
#include "csdisp.h"
|
|
|
|
#define __dwFILE__ __dwFILE_CERTLIB_CSPELOG_CPP__
|
|
|
|
|
|
HRESULT
|
|
SetModuleErrorInfo(
|
|
IN ICreateErrorInfo *pCreateErrorInfo)
|
|
{
|
|
HRESULT hr;
|
|
IErrorInfo *pErrorInfo = NULL;
|
|
|
|
hr = pCreateErrorInfo->QueryInterface(
|
|
IID_IErrorInfo,
|
|
(VOID **) &pErrorInfo);
|
|
_JumpIfError(hr, error, "QueryInterface");
|
|
|
|
hr = SetErrorInfo(0, pErrorInfo);
|
|
_JumpIfError(hr, error, "SetErrorInfo");
|
|
|
|
error:
|
|
if (NULL != pErrorInfo)
|
|
{
|
|
pErrorInfo->Release();
|
|
}
|
|
return(hr);
|
|
}
|
|
|
|
|
|
HRESULT
|
|
LogModuleStatus(
|
|
IN HMODULE hModule,
|
|
IN HRESULT hrMsg,
|
|
IN DWORD dwLogID, // Resource ID of log string
|
|
IN BOOL fPolicy,
|
|
IN WCHAR const *pwszSource,
|
|
IN WCHAR const * const *ppwszInsert, // array of insert strings
|
|
OPTIONAL OUT ICreateErrorInfo **ppCreateErrorInfo)
|
|
{
|
|
HRESULT hr;
|
|
WCHAR *pwszResult = NULL;
|
|
ICreateErrorInfo *pCreateErrorInfo = NULL;
|
|
|
|
if (NULL != ppCreateErrorInfo)
|
|
{
|
|
*ppCreateErrorInfo = NULL;
|
|
}
|
|
if (0 == FormatMessage(
|
|
FORMAT_MESSAGE_ALLOCATE_BUFFER |
|
|
FORMAT_MESSAGE_ARGUMENT_ARRAY |
|
|
FORMAT_MESSAGE_FROM_HMODULE,
|
|
hModule,
|
|
dwLogID,
|
|
0,
|
|
(WCHAR *) &pwszResult,
|
|
0,
|
|
(va_list *) ppwszInsert))
|
|
{
|
|
hr = myHLastError();
|
|
_JumpError(hr, error, "FormatMessage");
|
|
}
|
|
|
|
hr = CreateErrorInfo(&pCreateErrorInfo);
|
|
_JumpIfError(hr, error, "CreateErrorInfo");
|
|
|
|
hr = pCreateErrorInfo->SetGUID(fPolicy? IID_ICertPolicy : IID_ICertExit);
|
|
_PrintIfError(hr, "SetGUID");
|
|
|
|
if (S_OK != hrMsg)
|
|
{
|
|
WCHAR wszhr[cwcDWORDSPRINTF];
|
|
|
|
wsprintf(wszhr, L"0x%x", hrMsg);
|
|
hr = myPrependString(wszhr, L", ", &pwszResult);
|
|
_PrintIfError(hr, "myPrependString");
|
|
}
|
|
DBGPRINT((
|
|
fPolicy? DBG_SS_CERTPOL : DBG_SS_CERTEXIT,
|
|
"LogModuleStatus(%ws): %ws\n",
|
|
pwszSource,
|
|
pwszResult));
|
|
|
|
hr = pCreateErrorInfo->SetDescription(pwszResult);
|
|
_PrintIfError(hr, "SetDescription");
|
|
|
|
// Set ProgId:
|
|
|
|
hr = pCreateErrorInfo->SetSource(const_cast<WCHAR *>(pwszSource));
|
|
_PrintIfError(hr, "SetSource");
|
|
|
|
if (NULL != ppCreateErrorInfo)
|
|
{
|
|
*ppCreateErrorInfo = pCreateErrorInfo;
|
|
pCreateErrorInfo = NULL;
|
|
}
|
|
else
|
|
{
|
|
hr = SetModuleErrorInfo(pCreateErrorInfo);
|
|
_JumpIfError(hr, error, "SetModuleErrorInfo");
|
|
}
|
|
hr = S_OK;
|
|
|
|
error:
|
|
if (NULL != pwszResult)
|
|
{
|
|
LocalFree(pwszResult);
|
|
}
|
|
if (NULL != pCreateErrorInfo)
|
|
{
|
|
pCreateErrorInfo->Release();
|
|
}
|
|
return(hr);
|
|
}
|
|
|
|
|
|
HRESULT
|
|
LogPolicyEvent(
|
|
IN HMODULE hModule,
|
|
IN HRESULT hrMsg,
|
|
IN DWORD dwLogID, // Resource ID of log string
|
|
IN ICertServerPolicy *pServer,
|
|
IN WCHAR const *pwszPropEvent,
|
|
IN WCHAR const * const *ppwszInsert) // array of insert strings
|
|
{
|
|
HRESULT hr;
|
|
WCHAR *pwszValue = NULL;
|
|
BSTR strName = NULL;
|
|
VARIANT varValue;
|
|
|
|
if (0 == FormatMessage(
|
|
FORMAT_MESSAGE_ALLOCATE_BUFFER |
|
|
FORMAT_MESSAGE_ARGUMENT_ARRAY |
|
|
FORMAT_MESSAGE_FROM_HMODULE,
|
|
hModule,
|
|
dwLogID,
|
|
0,
|
|
(WCHAR *) &pwszValue,
|
|
0,
|
|
(va_list *) ppwszInsert))
|
|
{
|
|
hr = myHLastError();
|
|
_JumpError(hr, error, "FormatMessage");
|
|
}
|
|
DBGPRINT((DBG_SS_CERTPOL, "LogPolicyEvent: %ws\n", pwszValue));
|
|
|
|
varValue.vt = VT_EMPTY;
|
|
|
|
if (!myConvertWszToBstr(&strName, pwszPropEvent, -1))
|
|
{
|
|
hr = E_OUTOFMEMORY;
|
|
_JumpError(hr, error, "myConvertWszToBstr");
|
|
}
|
|
|
|
if (S_OK != hrMsg)
|
|
{
|
|
WCHAR wszhr[cwcDWORDSPRINTF];
|
|
|
|
wsprintf(wszhr, L"0x%x", hrMsg);
|
|
hr = myPrependString(wszhr, L",", &pwszValue);
|
|
_PrintIfError(hr, "myPrependString");
|
|
}
|
|
varValue.bstrVal = NULL;
|
|
if (!myConvertWszToBstr(&varValue.bstrVal, pwszValue, -1))
|
|
{
|
|
hr = E_OUTOFMEMORY;
|
|
_JumpError(hr, error, "myConvertWszToBstr");
|
|
}
|
|
varValue.vt = VT_BSTR;
|
|
|
|
hr = pServer->SetCertificateProperty(strName, PROPTYPE_STRING, &varValue);
|
|
_JumpIfError(hr, error, "SetCertificateProperty");
|
|
|
|
error:
|
|
VariantClear(&varValue);
|
|
if (NULL != strName)
|
|
{
|
|
SysFreeString(strName);
|
|
}
|
|
if (NULL != pwszValue)
|
|
{
|
|
LocalFree(pwszValue);
|
|
}
|
|
return(hr);
|
|
}
|