Electroneum
Toggle main menu visibility
Loading...
Searching...
No Matches
cold-transaction.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
ColdTransactionFuzzer
:
public
Fuzzer
39
{
40
public
:
41
ColdTransactionFuzzer
(): wallet(
cryptonote
::TESTNET) {}
42
virtual
int
init
();
43
virtual
int
run
(
const
std::string &filename);
44
45
private
:
46
tools::wallet2
wallet;
47
};
48
49
50
int
ColdTransactionFuzzer::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
catch
(
const
std::exception &e)
63
{
64
std::cerr <<
"Error on ColdTransactionFuzzer::init: "
<< e.what() << std::endl;
65
return
1;
66
}
67
return
0;
68
}
69
70
int
ColdTransactionFuzzer::run
(
const
std::string &filename)
71
{
72
std::string s;
73
74
if
(!
epee::file_io_utils::load_file_to_string
(filename, s))
75
{
76
std::cout <<
"Error: failed to load file "
<< filename << std::endl;
77
return
1;
78
}
79
s = std::string(
"\x01\x16serialization::archive"
) + s;
80
try
81
{
82
tools::wallet2::unsigned_tx_set
exported_txs;
83
std::stringstream iss;
84
iss << s;
85
boost::archive::portable_binary_iarchive
ar(iss);
86
ar >> exported_txs;
87
std::vector<tools::wallet2::pending_tx> ptx;
88
bool
success = wallet.sign_tx(exported_txs,
"/tmp/cold-transaction-test-signed"
, ptx);
89
std::cout << (success ?
"signed"
:
"error"
) << std::endl;
90
}
91
catch
(
const
std::exception &e)
92
{
93
std::cerr <<
"Failed to sign transaction: "
<< e.what() << std::endl;
94
return
1;
95
}
96
return
0;
97
}
98
99
int
main
(
int
argc,
const
char
**argv)
100
{
101
TRY_ENTRY
();
102
ColdTransactionFuzzer
fuzzer;
103
return
run_fuzzer
(argc, argv, fuzzer);
104
CATCH_ENTRY_L0
(
"main"
, 1);
105
}
main
int main()
Definition
archivertest.cpp:283
blobdatatype.h
ColdTransactionFuzzer
Definition
cold-transaction.cpp:39
ColdTransactionFuzzer::init
virtual int init()
Definition
cold-transaction.cpp:50
ColdTransactionFuzzer::run
virtual int run(const std::string &filename)
Definition
cold-transaction.cpp:70
ColdTransactionFuzzer::ColdTransactionFuzzer
ColdTransactionFuzzer()
Definition
cold-transaction.cpp:41
Fuzzer
Definition
fuzzer.h:33
boost::archive::portable_binary_iarchive
Definition
portable_binary_iarchive.hpp:81
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
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
tools::wallet2::unsigned_tx_set
Definition
wallet2.h:498
spendkey
const char * spendkey
Definition
multisig.cpp:38
wallet2.h
tests
fuzz
cold-transaction.cpp
Generated on
for Electroneum by
1.17.0