Files
Slnkdwf/SlnkDWFCom/Crypto.h
Jos Groot Lipman 0b955c13b8 Crypto ook hmac_sha256 toegevoegd + base64/base32 encoding afgesplitst
svn path=/Slnkdwf/trunk/; revision=30449
2016-08-28 19:14:11 +00:00

72 lines
2.3 KiB
C++

// Crypto.h : Declaration of the CCrypto
#pragma once
#include "resource.h" // main symbols
#include "SLNKDWF.h"
#if defined(_WIN32_WCE) && !defined(_CE_DCOM) && !defined(_CE_ALLOW_SINGLE_THREADED_OBJECTS_IN_MTA)
#error "Single-threaded COM objects are not properly supported on Windows CE platform, such as the Windows Mobile platforms that do not include full DCOM support. Define _CE_ALLOW_SINGLE_THREADED_OBJECTS_IN_MTA to force ATL to support creating single-thread COM object's and allow use of it's single-threaded COM object implementations. The threading model in your rgs file was set to 'Free' as that is the only threading model supported in non DCOM Windows CE platforms."
#endif
// CCrypto
class ATL_NO_VTABLE CCrypto :
public CComObjectRootEx<CComSingleThreadModel>,
public CComCoClass<CCrypto, &CLSID_Crypto>,
public IDispatchImpl<ICrypto, &IID_ICrypto, &LIBID_SLNKDWFLib, /*wMajor =*/ 1, /*wMinor =*/ 0>
{
public:
CCrypto()
{
}
DECLARE_REGISTRY_RESOURCEID(IDR_CRYPTO)
BEGIN_COM_MAP(CCrypto)
COM_INTERFACE_ENTRY(ICrypto)
COM_INTERFACE_ENTRY(IDispatch)
END_COM_MAP()
DECLARE_PROTECT_FINAL_CONSTRUCT()
HRESULT FinalConstruct()
{
return S_OK;
}
void FinalRelease()
{
}
public:
STDMETHOD(base64)(BSTR data, VARIANT_BOOL padding /*FALSE*/, VARIANT_BOOL urlsafe /*FALSE*/, BSTR* pVal);
STDMETHOD(base64_decode)(BSTR data, BSTR* pVal);
STDMETHOD(base32)(BSTR data, BSTR* pVal);
STDMETHOD(hex2base64)(BSTR data, VARIANT_BOOL padding /*FALSE*/, VARIANT_BOOL urlsafe /*FALSE*/, BSTR* pVal);
STDMETHOD(hex2base32)(BSTR data, BSTR* pVal);
// STDMETHOD(hex)(BSTR data, BSTR* pVal);
STDMETHOD(b64_hmac_sha1)(BSTR key, BSTR data, BSTR* pVal);
STDMETHOD(hex_hmac_sha1)(BSTR key, BSTR data, BSTR* pVal);
STDMETHOD(hex_sha1)(BSTR data, BSTR* pVal);
STDMETHOD(hex_sha1_file)(BSTR fname, BSTR* pVal);
STDMETHOD(hotp)(BSTR hexseed, LONGLONG counter, BYTE digits, BSTR* pVal);
STDMETHOD(hex_pbkdf2)(BSTR pPassword, BSTR pSalt, ULONG pCount, ULONG pLength, BSTR* pVal);
STDMETHOD(hex_random)(ULONG pLength, BSTR* pVal);
STDMETHOD(hex_sha256)(BSTR data, BSTR* pVal);
STDMETHOD(hex_hmac_sha256)(BSTR key, BSTR data, BSTR* pVal);
STDMETHOD(hex_md5)(BSTR data, BSTR* pVal);
};
OBJECT_ENTRY_AUTO(__uuidof(Crypto), CCrypto)