| 1 | // | 
|---|---|
| 2 | // SHA3Engine.h | 
| 3 | // | 
| 4 | // Library: Foundation | 
| 5 | // Package: Crypt | 
| 6 | // Module: SHA3Engine | 
| 7 | // | 
| 8 | // Definition of class SHA3Engine. | 
| 9 | // | 
| 10 | /// This class implements the SHA-3 message digest algorithm. | 
| 11 | /// (FIPS 202, see http://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.202.pdf) | 
| 12 | // | 
| 13 | // Based on the Keccak Code Package (public domain) | 
| 14 | // https://github.com/gvanas/KeccakCodePackage | 
| 15 | // | 
| 16 | // Copyright (c) 2017, Applied Informatics Software Engineering GmbH | 
| 17 | // and Contributors. | 
| 18 | // | 
| 19 | // SPDX-License-Identifier: BSL-1.0 | 
| 20 | // | 
| 21 | |
| 22 | #ifndef Foundation_SHA3Engine_INCLUDED | 
| 23 | #define Foundation_SHA3Engine_INCLUDED | 
| 24 | |
| 25 | #include "Poco/Foundation.h" | 
| 26 | #include "Poco/DigestEngine.h" | 
| 27 | |
| 28 | namespace Poco { | 
| 29 | |
| 30 | class Foundation_API SHA3Engine: public DigestEngine | 
| 31 | /// This class implements the SHA-3 message digest algorithm. | 
| 32 | /// (FIPS 202, see http://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.202.pdf) | 
| 33 | { | 
| 34 | public: | 
| 35 | enum ALGORITHM | 
| 36 | { | 
| 37 | SHA3_224 = 224, | 
| 38 | SHA3_256 = 256, | 
| 39 | SHA3_384 = 384, | 
| 40 | SHA3_512 = 512, | 
| 41 | }; | 
| 42 | |
| 43 | SHA3Engine(ALGORITHM algorithm = SHA3_512); | 
| 44 | ~SHA3Engine(); | 
| 45 | |
| 46 | std::size_t digestLength() const; | 
| 47 | void reset(); | 
| 48 | const DigestEngine::Digest& digest(); | 
| 49 | |
| 50 | protected: | 
| 51 | void updateImpl(const void* data, std::size_t length); | 
| 52 | |
| 53 | private: | 
| 54 | void transform(); | 
| 55 | |
| 56 | void* _context; | 
| 57 | ALGORITHM _algorithm; | 
| 58 | DigestEngine::Digest _digest; | 
| 59 | |
| 60 | SHA3Engine(const SHA3Engine&); | 
| 61 | SHA3Engine& operator = (const SHA3Engine&); | 
| 62 | }; | 
| 63 | |
| 64 | } // namespace Poco | 
| 65 | |
| 66 | #endif // Foundation_SHA3Engine_INCLUDED | 
| 67 | 
