|
|
/*++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Microsoft Windows, Copyright (C) Microsoft Corporation, 2000
File: SignedData.h
Content: Declaration of the CSignedData.
History: 11-15-99 dsie created
------------------------------------------------------------------------------*/
#ifndef __SIGNEDDATA_H_
#define __SIGNEDDATA_H_
#include "Resource.h"
#include "Error.h"
#include "Lock.h"
#include "Debug.h"
#include "DialogUI.h"
///////////////////////////////////////////////////////////////////////////////
//
// CSignedData
//
class ATL_NO_VTABLE CSignedData : public CComObjectRootEx<CComMultiThreadModel>, public CComCoClass<CSignedData, &CLSID_SignedData>, public ICAPICOMError<CSignedData, &IID_ISignedData>, public IPromptUser<CSignedData>, public IDispatchImpl<ISignedData, &IID_ISignedData, &LIBID_CAPICOM, CAPICOM_MAJOR_VERSION, CAPICOM_MINOR_VERSION>, public IObjectSafetyImpl<CSignedData, INTERFACESAFE_FOR_UNTRUSTED_CALLER | INTERFACESAFE_FOR_UNTRUSTED_DATA> { public: CSignedData() { }
DECLARE_REGISTRY_RESOURCEID(IDR_SIGNEDDATA)
DECLARE_GET_CONTROLLING_UNKNOWN()
DECLARE_PROTECT_FINAL_CONSTRUCT()
BEGIN_COM_MAP(CSignedData) COM_INTERFACE_ENTRY(ISignedData) COM_INTERFACE_ENTRY(IDispatch) COM_INTERFACE_ENTRY(IObjectSafety) COM_INTERFACE_ENTRY(IObjectWithSite) COM_INTERFACE_ENTRY(ISupportErrorInfo) END_COM_MAP()
BEGIN_CATEGORY_MAP(CSignedData) IMPLEMENTED_CATEGORY(CATID_SafeForScripting) IMPLEMENTED_CATEGORY(CATID_SafeForInitializing) END_CATEGORY_MAP()
HRESULT FinalConstruct() { HRESULT hr;
if (FAILED(hr = m_Lock.Initialized())) { DebugTrace("Error [%#x]: Critical section could not be created for SignedData object.\n", hr); return hr; }
m_bSigned = FALSE; m_bDetached = VARIANT_FALSE; m_ContentBlob.cbData = 0; m_ContentBlob.pbData = NULL; m_MessageBlob.cbData = 0; m_MessageBlob.pbData = NULL;
return S_OK; }
void FinalRelease() { if (m_ContentBlob.pbData) { ::CoTaskMemFree(m_ContentBlob.pbData); }
if (m_MessageBlob.pbData) { ::CoTaskMemFree(m_MessageBlob.pbData); } }
//
// ISignedData
//
public: STDMETHOD(Verify) (/*[in]*/ BSTR SignedMessage, /*[in, defaultvalue(0)]*/ VARIANT_BOOL bDetached, /*[in, defaultvalue(CAPICOM_VERIFY_SIGNATURE_AND_CERTIFICATE)]*/ CAPICOM_SIGNED_DATA_VERIFY_FLAG VerifyFlag);
STDMETHOD(CoSign) (/*[in, defaultvalue(NULL)]*/ ISigner * pSigner, /*[in, defaultvalue(CAPICOM_BASE64_ENCODE)]*/ CAPICOM_ENCODING_TYPE EncodingType, /*[out, retval]*/ BSTR * pVal);
STDMETHOD(Sign) (/*[in, defaultvalue(NULL)]*/ ISigner * pSigner, /*[in, defaultvalue(0)]*/ VARIANT_BOOL bDetached, /*[in, defaultvalue(CAPICOM_BASE64_ENCODE)]*/ CAPICOM_ENCODING_TYPE EncodingType, /*[out, retval]*/ BSTR * pVal);
STDMETHOD(get_Certificates) (/*[out, retval]*/ ICertificates ** pVal);
STDMETHOD(get_Signers) (/*[out, retval]*/ ISigners ** pVal);
STDMETHOD(get_Content) (/*[out, retval]*/ BSTR * pVal);
STDMETHOD(put_Content) (/*[in]*/ BSTR newVal);
private: CLock m_Lock; BOOL m_bSigned; VARIANT_BOOL m_bDetached; DATA_BLOB m_ContentBlob; DATA_BLOB m_MessageBlob;
STDMETHOD(OpenToEncode) (CMSG_SIGNER_ENCODE_INFO * pSignerEncodeInfo, DATA_BLOB * pChainBlob, CAPICOM_CERTIFICATE_INCLUDE_OPTION IncludeOption, HCRYPTMSG * phMsg);
STDMETHOD(OpenToDecode) (HCRYPTPROV hCryptProv, HCRYPTMSG * phMsg);
STDMETHOD(SignContent) (ISigner2 * pISigner2, CMSG_SIGNER_ENCODE_INFO * pSignerEncodeInfo, DATA_BLOB * pChainBlob, VARIANT_BOOL bDetached, CAPICOM_ENCODING_TYPE EncodingType, BSTR * pVal);
STDMETHOD(CoSignContent) (ISigner2 * pISigner2, CMSG_SIGNER_ENCODE_INFO * pSignerEncodeInfo, DATA_BLOB * pChainBlob, CAPICOM_ENCODING_TYPE EncodingType, BSTR * pVal); };
#endif //__SIGNEDDATA_H_
|