Reece Wilson
8a2947ffc5
[*] Refactor bcrypt api: HashPW[Ex] -> HashPassword[Ex] [+] ByteBuffer::GetOrAllocateLinearWriteable [+] ByteBuffer::Can[Read/Write](n) [+] ByteBuffer::GetLinear[Read/Writable]able(n) [*] Split RNG.cpp into two files [+] EHashType::eSHA2_48 (_32, _64 was already in place. missed 48/384 bit) [+] AuCrypto::HMAC and IHMACContext (AuHashing) [+] EHashType::eSHA3_28 [+] EHashType::eSHA3_32 [+] EHashType::eSHA3_48 [+] EHashType::eSHA3_64 (AuCrypto) [+] EHashType::eSHA2_48_384 [+] EHashType::eSHA2_64_512 [+] EHashType::eSHA3_28_224 [+] EHashType::eSHA3_32_256 [+] EHashType::eSHA3_48_384 [+] EHashType::eSHA3_64_512 [*] (IRandomDevice) class -> struct [*] Bugfix: cast in Promise<SuccessValue_t, ErrorValue_t>::WriteIntoError [+] Missing AuHashing namespace alias [*] Time util: pad ms when fraction of a second to 3 digits
35 lines
774 B
C++
35 lines
774 B
C++
/***
|
|
Copyright (C) 2022 J Reece Wilson (a/k/a "Reece"). All rights reserved.
|
|
|
|
File: HMAC.hpp
|
|
Date: 2022-9-18
|
|
Author: Reece
|
|
***/
|
|
#pragma once
|
|
|
|
namespace Aurora::Crypto::HMAC
|
|
{
|
|
struct IHMACContext
|
|
{
|
|
/**
|
|
* @brief Processes an arbitrary amount of bytes
|
|
* @param input
|
|
*/
|
|
virtual void Ingest(const Memory::MemoryViewRead &input) = 0;
|
|
|
|
/**
|
|
* @brief Finalizes the hash stream
|
|
* @return
|
|
*/
|
|
virtual Memory::MemoryViewRead Finalize() = 0;
|
|
|
|
/**
|
|
* @brief
|
|
*/
|
|
virtual void Reset() = 0;
|
|
};
|
|
|
|
AUKN_SHARED_API(HMAC, IHMACContext,
|
|
EHashType algorithm,
|
|
const Memory::MemoryViewRead &sharedSecret);
|
|
} |