43template<
size_t a_ring_size,
size_t a_outputs,
bool a_rct, rct::RangeProofType range_proof_type = rct::RangeProofBorromean,
int bp_version = 2>
46 static_assert(0 < a_ring_size,
"ring_size must be greater than 0");
49 static const size_t loop_count = a_rct ? (a_ring_size <= 2 ? 50 : 10) : a_ring_size < 100 ? 100 : 10;
52 static const bool rct = a_rct;
65 std::vector<tx_destination_entry> destinations;
67 for (
size_t n = 1; n <
outputs; ++n)
71 std::vector<crypto::secret_key> additional_tx_keys;
72 std::unordered_map<crypto::public_key, cryptonote::subaddress_index> subaddresses;
75 if (!construct_tx_and_get_tx_key(this->m_miners[this->
real_source_idx].get_keys(), subaddresses, this->
m_sources, destinations,
cryptonote::account_public_address{}, std::vector<uint8_t>(),
m_tx, tx_key, additional_tx_keys,
rct, rct_config))
105template<
size_t a_ring_size,
size_t a_outputs,
size_t a_num_txes,
size_t extra_outs = 0>
108 static_assert(0 < a_ring_size,
"ring_size must be greater than 0");
126 std::vector<tx_destination_entry> destinations;
128 for (
size_t n = 1; n <
outputs; ++n)
132 std::vector<crypto::secret_key> additional_tx_keys;
133 std::unordered_map<crypto::public_key, cryptonote::subaddress_index> subaddresses;
136 m_txes.resize(a_num_txes + (extra_outs > 0 ? 1 : 0));
137 for (
size_t n = 0; n < a_num_txes; ++n)
139 if (!construct_tx_and_get_tx_key(this->m_miners[this->
real_source_idx].get_keys(), subaddresses, this->
m_sources, destinations,
cryptonote::account_public_address{}, std::vector<uint8_t>(),
m_txes[n], tx_key, additional_tx_keys,
true, {
rct::RangeProofPaddedBulletproof, 2}))
145 destinations.clear();
147 for (
size_t n = 1; n < extra_outs; ++n)
150 if (!construct_tx_and_get_tx_key(this->m_miners[this->
real_source_idx].get_keys(), subaddresses, this->
m_sources, destinations,
cryptonote::account_public_address{}, std::vector<uint8_t>(),
m_txes.back(), tx_key, additional_tx_keys,
true, {
rct::RangeProofMultiOutputBulletproof, 2}))
159 std::vector<const rct::rctSig*> rvv;
160 rvv.reserve(
m_txes.size());
161 for (
size_t n = 0; n <
m_txes.size(); ++n)
173 std::vector<cryptonote::transaction>
m_txes;
crypto::secret_key generate(const crypto::secret_key &recovery_key=crypto::secret_key(), bool recover=false, bool two_random=false)
Definition account.cpp:166
const account_keys & get_keys() const
Definition account.cpp:267
std::vector< txin_v > vin
Definition cryptonote_basic.h:178
Definition cryptonote_basic.h:205
rct::rctSig rct_signatures
Definition cryptonote_basic.h:214
std::vector< std::vector< crypto::signature > > signatures
Definition cryptonote_basic.h:213
Definition multi_tx_test_base.h:42
std::vector< cryptonote::tx_source_entry > m_sources
Definition multi_tx_test_base.h:88
bool init()
Definition multi_tx_test_base.h:49
cryptonote::account_base m_miners[ring_size]
Definition multi_tx_test_base.h:84
static const size_t real_source_idx
Definition multi_tx_test_base.h:47
uint64_t m_source_amount
Definition multi_tx_test_base.h:86
Definition check_tx_signature.h:107
static const size_t loop_count
Definition check_tx_signature.h:111
bool init()
Definition check_tx_signature.h:117
std::vector< cryptonote::transaction > m_txes
Definition check_tx_signature.h:173
multi_tx_test_base< a_ring_size > base_class
Definition check_tx_signature.h:115
static const size_t ring_size
Definition check_tx_signature.h:112
cryptonote::account_base m_alice
Definition check_tx_signature.h:172
bool test()
Definition check_tx_signature.h:157
static const size_t outputs
Definition check_tx_signature.h:113
Definition check_tx_signature.h:45
static const size_t loop_count
Definition check_tx_signature.h:49
bool test()
Definition check_tx_signature.h:83
static const size_t ring_size
Definition check_tx_signature.h:50
crypto::hash m_tx_prefix_hash
Definition check_tx_signature.h:102
static const bool rct
Definition check_tx_signature.h:52
cryptonote::transaction m_tx
Definition check_tx_signature.h:101
cryptonote::account_base m_alice
Definition check_tx_signature.h:100
static const size_t outputs
Definition check_tx_signature.h:51
bool init()
Definition check_tx_signature.h:56
multi_tx_test_base< a_ring_size > base_class
Definition check_tx_signature.h:54
POD_CLASS hash
Definition hash.h:49
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
Holds cryptonote related classes and helpers.
Definition blockchain_db.cpp:45
Definition bulletproofs.cc:64
@ RCTTypeFull
Definition rctTypes.h:300
static bool verRctSimple(const rctSig &rv)
Definition rctSigs.h:135
bool verRct(const rctSig &rv, bool semantics)
Definition rctSigs.cpp:1318
bool verRctSemanticsSimple(const std::vector< const rctSig * > &rvv)
Definition rctSigs.cpp:1381
bool verRctNonSemanticsSimple(const rctSig &rv)
Definition rctSigs.cpp:1521
@ RangeProofMultiOutputBulletproof
Definition rctTypes.h:307
@ RangeProofPaddedBulletproof
Definition rctTypes.h:307
account_public_address m_account_address
Definition account.h:42
Definition cryptonote_basic.h:512
crypto::public_key m_spend_public_key
Definition cryptonote_basic.h:513
Definition cryptonote_tx_utils.h:75
Definition cryptonote_basic.h:139
crypto::key_image k_image
Definition cryptonote_basic.h:142
Definition rctTypes.h:308
uint8_t type
Definition rctTypes.h:319
Definition rctTypes.h:613