Electroneum
Toggle main menu visibility
Loading...
Searching...
No Matches
ge_frombytes_vartime.h
Go to the documentation of this file.
1
// Copyrights(c) 2017-2021, The Electroneum Project
2
// Copyrights(c) 2014-2019, The Monero Project
3
//
4
// All rights reserved.
5
//
6
// Redistribution and use in source and binary forms, with or without modification, are
7
// permitted provided that the following conditions are met:
8
//
9
// 1. Redistributions of source code must retain the above copyright notice, this list of
10
// conditions and the following disclaimer.
11
//
12
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
13
// of conditions and the following disclaimer in the documentation and/or other
14
// materials provided with the distribution.
15
//
16
// 3. Neither the name of the copyright holder nor the names of its contributors may be
17
// used to endorse or promote products derived from this software without specific
18
// prior written permission.
19
//
20
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
21
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
22
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
23
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
27
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
28
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29
//
30
// Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers
31
32
#pragma once
33
34
#include "
crypto/crypto.h
"
35
#include "
cryptonote_basic/cryptonote_basic.h
"
36
37
#include "
single_tx_test_base.h
"
38
39
class
test_ge_frombytes_vartime
:
public
multi_tx_test_base
<1>
40
{
41
public
:
42
static
const
size_t
loop_count
= 10000;
43
44
typedef
multi_tx_test_base<1>
base_class
;
45
46
bool
init
()
47
{
48
using namespace
cryptonote
;
49
50
if
(!
base_class::init
())
51
return
false
;
52
53
cryptonote::account_base
m_alice;
54
cryptonote::transaction
m_tx;
55
56
m_alice.
generate
();
57
58
std::vector<tx_destination_entry> destinations;
59
destinations.push_back(
tx_destination_entry
(1, m_alice.
get_keys
().
m_account_address
,
false
));
60
61
if
(!
construct_tx
(this->
m_miners
[this->
real_source_idx
].get_keys(), this->
m_sources
, destinations, boost::none, std::vector<uint8_t>(), m_tx, 0))
62
return
false
;
63
64
const
cryptonote::txin_to_key
& txin = boost::get<cryptonote::txin_to_key>(m_tx.
vin
[0]);
65
m_key = rct::ki2rct(txin.
k_image
);
66
67
return
true
;
68
}
69
70
bool
test
()
71
{
72
ge_p3
unp;
73
return
ge_frombytes_vartime
(&unp, (
const
unsigned
char
*) &m_key) == 0;
74
}
75
76
private
:
77
rct::key
m_key;
78
};
cryptonote::account_base
Definition
account.h:77
cryptonote::account_base::generate
crypto::secret_key generate(const crypto::secret_key &recovery_key=crypto::secret_key(), bool recover=false, bool two_random=false)
Definition
account.cpp:158
cryptonote::account_base::get_keys
const account_keys & get_keys() const
Definition
account.cpp:264
cryptonote::transaction_prefix::vin
std::vector< txin_v > vin
Definition
cryptonote_basic.h:263
cryptonote::transaction
Definition
cryptonote_basic.h:298
multi_tx_test_base
Definition
multi_tx_test_base.h:43
multi_tx_test_base< 1 >::m_sources
std::vector< cryptonote::tx_source_entry > m_sources
Definition
multi_tx_test_base.h:89
multi_tx_test_base< 1 >::init
bool init()
Definition
multi_tx_test_base.h:50
multi_tx_test_base< 1 >::m_miners
cryptonote::account_base m_miners[ring_size]
Definition
multi_tx_test_base.h:85
multi_tx_test_base< 1 >::real_source_idx
static const size_t real_source_idx
Definition
multi_tx_test_base.h:48
test_ge_frombytes_vartime
Definition
ge_frombytes_vartime.h:40
test_ge_frombytes_vartime::loop_count
static const size_t loop_count
Definition
ge_frombytes_vartime.h:42
test_ge_frombytes_vartime::init
bool init()
Definition
ge_frombytes_vartime.h:46
test_ge_frombytes_vartime::test
bool test()
Definition
ge_frombytes_vartime.h:70
test_ge_frombytes_vartime::base_class
multi_tx_test_base< 1 > base_class
Definition
ge_frombytes_vartime.h:44
ge_frombytes_vartime
int ge_frombytes_vartime(ge_p3 *, const unsigned char *)
crypto.h
cryptonote_basic.h
cryptonote
Holds cryptonote related classes and helpers.
Definition
ban.cpp:40
cryptonote::construct_tx
bool construct_tx(const account_keys &sender_account_keys, std::vector< tx_source_entry > &sources, const std::vector< tx_destination_entry > &destinations, const boost::optional< cryptonote::account_public_address > &change_addr, const std::vector< uint8_t > &extra, transaction &tx, uint64_t unlock_time)
Definition
cryptonote_tx_utils.cpp:694
single_tx_test_base.h
cryptonote::account_keys::m_account_address
account_public_address m_account_address
Definition
account.h:43
cryptonote::tx_destination_entry
Definition
cryptonote_tx_utils.h:84
cryptonote::txin_to_key
Definition
cryptonote_basic.h:198
cryptonote::txin_to_key::k_image
crypto::key_image k_image
Definition
cryptonote_basic.h:201
ge_p3
Definition
crypto-ops.h:46
rct::key
Definition
rctTypes.h:78
tests
performance_tests
ge_frombytes_vartime.h
Generated on
for Electroneum by
1.17.0