TrinityCore
CryptoRandom.h
Go to the documentation of this file.
1
/*
2
* This file is part of the TrinityCore Project. See AUTHORS file for Copyright information
3
*
4
* This program is free software; you can redistribute it and/or modify it
5
* under the terms of the GNU General Public License as published by the
6
* Free Software Foundation; either version 2 of the License, or (at your
7
* option) any later version.
8
*
9
* This program is distributed in the hope that it will be useful, but WITHOUT
10
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
12
* more details.
13
*
14
* You should have received a copy of the GNU General Public License along
15
* with this program. If not, see <http://www.gnu.org/licenses/>.
16
*/
17
18
#ifndef TRINITY_CRYPTORANDOM_H
19
#define TRINITY_CRYPTORANDOM_H
20
21
#include "
Define.h
"
22
#include <array>
23
24
namespace
Trinity
25
{
26
namespace
Crypto
27
{
28
void
TC_COMMON_API
GetRandomBytes
(
uint8
* buf,
size_t
len);
29
30
template
<
typename
Container>
31
void
GetRandomBytes
(Container& c)
32
{
33
GetRandomBytes
(std::data(c),
std::size
(c));
34
}
35
36
template
<
size_t
S>
37
std::array<uint8, S>
GetRandomBytes
()
38
{
39
std::array<uint8, S> arr;
40
GetRandomBytes
(arr);
41
return
arr;
42
}
43
}
44
}
45
46
#endif
Define.h
uint8
uint8_t uint8
Definition:
Define.h:144
TC_COMMON_API
#define TC_COMMON_API
Definition:
Define.h:99
Trinity::Crypto::GetRandomBytes
void TC_COMMON_API GetRandomBytes(uint8 *buf, size_t len)
Definition:
CryptoRandom.cpp:22
Trinity
Definition:
AsioHacksFwd.h:58
UF::size
constexpr std::size_t size()
Definition:
UpdateField.h:796
common
Cryptography
CryptoRandom.h
Generated on Thu Mar 14 2024 23:39:07 for TrinityCore by
1.9.4