summaryrefslogtreecommitdiffstats
path: root/twrpDigest/twrpSHA.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'twrpDigest/twrpSHA.hpp')
-rw-r--r--twrpDigest/twrpSHA.hpp54
1 files changed, 54 insertions, 0 deletions
diff --git a/twrpDigest/twrpSHA.hpp b/twrpDigest/twrpSHA.hpp
new file mode 100644
index 000000000..e3899300b
--- /dev/null
+++ b/twrpDigest/twrpSHA.hpp
@@ -0,0 +1,54 @@
+/*
+ Copyright 2012 to 2017 TeamWin
+ This file is part of TWRP/TeamWin Recovery Project.
+
+ TWRP is free software: you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation, either version 3 of the License, or
+ (at your option) any later version.
+
+ TWRP is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with TWRP. If not, see <http://www.gnu.org/licenses/>.
+*/
+#ifndef __TWRPSHA_H
+#define __TWRPSHA_H
+
+#include <openssl/sha.h>
+#include "twrpDigest.hpp"
+
+class twrpSHA256: public twrpDigest {
+public:
+ twrpSHA256(); // Initialize the SHA256 digest for streaming activities only
+ void init(); // Initialize the SHA256 digest algorithm
+
+protected:
+ void update(const unsigned char* stream, size_t len); // Update the SHA256 digest stream
+ void finalize(); // Finalize the SHA256 digest for computation
+ std::string return_digest_string(); // Return the digest string computed to the callee
+
+private:
+ uint8_t sha256_store[SHA256_DIGEST_LENGTH]; // Initialize the SHA256 digest array that holds the computation
+ SHA256_CTX sha256_ctx; // Initialize the SHA256 control structure
+};
+
+class twrpSHA512: public twrpDigest {
+public:
+ twrpSHA512(); // Initialize the SHA512 digest for streaming activities only
+ void init(); // Initialize the SHA512 digest algorithm
+
+protected:
+ void update(const unsigned char* stream, size_t len); // Update the SHA512 digest stream
+ void finalize(); // Finalize the SHA512 digest for computation
+ std::string return_digest_string(); // Return the digest string computed to the callee
+
+private:
+ uint8_t sha512_store[SHA512_DIGEST_LENGTH]; // Initialize the SHA512 digest array that holds the computation
+ SHA512_CTX sha512_ctx; // Initialize the SHA512 control structure
+};
+
+#endif //__TWRPSHA_H