Botan 3.11.0
Crypto and TLS for C&
blake2b.h
Go to the documentation of this file.
1/*
2* BLAKE2b
3* (C) 2016 cynecx
4*
5* Botan is released under the Simplified BSD License (see license.txt)
6*/
7
8#ifndef BOTAN_BLAKE2B_H_
9#define BOTAN_BLAKE2B_H_
10
11#include <botan/hash.h>
12#include <botan/sym_algo.h>
13#include <botan/internal/alignment_buffer.h>
14#include <string>
15
16namespace Botan {
17
18constexpr size_t BLAKE2B_BLOCKBYTES = 128;
19
20/**
21* BLAKE2B
22*/
23class BLAKE2b final : public HashFunction,
24 public SymmetricAlgorithm {
25 public:
26 /**
27 * @param output_bits the output size of BLAKE2b in bits
28 */
29 explicit BLAKE2b(size_t output_bits = 512);
30
31 size_t hash_block_size() const override { return 128; }
32
33 size_t output_length() const override { return m_output_bits / 8; }
34
35 size_t key_size() const { return m_key_size; }
36
37 Key_Length_Specification key_spec() const override;
38
39 std::unique_ptr<HashFunction> new_object() const override;
40 std::string name() const override;
41 void clear() override;
42 bool has_keying_material() const override;
43
44 std::unique_ptr<HashFunction> copy_state() const override;
45
46 protected:
47 friend class BLAKE2bMAC;
48
49 void key_schedule(std::span<const uint8_t> key) override;
50
51 void add_data(std::span<const uint8_t> input) override;
52 void final_result(std::span<uint8_t> out) override;
53
54 private:
55 void state_init();
56 void compress(const uint8_t* data, size_t blocks, uint64_t increment);
57
58 const size_t m_output_bits;
59
61
63 uint64_t m_T[2];
64 uint64_t m_F;
65
66 size_t m_key_size;
67 secure_vector<uint8_t> m_padded_key_buffer;
68};
69
70} // namespace Botan
71
72#endif
Alignment buffer helper.
size_t key_size() const
Definition blake2b.h:35
friend class BLAKE2bMAC
Definition blake2b.h:47
BLAKE2b(size_t output_bits=512)
Definition blake2b.cpp:34
Key_Length_Specification key_spec() const override
Definition blake2b.cpp:166
void key_schedule(std::span< const uint8_t > key) override
Definition blake2b.cpp:186
size_t output_length() const override
Definition blake2b.h:33
std::unique_ptr< HashFunction > new_object() const override
Definition blake2b.cpp:174
size_t hash_block_size() const override
Definition blake2b.h:31
std::string name() const override
Definition blake2b.cpp:170
bool has_keying_material() const override
Definition blake2b.cpp:182
void add_data(std::span< const uint8_t > input) override
Definition blake2b.cpp:139
void clear() override
Definition blake2b.cpp:201
std::unique_ptr< HashFunction > copy_state() const override
Definition blake2b.cpp:178
void final_result(std::span< uint8_t > out) override
Definition blake2b.cpp:156
void final(uint8_t out[])
Definition buf_comp.h:69
constexpr size_t BLAKE2B_BLOCKBYTES
Definition blake2b.h:18
std::vector< T, secure_allocator< T > > secure_vector
Definition secmem.h:68