forked from data61/MP-SPDZ
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathHash.h
61 lines (50 loc) · 1.18 KB
/
Hash.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
#ifndef _SHA1
#define _SHA1
#include <sodium.h>
#include <vector>
using namespace std;
#include "octetStream.h"
class Hash
{
crypto_generichash_state* state;
public:
static const int hash_length = crypto_generichash_BYTES;
unsigned size;
Hash();
~Hash();
void reset();
void update(const void *dataIn, unsigned long len)
{
crypto_generichash_update(state, (unsigned char*)dataIn, len);
size += len;
}
void update(const octetStream& os);
template<class T>
void update(const T& x)
{
update(x.get_ptr(), x.size());
}
template<class T>
void update(const vector<T>& v, const vector<int>& bit_lengths)
{
assert(v.size() == bit_lengths.size());
octetStream tmp(v.size() * sizeof(T));
for (size_t i = 0; i < v.size(); i++)
v[i].pack(tmp, bit_lengths[i]);
tmp.append(0);
update(tmp);
}
void update(const string& str);
void final(unsigned char hashout[hash_length])
{
final(hashout, hash_length);
}
void final(unsigned char* hashout, size_t length)
{
crypto_generichash_final(state, hashout, length);
}
void final(octetStream& os);
octetStream final();
};
void hash_update(Hash *ctx, const void *dataIn, unsigned long len);
#endif