blob: f5f094689e817712bafbb157934534677908a422 (
plain)
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
|
#pragma once
#include <openssl/rand.h>
#include <iostream>
#include <limits>
namespace bmcweb
{
struct OpenSSLGenerator
{
uint8_t operator()()
{
uint8_t index = 0;
int rc = RAND_bytes(&index, sizeof(index));
if (rc != opensslSuccess)
{
std::cerr << "Cannot get random number\n";
err = true;
}
return index;
}
static constexpr uint8_t max()
{
return std::numeric_limits<uint8_t>::max();
}
static constexpr uint8_t min()
{
return std::numeric_limits<uint8_t>::min();
}
bool error() const
{
return err;
}
// all generators require this variable
using result_type = uint8_t;
private:
// RAND_bytes() returns 1 on success, 0 otherwise. -1 if bad function
static constexpr int opensslSuccess = 1;
bool err = false;
};
} // namespace bmcweb
|