mirror of
https://github.com/EvernodeXRPL/hpcore.git
synced 2026-04-29 15:37:59 +00:00
40 lines
1.1 KiB
C++
40 lines
1.1 KiB
C++
#ifndef _HP_CRYPTO_
|
|
#define _HP_CRYPTO_
|
|
|
|
#include "pchheader.hpp"
|
|
|
|
/**
|
|
* Offers convenience functions for cryptographic operations wrapping libsodium.
|
|
* These functions are used for config and user/peer message authentication.
|
|
*/
|
|
namespace crypto
|
|
{
|
|
|
|
// Prefix byte to append to ed25519 keys.
|
|
static unsigned char KEYPFX_ed25519 = 0xED;
|
|
|
|
int init();
|
|
|
|
void generate_signing_keys(std::string &pubkey, std::string &seckey);
|
|
|
|
const std::string sign(std::string_view msg, std::string_view seckey);
|
|
|
|
int verify(std::string_view msg, std::string_view sig, std::string_view pubkey);
|
|
|
|
void random_bytes(std::string &result, const size_t len);
|
|
|
|
const std::string get_hash(std::string_view data);
|
|
|
|
const std::string get_hash(const unsigned char *data, size_t data_length);
|
|
|
|
const std::string get_hash(std::string_view s1, std::string_view s2);
|
|
|
|
const std::string get_hash(const std::vector<std::string_view> &sw_vect);
|
|
|
|
const std::string get_hash(const std::set<std::string> &sw_set);
|
|
|
|
const std::string generate_uuid();
|
|
|
|
} // namespace crypto
|
|
|
|
#endif |