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 #ifndef NSSCRYPTOHASHHMAC_INCLUDE
00027 #define NSSCRYPTOHASHHMAC_INCLUDE
00028
00029 #include <xsec/framework/XSECDefs.hpp>
00030 #include <xsec/enc/XSECCryptoHash.hpp>
00031
00032 #if defined (HAVE_NSS)
00033
00034 #include "nss/pk11func.h"
00035 #include "nss/nss.h"
00036
00049 class DSIG_EXPORT NSSCryptoHashHMAC : public XSECCryptoHash {
00050
00051
00052 public :
00053
00056
00066 NSSCryptoHashHMAC(XSECCryptoHash::HashType alg);
00067 virtual ~NSSCryptoHashHMAC();
00068
00070
00073
00083 virtual void setKey(XSECCryptoKey * key);
00084
00086
00089
00096 virtual void reset(void);
00097
00109 virtual void hash(unsigned char * data,
00110 unsigned int length);
00111
00125 virtual unsigned int finish(unsigned char * hash,
00126 unsigned int maxLength);
00127
00129
00132
00141 virtual HashType getHashType(void);
00142
00144
00145 private:
00146
00147
00148 NSSCryptoHashHMAC();
00149
00150 unsigned char m_mdValue[XSEC_MAX_HASH_SIZE];
00151 unsigned int m_mdLen;
00152
00153 HashType m_hashType;
00154
00155 PK11Context * mp_md;
00156
00157 unsigned char m_ipadKeyed[XSEC_MAX_HASH_SIZE];
00158 unsigned char m_opadKeyed[XSEC_MAX_HASH_SIZE];
00159
00160 unsigned int m_blockSize;
00161
00162 safeBuffer m_keyBuf;
00163 unsigned int m_keyLen;
00164
00165 };
00166
00167 #endif
00168 #endif