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 OPENSSLCRYPTOHASHSHA1_INCLUDE
00029 #define OPENSSLCRYPTOHASHSHA1_INCLUDE
00030
00031 #include <xsec/framework/XSECDefs.hpp>
00032 #include <xsec/enc/XSECCryptoHash.hpp>
00033
00034
00035
00036 #if defined (HAVE_OPENSSL)
00037
00038 # include <openssl/evp.h>
00039
00052 class DSIG_EXPORT OpenSSLCryptoHash : public XSECCryptoHash {
00053
00054 public :
00055
00058
00059 OpenSSLCryptoHash(XSECCryptoHash::HashType alg);
00060 virtual ~OpenSSLCryptoHash();
00061
00063
00066
00076 virtual void setKey(XSECCryptoKey * key) {}
00077
00079
00082
00089 virtual void reset(void);
00090
00102 virtual void hash(unsigned char * data,
00103 unsigned int length);
00116 virtual unsigned int finish(unsigned char * hash,
00117 unsigned int maxLength);
00118
00120
00123
00132 virtual HashType getHashType(void);
00133
00135
00136
00137 private:
00138
00139
00140 OpenSSLCryptoHash();
00141
00142 EVP_MD_CTX m_mdctx;
00143 const EVP_MD * mp_md;
00144 unsigned char m_mdValue[EVP_MAX_MD_SIZE];
00145 unsigned int m_mdLen;
00146 HashType m_hashType;
00147
00148 };
00149
00150 #endif
00151 #endif