|
|
//+-------------------------------------------------------------------------
//
// Microsoft Windows
//
// Copyright (C) Microsoft Corporation, 1995 - 1999
//
// File: admin.cpp
//
// Contents: ICertAdmin IDispatch helper functions
//
//--------------------------------------------------------------------------
#include <pch.cpp>
#pragma hdrstop
#include <stdlib.h>
#include "csdisp.h"
#define __dwFILE__ __dwFILE_CERTLIB_ADMIN_CPP__
//+------------------------------------------------------------------------
// ICertAdmin dispatch support
//TCHAR szRegKeyAdminClsid[] = wszCLASS_CERTADMIN TEXT("\\Clsid");
//+------------------------------------
// IsValidCertificate method:
static OLECHAR *_apszIsValidCertificate[] = { TEXT("IsValidCertificate"), TEXT("strConfig"), TEXT("strSerialNumber"), };
//+------------------------------------
// GetRevocationReason method:
static OLECHAR *_apszGetRevocationReason[] = { TEXT("GetRevocationReason"), };
//+------------------------------------
// RevokeCertificate method:
static OLECHAR *_apszRevokeCertificate[] = { TEXT("RevokeCertificate"), TEXT("strConfig"), TEXT("strSerialNumber"), TEXT("Reason"), TEXT("Date"), };
//+------------------------------------
// SetRequestAttributes method:
static OLECHAR *_apszSetRequestAttributes[] = { TEXT("SetRequestAttributes"), TEXT("strConfig"), TEXT("RequestId"), TEXT("strAttributes"), };
//+------------------------------------
// SetCertificateExtension method:
static OLECHAR *_apszSetCertificateExtension[] = { TEXT("SetCertificateExtension"), TEXT("strConfig"), TEXT("RequestId"), TEXT("strExtensionName"), TEXT("Type"), TEXT("Flags"), TEXT("pvarValue"), };
//+------------------------------------
// DenyRequest method:
static OLECHAR *_apszDenyRequest[] = { TEXT("DenyRequest"), TEXT("strConfig"), TEXT("RequestId"), };
//+------------------------------------
// ResubmitRequest method:
static OLECHAR *_apszResubmitRequest[] = { TEXT("ResubmitRequest"), TEXT("strConfig"), TEXT("RequestId"), };
//+------------------------------------
// PublishCRL method:
static OLECHAR *_apszPublishCRL[] = { TEXT("PublishCRL"), TEXT("strConfig"), TEXT("Date"), };
//+------------------------------------
// GetCRL method:
static OLECHAR *_apszGetCRL[] = { TEXT("GetCRL"), TEXT("strConfig"), TEXT("Flags"), };
//+------------------------------------
// ImportCertificate method:
static OLECHAR *_apszImportCertificate[] = { TEXT("ImportCertificate"), TEXT("strConfig"), TEXT("strCertificate"), TEXT("Flags"), };
//+------------------------------------
// PublishCRLs method:
static OLECHAR *_apszPublishCRLs[] = { TEXT("PublishCRLs"), TEXT("strConfig"), TEXT("Date"), TEXT("CRLFlags"), };
//+------------------------------------
// GetCAProperty method:
static OLECHAR *_apszGetCAProperty[] = { TEXT("GetCAProperty"), TEXT("strConfig"), TEXT("PropId"), TEXT("PropIndex"), TEXT("PropType"), TEXT("Flags"), };
//+------------------------------------
// SetCAProperty method:
static OLECHAR *_apszSetCAProperty[] = { TEXT("SetCAProperty"), TEXT("strConfig"), TEXT("PropId"), TEXT("PropIndex"), TEXT("PropType"), TEXT("pvarPropertyValue"), };
//+------------------------------------
// GetCAPropertyFlags method:
static OLECHAR *_apszGetCAPropertyFlags[] = { TEXT("GetCAPropertyFlags"), TEXT("strConfig"), TEXT("PropId"), };
//+------------------------------------
// GetCAPropertyDisplayName method:
static OLECHAR *_apszGetCAPropertyDisplayName[] = { TEXT("GetCAPropertyDisplayName"), TEXT("strConfig"), TEXT("PropId"), };
//+------------------------------------
// GetArchivedKey method:
static OLECHAR *_apszGetArchivedKey[] = { TEXT("GetArchivedKey"), TEXT("strConfig"), TEXT("RequestId"), TEXT("Flags"), };
//+------------------------------------
// GetConfigEntry method:
static OLECHAR *_apszGetConfigEntry[] = { TEXT("GetConfigEntry"), TEXT("strConfig"), TEXT("strNodePath"), TEXT("strEntryName"), };
//+------------------------------------
// SetConfigEntry method:
static OLECHAR *_apszSetConfigEntry[] = { TEXT("SetConfigEntry"), TEXT("strConfig"), TEXT("strNodePath"), TEXT("strEntryName"), TEXT("pvarEntry"), };
//+------------------------------------
// ImportKey method:
static OLECHAR *_apszImportKey[] = { TEXT("ImportKey"), TEXT("strConfig"), TEXT("RequestId"), TEXT("strCertHash"), TEXT("Flags"), TEXT("strKey"), };
//+------------------------------------
// GetMyRoles method:
static OLECHAR *_apszGetMyRoles[] = { TEXT("GetMyRoles"), TEXT("strConfig"), };
//+------------------------------------
// DeleteRow method:
static OLECHAR *_apszDeleteRow[] = { TEXT("DeleteRow"), TEXT("strConfig"), TEXT("Flags"), TEXT("Date"), TEXT("Table"), TEXT("RowId"), };
//+------------------------------------
// Dispatch Table:
DISPATCHTABLE s_adtAdmin[] = { #define ADMIN_ISVALIDCERTIFICATE 0
DECLARE_DISPATCH_ENTRY(_apszIsValidCertificate)
#define ADMIN_GETREVOCATIONREASON 1
DECLARE_DISPATCH_ENTRY(_apszGetRevocationReason)
#define ADMIN_REVOKECERTIFICATE 2
DECLARE_DISPATCH_ENTRY(_apszRevokeCertificate)
#define ADMIN_SETREQUESTATTRIBUTES 3
DECLARE_DISPATCH_ENTRY(_apszSetRequestAttributes)
#define ADMIN_SETCERTIFICATEEXTENSION 4
DECLARE_DISPATCH_ENTRY(_apszSetCertificateExtension)
#define ADMIN_DENYREQUEST 5
DECLARE_DISPATCH_ENTRY(_apszDenyRequest)
#define ADMIN_RESUBMITREQUEST 6
DECLARE_DISPATCH_ENTRY(_apszResubmitRequest)
#define ADMIN_PUBLISHCRL 7
DECLARE_DISPATCH_ENTRY(_apszPublishCRL)
#define ADMIN_GETCRL 8
DECLARE_DISPATCH_ENTRY(_apszGetCRL)
#define ADMIN_IMPORTCERTIFICATE 9
DECLARE_DISPATCH_ENTRY(_apszImportCertificate)
#define ADMIN2_PUBLISHCRLS 10
DECLARE_DISPATCH_ENTRY(_apszPublishCRLs)
#define ADMIN2_GETCAPROPERTY 11
DECLARE_DISPATCH_ENTRY(_apszGetCAProperty)
#define ADMIN2_SETCAPROPERTY 12
DECLARE_DISPATCH_ENTRY(_apszSetCAProperty)
#define ADMIN2_GETCAPROPERTYFLAGS 13
DECLARE_DISPATCH_ENTRY(_apszGetCAPropertyFlags)
#define ADMIN2_GETCAPROPERTYDISPLAYNAME 14
DECLARE_DISPATCH_ENTRY(_apszGetCAPropertyDisplayName)
#define ADMIN2_GETARCHIVEDKEY 15
DECLARE_DISPATCH_ENTRY(_apszGetArchivedKey)
#define ADMIN2_GETCONFIGENTRY 16
DECLARE_DISPATCH_ENTRY(_apszGetConfigEntry)
#define ADMIN2_SETCONFIGENTRY 17
DECLARE_DISPATCH_ENTRY(_apszSetConfigEntry)
#define ADMIN2_IMPORTKEY 18
DECLARE_DISPATCH_ENTRY(_apszImportKey)
#define ADMIN2_GETMYROLES 19
DECLARE_DISPATCH_ENTRY(_apszGetMyRoles)
#define ADMIN2_DELETEROW 20
DECLARE_DISPATCH_ENTRY(_apszDeleteRow) }; #define CADMINDISPATCH (ARRAYSIZE(s_adtAdmin))
#define CADMINDISPATCH_V1 ADMIN2_PUBLISHCRLS
#define CADMINDISPATCH_V2 CADMINDISPATCH
DWORD s_acAdminDispatch[] = { CADMINDISPATCH_V2, CADMINDISPATCH_V1, };
IID const *s_apAdminiid[] = { &IID_ICertAdmin2, &IID_ICertAdmin, };
HRESULT Admin_Init( IN DWORD Flags, OUT DISPATCHINTERFACE *pdiAdmin) { HRESULT hr;
hr = DispatchSetup2( Flags, CLSCTX_INPROC_SERVER, wszCLASS_CERTADMIN, &CLSID_CCertAdmin, ARRAYSIZE(s_acAdminDispatch), // cver
s_apAdminiid, s_acAdminDispatch, s_adtAdmin, pdiAdmin); _JumpIfError(hr, error, "DispatchSetup2(ICertAdmin)");
error: return(hr); }
VOID Admin_Release( IN OUT DISPATCHINTERFACE *pdiAdmin) { DispatchRelease(pdiAdmin); }
HRESULT AdminVerifyVersion( IN DISPATCHINTERFACE *pdiAdmin, IN DWORD RequiredVersion) { HRESULT hr;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
switch (pdiAdmin->m_dwVersion) { case 1: CSASSERT( NULL == pdiAdmin->pDispatch || CADMINDISPATCH_V1 == pdiAdmin->m_cDispatchTable); break;
case 2: CSASSERT( NULL == pdiAdmin->pDispatch || CADMINDISPATCH_V2 == pdiAdmin->m_cDispatchTable); break;
default: hr = HRESULT_FROM_WIN32(ERROR_INTERNAL_ERROR); _JumpError(hr, error, "m_dwVersion"); } if (pdiAdmin->m_dwVersion < RequiredVersion) { hr = E_NOTIMPL; _JumpError(hr, error, "old interface"); } hr = S_OK;
error: return(hr); }
HRESULT Admin_IsValidCertificate( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN WCHAR const *pwszSerialNumber, OUT LONG *pDisposition) { HRESULT hr; BSTR strConfig = NULL; BSTR strSerialNumber = NULL;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { hr = E_OUTOFMEMORY; _JumpError(hr, error, "ConvertWszToBstr"); } if (!ConvertWszToBstr(&strSerialNumber, pwszSerialNumber, -1)) { hr = E_OUTOFMEMORY; _JumpError(hr, error, "ConvertWszToBstr"); } if (NULL != pdiAdmin->pDispatch) { VARIANT avar[2];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig; avar[1].vt = VT_BSTR; avar[1].bstrVal = strSerialNumber;
hr = DispatchInvoke( pdiAdmin, ADMIN_ISVALIDCERTIFICATE, ARRAYSIZE(avar), avar, VT_I4, pDisposition); _JumpIfError(hr, error, "Invoke(IsValidCertificate)"); } else { hr = ((ICertAdmin *) pdiAdmin->pUnknown)->IsValidCertificate( strConfig, strSerialNumber, pDisposition);
_JumpIfError(hr, error, "ICertAdmin::IsValidCertificate"); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } if (NULL != strSerialNumber) { SysFreeString(strSerialNumber); } return(hr); }
HRESULT Admin_GetRevocationReason( IN DISPATCHINTERFACE *pdiAdmin, OUT LONG *pReason) { HRESULT hr;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
if (NULL != pdiAdmin->pDispatch) { hr = DispatchInvoke( pdiAdmin, ADMIN_GETREVOCATIONREASON, 0, NULL, VT_I4, pReason); _JumpIfError(hr, error, "Invoke(GetRevocationReason)"); } else { hr = ((ICertAdmin *) pdiAdmin->pUnknown)->GetRevocationReason(pReason); _JumpIfError(hr, error, "ICertAdmin::GetRevocationReason"); }
error: return(hr); }
HRESULT Admin_RevokeCertificate( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN WCHAR const *pwszSerialNumber, IN LONG Reason, IN DATE Date) { HRESULT hr; BSTR strConfig = NULL; BSTR strSerialNumber = NULL;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
hr = E_OUTOFMEMORY; if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { _JumpError(hr, error, "ConvertWszToBstr"); } if (!ConvertWszToBstr(&strSerialNumber, pwszSerialNumber, -1)) { _JumpError(hr, error, "ConvertWszToBstr"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[4];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig; avar[1].vt = VT_BSTR; avar[1].bstrVal = strSerialNumber; avar[2].vt = VT_I4; avar[2].lVal = Reason; avar[3].vt = VT_DATE; avar[3].date = Date;
hr = DispatchInvoke( pdiAdmin, ADMIN_REVOKECERTIFICATE, ARRAYSIZE(avar), avar, 0, NULL); _JumpIfError(hr, error, "Invoke(RevokeCertificate)"); } else { hr = ((ICertAdmin *) pdiAdmin->pUnknown)->RevokeCertificate( strConfig, strSerialNumber, Reason, Date); _JumpIfError(hr, error, "ICertAdmin::RevokeCertificate"); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } if (NULL != strSerialNumber) { SysFreeString(strSerialNumber); } return(hr); }
HRESULT Admin_SetRequestAttributes( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN LONG RequestId, IN WCHAR const *pwszAttributes) { HRESULT hr; BSTR strConfig = NULL; BSTR strAttributes = NULL;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
hr = E_OUTOFMEMORY; if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { _JumpError(hr, error, "ConvertWszToBstr"); } if (!ConvertWszToBstr(&strAttributes, pwszAttributes, -1)) { _JumpError(hr, error, "ConvertWszToBstr"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[3];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig; avar[1].vt = VT_I4; avar[1].lVal = RequestId; avar[2].vt = VT_BSTR; avar[2].bstrVal = strAttributes;
hr = DispatchInvoke( pdiAdmin, ADMIN_SETREQUESTATTRIBUTES, ARRAYSIZE(avar), avar, 0, NULL); _JumpIfError(hr, error, "Invoke(SetRequestAttributes)"); } else { hr = ((ICertAdmin *) pdiAdmin->pUnknown)->SetRequestAttributes( strConfig, RequestId, strAttributes);
_JumpIfError(hr, error, "ICertAdmin::SetRequestAttributes"); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } if (NULL != strAttributes) { SysFreeString(strAttributes); } return(hr); }
HRESULT Admin_SetCertificateExtension( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN LONG RequestId, IN WCHAR const *pwszExtensionName, IN LONG Type, IN LONG Flags, IN VARIANT const *pvarValue)
{ HRESULT hr; BSTR strConfig = NULL; BSTR strExtensionName = NULL;
hr = E_OUTOFMEMORY; if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { _JumpError(hr, error, "ConvertWszToBstr"); } if (!ConvertWszToBstr(&strExtensionName, pwszExtensionName, -1)) { _JumpError(hr, error, "ConvertWszToBstr"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[6];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig;
avar[1].vt = VT_I4; avar[1].lVal = RequestId;
avar[2].vt = VT_BSTR; avar[2].bstrVal = strExtensionName;
avar[3].vt = VT_I4; avar[3].lVal = Type;
avar[4].vt = VT_I4; avar[4].lVal = Flags;
avar[5].vt = VT_VARIANT | VT_BYREF; avar[5].pvarVal = (VARIANT *) pvarValue;
hr = DispatchInvoke( pdiAdmin, ADMIN_SETCERTIFICATEEXTENSION, ARRAYSIZE(avar), avar, 0, NULL); _JumpIfError(hr, error, "Invoke(SetCertificateExtension)"); } else { hr = ((ICertAdmin *) pdiAdmin->pUnknown)->SetCertificateExtension( strConfig, RequestId, strExtensionName, Type, Flags, pvarValue); _JumpIfError(hr, error, "ICertAdmin::SetCertificateExtension"); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } if (NULL != strExtensionName) { SysFreeString(strExtensionName); } return(hr); }
HRESULT Admin_DenyRequest( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN LONG RequestId) { HRESULT hr; BSTR strConfig = NULL;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { hr = E_OUTOFMEMORY; _JumpError(hr, error, "ConvertWszToBstr"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[2];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig;
avar[1].vt = VT_I4; avar[1].lVal = RequestId;
hr = DispatchInvoke( pdiAdmin, ADMIN_DENYREQUEST, ARRAYSIZE(avar), avar, 0, NULL); _JumpIfError(hr, error, "Invoke(DenyRequest)"); } else { hr = ((ICertAdmin *) pdiAdmin->pUnknown)->DenyRequest( strConfig, RequestId); _JumpIfError(hr, error, "ICertAdmin::DenyRequest"); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } return(hr); }
HRESULT Admin_ResubmitRequest( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN LONG RequestId, OUT LONG *pDisposition) { HRESULT hr; BSTR strConfig = NULL;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { hr = E_OUTOFMEMORY; _JumpError(hr, error, "ConvertWszToBstr"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[2];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig;
avar[1].vt = VT_I4; avar[1].lVal = RequestId;
hr = DispatchInvoke( pdiAdmin, ADMIN_RESUBMITREQUEST, ARRAYSIZE(avar), avar, VT_I4, pDisposition); _JumpIfError(hr, error, "Invoke(ResubmitRequest)"); } else { hr = ((ICertAdmin *) pdiAdmin->pUnknown)->ResubmitRequest( strConfig, RequestId, pDisposition); _JumpIfError(hr, error, "ICertAdmin::ResubmitRequest"); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } return(hr); }
HRESULT Admin_PublishCRL( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN DATE Date) { HRESULT hr; BSTR strConfig = NULL;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { hr = E_OUTOFMEMORY; _JumpError(hr, error, "ConvertWszToBstr"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[2];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig; avar[1].vt = VT_DATE; avar[1].date = Date;
hr = DispatchInvoke( pdiAdmin, ADMIN_PUBLISHCRL, ARRAYSIZE(avar), avar, 0, NULL); _JumpIfError(hr, error, "Invoke(PublishCRL)"); } else { hr = ((ICertAdmin *) pdiAdmin->pUnknown)->PublishCRL( strConfig, Date); _JumpIfError(hr, error, "ICertAdmin::PublishCRL"); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } return(hr); }
HRESULT Admin2_PublishCRLs( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN DATE Date, IN LONG CRLFlags) // CA_CRL_*
{ HRESULT hr; BSTR strConfig = NULL;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
hr = AdminVerifyVersion(pdiAdmin, 2); _JumpIfError(hr, error, "AdminVerifyVersion");
if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { hr = E_OUTOFMEMORY; _JumpError(hr, error, "ConvertWszToBstr"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[3];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig;
avar[1].vt = VT_DATE; avar[1].date = Date;
avar[2].vt = VT_I4; avar[2].date = CRLFlags;
hr = DispatchInvoke( pdiAdmin, ADMIN2_PUBLISHCRLS, ARRAYSIZE(avar), avar, 0, NULL); _JumpIfError(hr, error, "Invoke(PublishCRLs)"); } else { hr = ((ICertAdmin2 *) pdiAdmin->pUnknown)->PublishCRLs( strConfig, Date, CRLFlags); _JumpIfError(hr, error, "ICertAdmin2::PublishCRLs"); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } return(hr); }
HRESULT Admin_GetCRL( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN LONG Flags, OUT BSTR *pstrCRL) { HRESULT hr; BSTR strConfig = NULL;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
hr = AdminVerifyVersion(pdiAdmin, 2); _JumpIfError(hr, error, "AdminVerifyVersion");
if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { hr = E_OUTOFMEMORY; _JumpError(hr, error, "ConvertWszToBstr"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[2];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig; avar[1].vt = VT_I4; avar[1].lVal = Flags;
hr = DispatchInvoke( pdiAdmin, ADMIN_GETCRL, ARRAYSIZE(avar), avar, VT_BSTR, pstrCRL); _JumpIfError(hr, error, "Invoke(GetCRL)"); } else { hr = ((ICertAdmin *) pdiAdmin->pUnknown)->GetCRL( strConfig, Flags, pstrCRL); _JumpIfError(hr, error, "ICertAdmin::GetCRL"); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } return(hr); }
HRESULT Admin_ImportCertificate( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN WCHAR const *pwszCertificate, IN DWORD cbCertificate, IN LONG dwFlags, OUT LONG *pRequestId) { HRESULT hr; BSTR strConfig = NULL; BSTR strCertificate = NULL;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
hr = E_OUTOFMEMORY; if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { _JumpError(hr, error, "ConvertWszToBstr"); } strCertificate = SysAllocStringByteLen( (CHAR const *) pwszCertificate, cbCertificate); if (NULL == strCertificate) { _JumpError(hr, error, "SysAllocStringByteLen"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[3];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig; avar[1].vt = VT_BSTR; avar[1].bstrVal = strCertificate; avar[2].vt = VT_I4; avar[2].lVal = dwFlags;
hr = DispatchInvoke( pdiAdmin, ADMIN_IMPORTCERTIFICATE, ARRAYSIZE(avar), avar, VT_I4, pRequestId); _JumpIfError(hr, error, "Invoke(ImportCertificate)"); } else { hr = ((ICertAdmin *) pdiAdmin->pUnknown)->ImportCertificate( strConfig, strCertificate, dwFlags, pRequestId); _JumpIfError3( hr, error, "ICertAdmin::ImportCertificate", NTE_BAD_SIGNATURE, HRESULT_FROM_WIN32(ERROR_OBJECT_ALREADY_EXISTS)); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } if (NULL != strCertificate) { SysFreeString(strCertificate); } return(hr); }
HRESULT AdminRevokeCertificate( IN DWORD Flags, OPTIONAL IN WCHAR const *pwszConfig, IN WCHAR const *pwszSerialNumber, IN LONG Reason, IN DATE Date) { HRESULT hr; DISPATCHINTERFACE diAdmin; BSTR strConfig = NULL; if (NULL == pwszConfig) { hr = ConfigGetConfig(Flags, CC_LOCALACTIVECONFIG, &strConfig); _JumpIfError(hr, error, "ConfigGetConfig");
pwszConfig = strConfig; } hr = Admin_Init(Flags, &diAdmin); _JumpIfError(hr, error, "Admin_Init");
hr = Admin_RevokeCertificate( &diAdmin, pwszConfig, pwszSerialNumber, Reason, Date); _JumpIfError(hr, error, "Admin_RevokeCertificate");
error: Admin_Release(&diAdmin); if (NULL != strConfig) { SysFreeString(strConfig); } return(hr); }
#if 0
HRESULT Admin2_SetCAProperty( IN WCHAR const *pwszConfig, IN LONG PropId, // CR_PROP_*
IN LONG PropIndex, IN LONG PropType, // PROPTYPE_*
IN VARIANT *pvarPropertyValue) { } #endif
HRESULT Admin2_GetArchivedKey( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN LONG RequestId, IN LONG Flags, // CR_OUT_*
OUT BSTR *pstrArchivedKey) { HRESULT hr; BSTR strConfig = NULL;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
hr = AdminVerifyVersion(pdiAdmin, 2); _JumpIfError(hr, error, "AdminVerifyVersion");
if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { hr = E_OUTOFMEMORY; _JumpError(hr, error, "ConvertWszToBstr"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[3];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig; avar[1].vt = VT_I4; avar[1].lVal = RequestId; avar[2].vt = VT_I4; avar[2].lVal = Flags;
hr = DispatchInvoke( pdiAdmin, ADMIN2_GETARCHIVEDKEY, ARRAYSIZE(avar), avar, VT_BSTR, pstrArchivedKey); _JumpIfError(hr, error, "Invoke(GetArchivedKey)"); } else { hr = ((ICertAdmin2 *) pdiAdmin->pUnknown)->GetArchivedKey( strConfig, RequestId, Flags, pstrArchivedKey); _JumpIfError(hr, error, "ICertAdmin::GetArchivedKey"); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } return(hr); }
#if 0
HRESULT Admin2_GetConfigEntry( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN WCHAR const *pwszNodePath, IN WCHAR const *pwszEntryName, OUT VARIANT *pvarEntry) { } #endif
#if 0
HRESULT Admin2_SetConfigEntry( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN WCHAR const *pwszNodePath, IN WCHAR const *pwszEntryName, IN VARIANT const *pvarEntry) { } #endif
HRESULT Admin2_ImportKey( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN LONG RequestId, IN WCHAR const *pwszCertHash, IN LONG Flags, IN WCHAR const *pwszKey, IN DWORD cbKey) { HRESULT hr; BSTR strConfig = NULL; BSTR strCertHash = NULL; BSTR strKey = NULL;
if (NULL == pwszKey || NULL == pwszConfig) { hr = E_INVALIDARG; _JumpError(hr, error, "NULL parm"); } hr = E_OUTOFMEMORY; if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { _JumpError(hr, error, "ConvertWszToBstr"); } if (NULL != pwszCertHash) { if (!ConvertWszToBstr(&strCertHash, pwszCertHash, -1)) { _JumpError(hr, error, "ConvertWszToBstr"); } } strKey = SysAllocStringByteLen((CHAR const *) pwszKey, cbKey); if (NULL == strKey) { _JumpError(hr, error, "SysAllocStringByteLen"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[5];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig;
avar[1].vt = VT_I4; avar[1].lVal = RequestId;
avar[2].vt = VT_BSTR; avar[2].bstrVal = strCertHash;
avar[3].vt = VT_I4; avar[3].lVal = Flags;
avar[4].vt = VT_BSTR; avar[4].bstrVal = strKey;
hr = DispatchInvoke( pdiAdmin, ADMIN2_IMPORTKEY, ARRAYSIZE(avar), avar, 0, NULL); _JumpIfError(hr, error, "Invoke(ImportKey)"); } else { hr = ((ICertAdmin2 *) pdiAdmin->pUnknown)->ImportKey( strConfig, RequestId, strCertHash, Flags, strKey); _JumpIfError2( hr, error, "ICertAdmin::ImportKey", HRESULT_FROM_WIN32(ERROR_OBJECT_ALREADY_EXISTS)); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } if (NULL != strCertHash) { SysFreeString(strCertHash); } if (NULL != strKey) { SysFreeString(strKey); } return(hr); }
HRESULT Admin2_GetMyRoles( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, OUT LONG *pRoles) // CA_ACCESS_*
{ HRESULT hr; BSTR strConfig = NULL;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
hr = AdminVerifyVersion(pdiAdmin, 2); _JumpIfError(hr, error, "AdminVerifyVersion");
if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { hr = E_OUTOFMEMORY; _JumpError(hr, error, "ConvertWszToBstr"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[1];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig;
hr = DispatchInvoke( pdiAdmin, ADMIN2_GETMYROLES, ARRAYSIZE(avar), avar, VT_I4, pRoles); _JumpIfError(hr, error, "Invoke(GetMyRoles)"); } else { hr = ((ICertAdmin2 *) pdiAdmin->pUnknown)->GetMyRoles( strConfig, pRoles); _JumpIfError(hr, error, "ICertAdmin::GetMyRoles"); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } return(hr); }
HRESULT Admin2_DeleteRow( IN DISPATCHINTERFACE *pdiAdmin, IN WCHAR const *pwszConfig, IN LONG Flags, // CDR_*
IN DATE Date, IN LONG Table, // CVRC_TABLE_*
IN LONG RowId, OUT LONG *pcDeleted) { HRESULT hr; BSTR strConfig = NULL;
CSASSERT(NULL != pdiAdmin && NULL != pdiAdmin->pDispatchTable);
hr = AdminVerifyVersion(pdiAdmin, 2); _JumpIfError(hr, error, "AdminVerifyVersion");
if (!ConvertWszToBstr(&strConfig, pwszConfig, -1)) { hr = E_OUTOFMEMORY; _JumpError(hr, error, "ConvertWszToBstr"); }
if (NULL != pdiAdmin->pDispatch) { VARIANT avar[5];
avar[0].vt = VT_BSTR; avar[0].bstrVal = strConfig; avar[1].vt = VT_I4; avar[1].lVal = Flags; avar[2].vt = VT_DATE; avar[2].date = Date; avar[3].vt = VT_I4; avar[3].lVal = Table; avar[4].vt = VT_I4; avar[4].lVal = RowId;
hr = DispatchInvoke( pdiAdmin, ADMIN2_DELETEROW, ARRAYSIZE(avar), avar, VT_I4, pcDeleted); _JumpIfError(hr, error, "Invoke(DeleteRow)"); } else { hr = ((ICertAdmin2 *) pdiAdmin->pUnknown)->DeleteRow( strConfig, Flags, Date, Table, RowId, pcDeleted); _JumpIfError(hr, error, "ICertAdmin::DeleteRow"); }
error: if (NULL != strConfig) { SysFreeString(strConfig); } return(hr); }
#undef __dwFILE__
#define CCERTADMIN
#include "prop2.cpp"
|