Electroneum
Toggle main menu visibility
Loading...
Searching...
No Matches
signature.cpp
Go to the documentation of this file.
1
// Copyright (c) 2017-Present, Electroneum
2
// Copyright (c) 2017-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
#include "
include_base_utils.h
"
31
#include "
file_io_utils.h
"
32
#include "
cryptonote_basic/blobdatatype.h
"
33
#include "
cryptonote_basic/cryptonote_basic.h
"
34
#include "
cryptonote_basic/cryptonote_format_utils.h
"
35
#include "
wallet/wallet2.h
"
36
#include "
fuzzer.h
"
37
38
class
SignatureFuzzer
:
public
Fuzzer
39
{
40
public
:
41
SignatureFuzzer
():
Fuzzer
(), wallet(
cryptonote
::TESTNET) {}
42
virtual
int
init
();
43
virtual
int
run
(
const
std::string &filename);
44
45
private
:
46
tools::wallet2
wallet;
47
cryptonote::account_public_address
address
;
48
};
49
50
int
SignatureFuzzer::init
()
51
{
52
static
const
char
*
const
spendkey_hex =
"0b4f47697ec99c3de6579304e5f25c68b07afbe55b71d99620bf6cbf4e45a80f"
;
53
crypto::secret_key
spendkey
;
54
epee::string_tools::hex_to_pod
(spendkey_hex,
spendkey
);
55
56
try
57
{
58
wallet.init(
""
, boost::none, boost::asio::ip::tcp::endpoint{}, 0,
true
,
epee::net_utils::ssl_support_t::e_ssl_support_disabled
);
59
wallet.set_subaddress_lookahead(1, 1);
60
wallet.generate(
""
,
""
,
spendkey
,
true
,
false
);
61
62
cryptonote::address_parse_info
info
;
63
if
(!
cryptonote::get_account_address_from_str_or_url
(
info
,
cryptonote::TESTNET
,
"9uVsvEryzpN8WH2t1WWhFFCG5tS8cBNdmJYNRuckLENFimfauV5pZKeS1P2CbxGkSDTUPHXWwiYE5ZGSXDAGbaZgDxobqDN"
))
64
{
65
std::cerr <<
"failed to parse address"
<< std::endl;
66
return
1;
67
}
68
address =
info
.address;
69
}
70
catch
(
const
std::exception &e)
71
{
72
std::cerr <<
"Error on SignatureFuzzer::init: "
<< e.what() << std::endl;
73
return
1;
74
}
75
return
0;
76
}
77
78
int
SignatureFuzzer::run
(
const
std::string &filename)
79
{
80
std::string s;
81
82
if
(!
epee::file_io_utils::load_file_to_string
(filename, s))
83
{
84
std::cout <<
"Error: failed to load file "
<< filename << std::endl;
85
return
1;
86
}
87
88
bool
valid = wallet.verify(
"test"
, address, s);
89
std::cout <<
"Signature "
<< (valid ?
"valid"
:
"invalid"
) << std::endl;
90
91
return
0;
92
}
93
94
int
main
(
int
argc,
const
char
**argv)
95
{
96
TRY_ENTRY
();
97
SignatureFuzzer
fuzzer;
98
return
run_fuzzer
(argc, argv, fuzzer);
99
CATCH_ENTRY_L0
(
"main"
, 1);
100
}
main
int main()
Definition
archivertest.cpp:283
blobdatatype.h
Fuzzer
Definition
fuzzer.h:33
SignatureFuzzer
Definition
signature.cpp:39
SignatureFuzzer::run
virtual int run(const std::string &filename)
Definition
signature.cpp:78
SignatureFuzzer::init
virtual int init()
Definition
signature.cpp:50
SignatureFuzzer::SignatureFuzzer
SignatureFuzzer()
Definition
signature.cpp:41
tools::wallet2
Definition
wallet2.h:210
cryptonote_basic.h
cryptonote_format_utils.h
file_io_utils.h
run_fuzzer
int run_fuzzer(int argc, const char **argv, Fuzzer &fuzzer)
Definition
fuzzer.cpp:48
fuzzer.h
include_base_utils.h
CATCH_ENTRY_L0
#define CATCH_ENTRY_L0(lacation, return_val)
Definition
misc_log_ex.h:165
TRY_ENTRY
#define TRY_ENTRY()
Definition
misc_log_ex.h:151
crypto::secret_key
epee::mlocked< tools::scrubbed< ec_scalar > > secret_key
Definition
crypto.h:82
cryptonote
Holds cryptonote related classes and helpers.
Definition
ban.cpp:40
cryptonote::TESTNET
@ TESTNET
Definition
cryptonote_config.h:249
cryptonote::get_account_address_from_str_or_url
bool get_account_address_from_str_or_url(address_parse_info &info, network_type nettype, const std::string &str_or_url, std::function< std::string(const std::string &, const std::vector< std::string > &, bool)> dns_confirm)
Definition
cryptonote_basic_impl.cpp:348
epee::file_io_utils::load_file_to_string
bool load_file_to_string(const std::string &path_to_file, std::string &target_str, size_t max_size=1000000000)
Definition
file_io_utils.h:130
epee::net_utils::ssl_support_t::e_ssl_support_disabled
@ e_ssl_support_disabled
Definition
net_ssl.h:47
epee::string_tools::hex_to_pod
bool hex_to_pod(const std::string &hex_str, t_pod_type &s)
Definition
string_tools.h:324
info
CXA_THROW_INFO_T * info
Definition
stack_trace.cpp:91
cryptonote::account_public_address
Definition
cryptonote_basic.h:75
cryptonote::address_parse_info
Definition
cryptonote_basic_impl.h:80
address
const char * address
Definition
multisig.cpp:37
spendkey
const char * spendkey
Definition
multisig.cpp:38
wallet2.h
tests
fuzz
signature.cpp
Generated on
for Electroneum by
1.17.0