00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #ifndef WINCAPICRYPTOHASHHMAC_INCLUDE
00029 #define WINCAPICRYPTOHASHHMAC_INCLUDE
00030
00031 #include <xsec/framework/XSECDefs.hpp>
00032 #include <xsec/enc/XSECCryptoHash.hpp>
00033
00034 #if !defined(_WIN32_WINNT)
00035 # define _WIN32_WINNT 0x0400
00036 #endif
00037
00038 #include <wincrypt.h>
00039
00040 class WinCAPICryptoProvider;
00041
00066 class DSIG_EXPORT WinCAPICryptoHashHMAC : public XSECCryptoHash {
00067
00068
00069 public :
00070
00073
00086 WinCAPICryptoHashHMAC(HCRYPTPROV prov, XSECCryptoHash::HashType alg);
00087 virtual ~WinCAPICryptoHashHMAC();
00088
00090
00093
00103 virtual void setKey(XSECCryptoKey * key);
00104
00106
00109
00116 virtual void reset(void);
00117
00129 virtual void hash(unsigned char * data,
00130 unsigned int length);
00131
00145 virtual unsigned int finish(unsigned char * hash,
00146 unsigned int maxLength);
00147
00149
00152
00161 virtual HashType getHashType(void);
00162
00164
00165 private:
00166
00167
00168 WinCAPICryptoHashHMAC();
00169
00170 unsigned char m_mdValue[XSEC_MAX_HASH_SIZE];
00171 unsigned int m_mdLen;
00172
00173 ALG_ID m_algId;
00174 XSECCryptoHash::HashType m_hashType;
00175
00176 HCRYPTPROV m_p;
00177 HCRYPTHASH m_h;
00178
00179 unsigned char m_ipadKeyed[XSEC_MAX_HASH_SIZE];
00180 unsigned char m_opadKeyed[XSEC_MAX_HASH_SIZE];
00181
00182 unsigned int m_blockSize;
00183
00184
00185 void eraseKeys();
00186
00187 };
00188
00189 #endif