|
Crypto++ 8.9
Free C++ class library of cryptographic schemes
|
SHA3 message digest base class. More...
#include <sha3.h>
Inheritance diagram for SHA3:Public Member Functions | |
| unsigned int | DigestSize () const |
| Provides the digest size of the hash. | |
| unsigned int | OptimalDataAlignment () const |
| Provides input and output data alignment for optimal performance. | |
| void | Update (const byte *input, size_t length) |
| Updates a hash with additional input. | |
| void | Restart () |
| Restart the hash. | |
| void | TruncatedFinal (byte *hash, size_t size) |
| Computes the hash of the current message. | |
Public Member Functions inherited from HashTransformation | |
| HashTransformation & | Ref () |
| Provides a reference to this object. | |
| virtual byte * | CreateUpdateSpace (size_t &size) |
| Request space which can be written into by the caller. | |
| virtual void | Final (byte *digest) |
| Computes the hash of the current message. | |
| unsigned int | TagSize () const |
| Provides the tag size of the hash. | |
| virtual unsigned int | BlockSize () const |
| Provides the block size of the compression function. | |
| virtual unsigned int | OptimalBlockSize () const |
| Provides the input block size most efficient for this hash. | |
| virtual void | CalculateDigest (byte *digest, const byte *input, size_t length) |
| Updates the hash with additional input and computes the hash of the current message. | |
| virtual bool | Verify (const byte *digest) |
| Verifies the hash of the current message. | |
| virtual bool | VerifyDigest (const byte *digest, const byte *input, size_t length) |
| Updates the hash with additional input and verifies the hash of the current message. | |
| virtual void | CalculateTruncatedDigest (byte *digest, size_t digestSize, const byte *input, size_t length) |
| Updates the hash with additional input and computes the hash of the current message. | |
| virtual bool | TruncatedVerify (const byte *digest, size_t digestLength) |
| Verifies the hash of the current message. | |
| virtual bool | VerifyTruncatedDigest (const byte *digest, size_t digestLength, const byte *input, size_t length) |
| Updates the hash with additional input and verifies the hash of the current message. | |
Public Member Functions inherited from Algorithm | |
| Algorithm (bool checkSelfTestStatus=true) | |
| Interface for all crypto algorithms. | |
| virtual std::string | AlgorithmName () const |
| Provides the name of this algorithm. | |
| virtual std::string | AlgorithmProvider () const |
| Retrieve the provider of this algorithm. | |
Public Member Functions inherited from Clonable | |
| virtual Clonable * | Clone () const |
| Copies this object. | |
SHA3 message digest base class.
The Crypto++ implementation conforms to FIPS 202 version of SHA3 using F1600 with XOF d=0x06. Previous behavior (XOF d=0x01) is available in Keccak classes.
SHA3 is the base class for SHA3_224, SHA3_256, SHA3_384 and SHA3_512. Library users should instantiate a derived class, and only use SHA3 as a base class reference or pointer.
|
inlinevirtual |
Provides the digest size of the hash.
Implements HashTransformation.
|
inlinevirtual |
Provides input and output data alignment for optimal performance.
Reimplemented from HashTransformation.
|
virtual |
Updates a hash with additional input.
| input | the additional input as a buffer |
| length | the size of the buffer, in bytes |
Implements HashTransformation.
|
virtual |
Restart the hash.
Discards the current state, and restart for a new message
Reimplemented from HashTransformation.
|
virtual |
Computes the hash of the current message.
| digest | a pointer to the buffer to receive the hash |
| digestSize | the size of the truncated digest, in bytes |
TruncatedFinal() calls Final() and then copies digestSize bytes to digest. The hash is restarted the hash for the next message.
COUNTOF(digest) <= DigestSize() or COUNTOF(digest) <= HASH::DIGESTSIZE ensures the output byte buffer is a valid size. Implements HashTransformation.