/src/monero/monero/tests/fuzz/signature.cpp
Line | Count | Source |
1 | | // Copyright (c) 2017-2024, The Monero Project |
2 | | // |
3 | | // All rights reserved. |
4 | | // |
5 | | // Redistribution and use in source and binary forms, with or without modification, are |
6 | | // permitted provided that the following conditions are met: |
7 | | // |
8 | | // 1. Redistributions of source code must retain the above copyright notice, this list of |
9 | | // conditions and the following disclaimer. |
10 | | // |
11 | | // 2. Redistributions in binary form must reproduce the above copyright notice, this list |
12 | | // of conditions and the following disclaimer in the documentation and/or other |
13 | | // materials provided with the distribution. |
14 | | // |
15 | | // 3. Neither the name of the copyright holder nor the names of its contributors may be |
16 | | // used to endorse or promote products derived from this software without specific |
17 | | // prior written permission. |
18 | | // |
19 | | // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY |
20 | | // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF |
21 | | // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL |
22 | | // THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
23 | | // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
24 | | // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
25 | | // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, |
26 | | // STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF |
27 | | // THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
28 | | |
29 | | #include "include_base_utils.h" |
30 | | #include "file_io_utils.h" |
31 | | #include "cryptonote_basic/blobdatatype.h" |
32 | | #include "cryptonote_basic/cryptonote_basic.h" |
33 | | #include "cryptonote_basic/cryptonote_format_utils.h" |
34 | | #include "wallet/wallet2.h" |
35 | | #include "fuzzer.h" |
36 | | |
37 | | static tools::wallet2 *wallet = NULL; |
38 | | static cryptonote::account_public_address address; |
39 | | |
40 | 2 | BEGIN_INIT_SIMPLE_FUZZER() |
41 | 2 | static tools::wallet2 local_wallet(cryptonote::TESTNET); |
42 | 2 | wallet = &local_wallet; |
43 | | |
44 | 2 | static const char * const spendkey_hex = "0b4f47697ec99c3de6579304e5f25c68b07afbe55b71d99620bf6cbf4e45a80f"; |
45 | 2 | crypto::secret_key spendkey; |
46 | 2 | epee::string_tools::hex_to_pod(spendkey_hex, spendkey); |
47 | | |
48 | 2 | wallet->init("", boost::none, "", 0, true, epee::net_utils::ssl_support_t::e_ssl_support_disabled); |
49 | 2 | wallet->set_subaddress_lookahead(1, 1); |
50 | 2 | wallet->generate("", "", spendkey, true, false); |
51 | | |
52 | 2 | cryptonote::address_parse_info info; |
53 | 2 | if (!cryptonote::get_account_address_from_str_or_url(info, cryptonote::TESTNET, "9uVsvEryzpN8WH2t1WWhFFCG5tS8cBNdmJYNRuckLENFimfauV5pZKeS1P2CbxGkSDTUPHXWwiYE5ZGSXDAGbaZgDxobqDN")) |
54 | 0 | { |
55 | 0 | std::cerr << "failed to parse address" << std::endl; |
56 | 0 | return 1; |
57 | 0 | } |
58 | 1 | address = info.address; |
59 | 1 | END_INIT_SIMPLE_FUZZER() |
60 | | |
61 | 19.9k | BEGIN_SIMPLE_FUZZER() |
62 | 9.95k | tools::wallet2::message_signature_result_t result = wallet->verify("test", address, std::string((const char*)buf, len)); |
63 | 9.95k | std::cout << "Signature " << (result.valid ? "valid" : "invalid") << std::endl; |
64 | | END_SIMPLE_FUZZER() |