/* */ #include "MessageDigestImpl.h" #include "crypto_hash.h" #include "Adler32MessageDigestImpl.h" namespace { using namespace aria2; using namespace crypto; template class MessageDigestBase : public MessageDigestImpl { public: MessageDigestBase() : ctx_{hash::create(algo)} {} virtual ~MessageDigestBase() {} static size_t length() { auto ctx = hash::create(algo); return ctx->length(); } virtual size_t getDigestLength() const CXX11_OVERRIDE { return ctx_->length(); } virtual void reset() CXX11_OVERRIDE { ctx_->reset(); } virtual void update(const void *data, size_t length) CXX11_OVERRIDE { ctx_->update(data, length); } virtual void digest(unsigned char *md) CXX11_OVERRIDE { auto rv = ctx_->finalize(); memcpy(md, rv.data(), rv.length()); } private: std::unique_ptr ctx_; }; typedef MessageDigestBase MessageDigestMD5; typedef MessageDigestBase MessageDigestSHA1; typedef MessageDigestBase MessageDigestSHA224; typedef MessageDigestBase MessageDigestSHA256; typedef MessageDigestBase MessageDigestSHA384; typedef MessageDigestBase MessageDigestSHA512; } // namespace namespace aria2 { std::unique_ptr MessageDigestImpl::sha1() { return make_unique(); } MessageDigestImpl::hashes_t MessageDigestImpl::hashes = { { "sha-1", make_hi() }, { "sha-224", make_hi() }, { "sha-256", make_hi() }, { "sha-384", make_hi() }, { "sha-512", make_hi() }, { "md5", make_hi() }, ADLER32_MESSAGE_DIGEST }; } // namespace aria2