/*** Copyright (C) 2021 J Reece Wilson (a/k/a "Reece"). All rights reserved. File: Digests.cpp Date: 2021-6-12 Author: Reece ***/ #include #include "Digests.hpp" #include namespace Aurora::Hashing { AUKN_SYM void MD4(const AuMemoryViewRead &read, AuArray &md4) { hash_state md; md4_init(&md); md4_process(&md, reinterpret_cast(read.ptr), read.length); md4_done(&md, md4.data()); } AUKN_SYM void MD5(const AuMemoryViewRead &read, AuArray &md5) { hash_state md; md5_init(&md); md5_process(&md, reinterpret_cast(read.ptr), read.length); md5_done(&md, md5.data()); } AUKN_SYM void SHA1(const AuMemoryViewRead &read, AuArray &sha1) { hash_state hs; sha1_init(&hs); sha1_process(&hs, reinterpret_cast(read.ptr), read.length); sha1_done(&hs, sha1.data()); } AUKN_SYM void Tiger(const AuMemoryViewRead &read, AuArray &tiger) { hash_state hs; tiger_init(&hs); tiger_process(&hs, reinterpret_cast(read.ptr), read.length); tiger_done(&hs, tiger.data()); } AUKN_SYM void SHA2(const AuMemoryViewRead &read, AuArray &sha2) { hash_state hs; sha256_init(&hs); sha256_process(&hs, reinterpret_cast(read.ptr), read.length); sha256_done(&hs, sha2.data()); } AUKN_SYM void SHA2_48(const AuMemoryViewRead &read, AuArray &sha2) { hash_state hs; sha384_init(&hs); sha384_process(&hs, reinterpret_cast(read.ptr), read.length); sha384_done(&hs, sha2.data()); } AUKN_SYM void SHA2_64(const AuMemoryViewRead &read, AuArray &sha2) { hash_state hs; sha512_init(&hs); sha512_process(&hs, reinterpret_cast(read.ptr), read.length); sha512_done(&hs, sha2.data()); } AUKN_SYM void SHA3_28(const AuMemoryViewRead &read, AuArray &sha3) { hash_state hs; sha3_224_init(&hs); sha3_process(&hs, reinterpret_cast(read.ptr), read.length); sha3_done(&hs, sha3.data()); } AUKN_SYM void SHA3_32(const AuMemoryViewRead &read, AuArray &sha3) { hash_state hs; sha3_256_init(&hs); sha3_process(&hs, reinterpret_cast(read.ptr), read.length); sha3_done(&hs, sha3.data()); } AUKN_SYM void SHA3_48(const AuMemoryViewRead &read, AuArray &sha3) { hash_state hs; sha3_384_init(&hs); sha3_process(&hs, reinterpret_cast(read.ptr), read.length); sha3_done(&hs, sha3.data()); } AUKN_SYM void SHA3_64(const AuMemoryViewRead &read, AuArray &sha3) { hash_state hs; sha3_512_init(&hs); sha3_process(&hs, reinterpret_cast(read.ptr), read.length); sha3_done(&hs, sha3.data()); } AUKN_SYM void RMD128(const AuMemoryViewRead &read, AuArray &rmd128) { hash_state hs; rmd128_init(&hs); rmd128_process(&hs, reinterpret_cast(read.ptr), read.length); rmd128_done(&hs, rmd128.data()); } AUKN_SYM void RMD160(const AuMemoryViewRead &read, AuArray &rmd160) { hash_state hs; rmd160_init(&hs); rmd160_process(&hs, reinterpret_cast(read.ptr), read.length); rmd160_done(&hs, rmd160.data()); } AUKN_SYM void RMD256(const AuMemoryViewRead &read, AuArray &rmd256) { hash_state hs; rmd256_init(&hs); rmd256_process(&hs, reinterpret_cast(read.ptr), read.length); rmd256_done(&hs, rmd256.data()); } AUKN_SYM void RMD320(const AuMemoryViewRead &read, AuArray &rmd320) { hash_state hs; rmd320_init(&hs); rmd320_process(&hs, reinterpret_cast(read.ptr), read.length); rmd320_done(&hs, rmd320.data()); } }