35#include <boost/optional.hpp>
75 std::vector<public_key> keys;
80 std::vector<secret_key> keys;
175 static_assert(std::is_standard_layout<T>(),
"cannot write random bytes into non-standard layout type");
176 static_assert(std::is_trivially_copyable<T>(),
"cannot write random bytes into non-trivially copyable type");
177 typename std::remove_cv<T>::type
res;
195 typename std::enable_if<std::is_integral<T>::value,
T>::type
rand_range(
T range_min,
T range_max) {
197 std::uniform_int_distribution<T> dis(range_min, range_max);
204 typename std::enable_if<std::is_unsigned<T>::value,
T>::type
rand_idx(
T sz) {
283 const public_key *
const *pubs, std::size_t pubs_count,
289 const public_key *
const *pubs, std::size_t pubs_count,
297 const std::vector<const public_key *> &pubs,
303 const std::vector<const public_key *> &pubs,
static bool check_key(const public_key &)
Definition crypto.cpp:175
void operator=(const crypto_ops &)
static void derive_secret_key(const key_derivation &, std::size_t, const secret_key &, secret_key &)
static bool check_tx_proof(const hash &, const public_key &, const public_key &, const boost::optional< public_key > &, const public_key &, const signature &, const int)
Definition crypto.cpp:508
static void generate_signature(const hash &, const public_key &, const secret_key &, signature &)
Definition crypto.cpp:290
static bool derive_subaddress_public_key(const public_key &, const key_derivation &, std::size_t, public_key &)
Definition crypto.cpp:245
static bool derive_public_key(const key_derivation &, std::size_t, const public_key &, public_key &)
static void derive_view_tag(const key_derivation &, std::size_t, view_tag &)
crypto_ops(const crypto_ops &)
static void derivation_to_scalar(const key_derivation &derivation, size_t output_index, ec_scalar &res)
Definition crypto.cpp:205
static bool check_signature(const hash &, const public_key &, const signature &)
Definition crypto.cpp:319
static void generate_ring_signature(const hash &, const key_image &, const public_key *const *, std::size_t, const secret_key &, std::size_t, signature *)
static void generate_tx_proof(const hash &, const public_key &, const public_key &, const boost::optional< public_key > &, const public_key &, const secret_key &, signature &)
Definition crypto.cpp:423
static secret_key generate_keys(public_key &pub, secret_key &sec, const secret_key &recovery_key=secret_key(), bool recover=false)
Definition crypto.cpp:153
static bool generate_key_derivation(const public_key &, const secret_key &, key_derivation &)
Definition crypto.cpp:190
static void generate_tx_proof_v1(const hash &, const public_key &, const public_key &, const boost::optional< public_key > &, const public_key &, const secret_key &, signature &)
Definition crypto.cpp:347
static bool check_ring_signature(const hash &, const key_image &, const public_key *const *, std::size_t, const signature *)
static bool secret_key_to_public_key(const secret_key &, public_key &)
Definition crypto.cpp:180
static void generate_key_image(const public_key &, const secret_key &, key_image &)
Definition crypto.cpp:621
#define CRYPTO_MAKE_HASHABLE_CONSTANT_TIME(type)
Definition generic-ops.h:84
#define CRYPTO_MAKE_COMPARABLE(type)
Definition generic-ops.h:39
#define CRYPTO_MAKE_HASHABLE(type)
Definition generic-ops.h:80
void * memcpy(void *a, const void *b, size_t c)
Definition glibc_compat.cpp:16
const char * res
Definition hmac_keccak.cpp:42
const char * key
Definition hmac_keccak.cpp:40
static int version
Definition mdb_load.c:29
crypto namespace.
Definition crypto.cpp:60
POD_CLASS secret_keyV
Definition crypto.h:79
void add_extra_entropy_thread_safe(const void *ptr, size_t bytes)
Definition crypto.cpp:105
const crypto::public_key null_pkey
Definition crypto.cpp:74
void generate_signature(const hash &prefix_hash, const public_key &pub, const secret_key &sec, signature &sig)
Definition crypto.h:252
POD_CLASS public_keyM
Definition crypto.h:84
void derive_view_tag(const key_derivation &derivation, std::size_t output_index, view_tag &vt)
Definition crypto.h:312
bool check_key(const public_key &key)
Definition crypto.h:216
void generate_random_bytes_thread_safe(size_t N, uint8_t *bytes)
Definition crypto.cpp:99
POD_CLASS ec_point
Definition crypto.h:55
void generate_tx_proof(const hash &prefix_hash, const public_key &R, const public_key &A, const boost::optional< public_key > &B, const public_key &D, const secret_key &r, signature &sig)
Definition crypto.h:263
T rand()
Definition crypto.h:174
POD_CLASS signature
Definition crypto.h:98
const crypto::secret_key null_skey
Definition crypto.cpp:75
bool operator>(const public_key &p1, const public_key &p2)
Definition crypto.h:345
epee::mlocked< tools::scrubbed< ec_scalar > > secret_key
Definition crypto.h:72
std::enable_if< std::is_integral< T >::value, T >::type rand_range(T range_min, T range_max)
Definition crypto.h:195
unsigned char uint8_t
Definition hash.h:125
POD_CLASS public_keyV
Definition crypto.h:74
bool derive_subaddress_public_key(const public_key &out_key, const key_derivation &derivation, std::size_t output_index, public_key &result)
Definition crypto.h:246
POD_CLASS key_derivation
Definition crypto.h:91
POD_CLASS view_tag
Definition crypto.h:103
POD_CLASS public_key_memsafe
Definition crypto.h:68
secret_key generate_keys(public_key &pub, secret_key &sec, const secret_key &recovery_key=secret_key(), bool recover=false)
Definition crypto.h:210
void derive_secret_key(const key_derivation &derivation, std::size_t output_index, const secret_key &base, secret_key &derived_key)
Definition crypto.h:242
std::vector< secret_keyV > column_vectors
Definition crypto.h:87
unsigned __int64 uint64_t
Definition hash.h:137
bool generate_key_derivation(const public_key &key1, const secret_key &key2, key_derivation &derivation)
Definition crypto.h:232
void generate_ring_signature(const hash &prefix_hash, const key_image &image, const public_key *const *pubs, std::size_t pubs_count, const secret_key &sec, std::size_t sec_index, signature *sig)
Definition crypto.h:282
POD_CLASS public_key
Definition crypto.h:64
bool check_tx_proof(const hash &prefix_hash, const public_key &R, const public_key &A, const boost::optional< public_key > &B, const public_key &D, const signature &sig, const int version)
Definition crypto.h:269
void random32_unbiased(unsigned char *bytes)
Definition crypto.cpp:123
bool derive_public_key(const key_derivation &derivation, std::size_t output_index, const public_key &base, public_key &derived_key)
Definition crypto.h:235
std::ostream & operator<<(std::ostream &o, const crypto::public_key &v)
Definition crypto.h:316
POD_CLASS key_image
Definition crypto.h:95
bool operator<(const public_key &p1, const public_key &p2)
Definition crypto.h:344
bool check_signature(const hash &prefix_hash, const public_key &pub, const signature &sig)
Definition crypto.h:255
POD_CLASS ec_scalar
Definition crypto.h:59
bool secret_key_to_public_key(const secret_key &sec, public_key &pub)
Definition crypto.h:222
std::enable_if< std::is_unsigned< T >::value, T >::type rand_idx(T sz)
Definition crypto.h:204
void hash_to_scalar(const void *data, size_t length, ec_scalar &res)
Definition crypto.cpp:143
int rows
Definition crypto.h:76
POD_CLASS hash
Definition hash.h:49
void generate_tx_proof_v1(const hash &prefix_hash, const public_key &R, const public_key &A, const boost::optional< public_key > &B, const public_key &D, const secret_key &r, signature &sig)
Definition crypto.h:266
void derivation_to_scalar(const key_derivation &derivation, size_t output_index, ec_scalar &res)
Definition crypto.h:239
bool check_ring_signature(const hash &prefix_hash, const key_image &image, const public_key *const *pubs, std::size_t pubs_count, const signature *sig)
Definition crypto.h:288
span< const std::uint8_t > as_byte_span(const T &src) noexcept
Definition span.h:161
#define POD_CLASS
Definition pod-class.h:43
tools::wallet2::message_signature_result_t result
Definition signature.cpp:62
static constexpr result_type min()
Definition crypto.h:187
result_type operator()() const
Definition crypto.h:189
uint64_t result_type
Definition crypto.h:186
static constexpr result_type max()
Definition crypto.h:188
const crypto::secret_key & sk
Definition crypto.h:324
static void formatted(std::ostream &out, const span< const std::uint8_t > src)
Append < + src + > as hex to out.
Definition hex.cpp:77
Definition chaingen.h:294
std::string data
Definition base58.cpp:37
static crypto::key_image generate_key_image()
Definition ringdb.cpp:55