// -*- mode: cpp; mode: fold -*- // Description /*{{{*/ // $Id: sha512.h,v 1.3 2001/05/07 05:05:47 jgg Exp $ /* ###################################################################### SHA{512,256}SumValue - Storage for a SHA-{512,256} hash. SHA{512,256}Summation - SHA-{512,256} Secure Hash Algorithm. This is a C++ interface to a set of SHA{512,256}Sum functions, that mirrors the equivalent MD5 & SHA1 classes. ##################################################################### */ /*}}}*/ #ifndef APTPKG_SHA2_H #define APTPKG_SHA2_H #include #include #include #include #include "sha2_internal.h" #include "hashsum_template.h" using std::string; using std::min; class SHA512Summation; class SHA256Summation; typedef HashSumValue<512> SHA512SumValue; typedef HashSumValue<256> SHA256SumValue; class SHA2SummationBase { protected: bool Done; public: virtual bool Add(const unsigned char *inbuf,unsigned long inlen) = 0; virtual bool AddFD(int Fd,unsigned long Size); inline bool Add(const char *Data) { return Add((unsigned char *)Data,strlen(Data)); }; inline bool Add(const unsigned char *Beg,const unsigned char *End) { return Add(Beg,End-Beg); }; void Result(); }; class SHA256Summation : public SHA2SummationBase { SHA256_CTX ctx; unsigned char Sum[32]; public: virtual bool Add(const unsigned char *inbuf, unsigned long len) { if (Done) return false; SHA256_Update(&ctx, inbuf, len); return true; }; SHA256SumValue Result() { if (!Done) { SHA256_Final(Sum, &ctx); Done = true; } SHA256SumValue res; res.Set(Sum); return res; }; SHA256Summation() { SHA256_Init(&ctx); Done = false; }; }; class SHA512Summation : public SHA2SummationBase { SHA512_CTX ctx; unsigned char Sum[64]; public: virtual bool Add(const unsigned char *inbuf, unsigned long len) { if (Done) return false; SHA512_Update(&ctx, inbuf, len); return true; }; SHA512SumValue Result() { if (!Done) { SHA512_Final(Sum, &ctx); Done = true; } SHA512SumValue res; res.Set(Sum); return res; }; SHA512Summation() { SHA512_Init(&ctx); Done = false; }; }; #endif