libfilezilla
Loading...
Searching...
No Matches
hash.hpp
Go to the documentation of this file.
1#ifndef LIBFILEZILLA_HASH_HEADER
2#define LIBFILEZILLA_HASH_HEADER
3
7
8#include "libfilezilla.hpp"
9
10#include <vector>
11#include <string>
12#include <cstdint>
13
14namespace fz {
15
18{
19 md5, // insecure
20 sha1, // insecure
21 sha256,
22 sha384,
23 sha512,
24 sha3_256,
25 sha3_384,
26 sha3_512
27};
28
29enum class hmac_algorithm
30{
31 sha1, // insecure
32 sha256,
33 sha512
34};
35
37size_t FZ_PUBLIC_SYMBOL get_digest_size(hash_algorithm);
38
39class buffer;
40
42class FZ_PUBLIC_SYMBOL hash_accumulator final
43{
44public:
47 hash_accumulator(hmac_algorithm algorithm, std::vector<uint8_t> const& key);
48 hash_accumulator(hmac_algorithm algorithm, std::string_view const& key);
50
51 hash_accumulator(hash_accumulator const&) = delete;
52 hash_accumulator& operator=(hash_accumulator const&) = delete;
53
54 size_t digest_size() const;
55
56 void reinit();
57
58 void update(std::string_view const& data);
59 void update(std::basic_string_view<uint8_t> const& data);
60 void update(std::vector<uint8_t> const& data);
61 void update(uint8_t const* data, size_t size);
62 void update(buffer const& data);
63 void update(uint8_t in) {
64 update(&in, 1);
65 }
66
68 void update_uint32_be(uint32_t v);
69
71 void update_with_length(std::string_view const& data);
72
74 std::vector<uint8_t> digest();
75 void digest(uint8_t* out, size_t s);
76
77 operator std::vector<uint8_t>() {
78 return digest();
79 }
80
81 bool is_digest(std::string_view const& ref);
82 bool is_digest(uint8_t const* ref, size_t s);
83
84 template<typename T>
85 hash_accumulator& operator<<(T && in) {
86 update(std::forward<T>(in));
87 return *this;
88 }
89
91 std::vector<std::uint8_t> export_state();
92 bool import_state(std::vector<std::uint8_t> const& state);
93
94 class impl;
95private:
96 impl* impl_;
97};
98
103std::vector<uint8_t> FZ_PUBLIC_SYMBOL md5(std::string_view const& data);
104std::vector<uint8_t> FZ_PUBLIC_SYMBOL md5(std::vector<uint8_t> const& data);
105
107std::vector<uint8_t> FZ_PUBLIC_SYMBOL sha1(std::string_view const& data);
108std::vector<uint8_t> FZ_PUBLIC_SYMBOL sha1(std::vector<uint8_t> const& data);
109
111std::vector<uint8_t> FZ_PUBLIC_SYMBOL sha256(std::string_view const& data);
112std::vector<uint8_t> FZ_PUBLIC_SYMBOL sha256(std::vector<uint8_t> const& data);
113
115std::vector<uint8_t> FZ_PUBLIC_SYMBOL sha384(std::string_view const& data);
116std::vector<uint8_t> FZ_PUBLIC_SYMBOL sha384(std::vector<uint8_t> const& data);
117
119std::vector<uint8_t> FZ_PUBLIC_SYMBOL sha512(std::string_view const& data);
120std::vector<uint8_t> FZ_PUBLIC_SYMBOL sha512(std::vector<uint8_t> const& data);
121
126std::vector<uint8_t> FZ_PUBLIC_SYMBOL hmac_sha1(std::string_view const& key, std::string_view const& data);
127std::vector<uint8_t> FZ_PUBLIC_SYMBOL hmac_sha1(std::vector<uint8_t> const& key, std::vector<uint8_t> const& data);
128std::vector<uint8_t> FZ_PUBLIC_SYMBOL hmac_sha1(std::vector<uint8_t> const& key, std::string_view const& data);
129std::vector<uint8_t> FZ_PUBLIC_SYMBOL hmac_sha1(std::string_view const& key, std::vector<uint8_t> const& data);
130
132std::vector<uint8_t> FZ_PUBLIC_SYMBOL hmac_sha256(std::string_view const& key, std::string_view const& data);
133std::vector<uint8_t> FZ_PUBLIC_SYMBOL hmac_sha256(std::vector<uint8_t> const& key, std::vector<uint8_t> const& data);
134std::vector<uint8_t> FZ_PUBLIC_SYMBOL hmac_sha256(std::vector<uint8_t> const& key, std::string_view const& data);
135std::vector<uint8_t> FZ_PUBLIC_SYMBOL hmac_sha256(std::string_view const& key, std::vector<uint8_t> const& data);
136
137std::vector<uint8_t> FZ_PUBLIC_SYMBOL pbkdf2_hmac_sha256(std::basic_string_view<uint8_t> const& password, std::basic_string_view<uint8_t> const& salt, size_t length, unsigned int iterations);
138
139template <typename PasswordContainer, typename SaltContainer,
140 std::enable_if_t<sizeof(typename PasswordContainer::value_type) == sizeof(uint8_t) &&
141 sizeof(typename SaltContainer::value_type) == sizeof(uint8_t)>* = nullptr>
142std::vector<uint8_t> pbkdf2_hmac_sha256(PasswordContainer const& password, SaltContainer const& salt, size_t length, unsigned int iterations)
143{
144 return pbkdf2_hmac_sha256(std::basic_string_view<uint8_t>(reinterpret_cast<uint8_t const*>(password.data()), password.size()),
145 std::basic_string_view<uint8_t>(reinterpret_cast<uint8_t const*>(salt.data()), salt.size()),
146 length, iterations);
147}
148}
149
150#endif
The buffer class is a simple buffer where data can be appended at the end and consumed at the front....
Definition buffer.hpp:28
Accumulator for hashing large amounts of data.
Definition hash.hpp:43
std::vector< std::uint8_t > export_state()
Currently only implemented for SHA1.
std::vector< uint8_t > digest()
Returns the raw digest and reinitializes the accumulator.
hash_accumulator(hash_algorithm algorithm)
Creates an initialized accumulator for the passed algorithm.
void update_with_length(std::string_view const &data)
Also feeds length, as uint32 in network byte order, to the hash.
void update_uint32_be(uint32_t v)
If platform is little-endian, converts to big-endian, aka network byte order, before feeding the hash...
Sets some global macros and further includes string.hpp.
The namespace used by libfilezilla.
Definition apply.hpp:17
std::vector< uint8_t > sha1(std::string_view const &data)
Standard SHA1.
hash_algorithm
List of supported hashing algorithms.
Definition hash.hpp:18
std::vector< uint8_t > md5(std::string_view const &data)
Standard MD5.
size_t get_digest_size(hash_algorithm)
Returns digest size in bytes.
std::vector< uint8_t > hmac_sha1(std::string_view const &key, std::string_view const &data)
Standard HMAC using SHA1.
std::vector< uint8_t > sha512(std::string_view const &data)
Standard SHA512.
std::vector< uint8_t > sha384(std::string_view const &data)
Standard SHA384.
std::vector< uint8_t > sha256(std::string_view const &data)
Standard SHA256.
std::vector< uint8_t > hmac_sha256(std::string_view const &key, std::string_view const &data)
Standard HMAC using SHA256.