mirror of
https://git.wownero.com/wownero/wownero.git
synced 2025-01-08 03:18:53 +00:00
Merge branch 'release-v0.3.0.0' into upstream
This commit is contained in:
commit
9d952da3a0
@ -95,7 +95,7 @@ Dates are provided in the format YYYY-MM-DD.
|
|||||||
| ------------------------------ | -----------| ----------------- | ---------------------- | -------------------------- | ---------------------------------------------------------------------------------- |
|
| ------------------------------ | -----------| ----------------- | ---------------------- | -------------------------- | ---------------------------------------------------------------------------------- |
|
||||||
| 1 | 2018-04-01 | v7 | v0.1.0.0 | v0.1.0.0 | Cryptonight variant 1, ringsize >= 8, sorted inputs
|
| 1 | 2018-04-01 | v7 | v0.1.0.0 | v0.1.0.0 | Cryptonight variant 1, ringsize >= 8, sorted inputs
|
||||||
| 6969 | 2018-04-24 | v8 | v0.2.0.0 | v0.2.0.0 | Bulletproofs, LWMA difficulty algorithm, ringsize >= 10, reduce unlock to 4
|
| 6969 | 2018-04-24 | v8 | v0.2.0.0 | v0.2.0.0 | Bulletproofs, LWMA difficulty algorithm, ringsize >= 10, reduce unlock to 4
|
||||||
| 53666 | 2018-10-06 | v9 | v0.3.0.0 | v0.3.0.0 | Cryptonight variant 2, LWMA v2, ringsize = 22, XXX
|
| 53666 | 2018-10-06 | v9 | v0.3.0.0 | v0.3.0.1 | Cryptonight variant 2, LWMA v2, ringsize = 22, XXX
|
||||||
|
|
||||||
X's indicate that these details have not been determined as of commit date.
|
X's indicate that these details have not been determined as of commit date.
|
||||||
|
|
||||||
|
2
external/unbound
vendored
2
external/unbound
vendored
@ -1 +1 @@
|
|||||||
Subproject commit 193bdc4ee3fe2b0d17e547e86512528c2614483a
|
Subproject commit 7f23967954736dcaa366806b9eaba7e2bdfede11
|
Binary file not shown.
@ -185,7 +185,10 @@ namespace cryptonote
|
|||||||
ADD_CHECKPOINT(20000, "52cc7edcb49eb02f28a653b824089a726f4050eb210263ee6f4180d388a1e5cc");
|
ADD_CHECKPOINT(20000, "52cc7edcb49eb02f28a653b824089a726f4050eb210263ee6f4180d388a1e5cc");
|
||||||
ADD_CHECKPOINT(30000, "d22fde5dd240ade16d3250eb0aa5d1c16dc7cb51c20484e05eb274911032b3fa");
|
ADD_CHECKPOINT(30000, "d22fde5dd240ade16d3250eb0aa5d1c16dc7cb51c20484e05eb274911032b3fa");
|
||||||
ADD_CHECKPOINT(40000, "aee0d642322542ba069cb1c58ab2acd3560f108d4682c3dc3cb15a54d442d91f");
|
ADD_CHECKPOINT(40000, "aee0d642322542ba069cb1c58ab2acd3560f108d4682c3dc3cb15a54d442d91f");
|
||||||
ADD_CHECKPOINT(50000, "5286ac2a0f39b3aefcba363cd71f2760bd1e0d763cbc81026ebdc3f80a86541f");
|
ADD_CHECKPOINT(50000, "5286ac2a0f39b3aefcba363cd71f2760bd1e0d763cbc81026ebdc3f80a86541f");
|
||||||
|
ADD_CHECKPOINT(53666, "3f43f56f66ef0c43cf2fd14d0d28fa2aae0ef8f40716773511345750770f1255"); //Hard fork to v9
|
||||||
|
ADD_CHECKPOINT(54500, "8ed3078b389c2b44add007803d741b58d3fbed2e1ba4139bda702152d8773c9b");
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4441,7 +4441,7 @@ void Blockchain::cancel()
|
|||||||
}
|
}
|
||||||
|
|
||||||
#if defined(PER_BLOCK_CHECKPOINT)
|
#if defined(PER_BLOCK_CHECKPOINT)
|
||||||
static const char expected_block_hashes_hash[] = "16cb7e839284c1910925f8d9f8a752f38ad908ae9deec7afdfbbc4a777f5ef2e";
|
static const char expected_block_hashes_hash[] = "e8255f4188ddb613df2953d8ae2ed509223e432290368b0eef062f8c12da9f70";
|
||||||
void Blockchain::load_compiled_in_block_hashes()
|
void Blockchain::load_compiled_in_block_hashes()
|
||||||
{
|
{
|
||||||
const bool testnet = m_nettype == TESTNET;
|
const bool testnet = m_nettype == TESTNET;
|
||||||
|
@ -127,7 +127,7 @@ namespace cryptonote
|
|||||||
out_amounts[1] += out_amounts[0];
|
out_amounts[1] += out_amounts[0];
|
||||||
for (size_t n = 1; n < out_amounts.size(); ++n)
|
for (size_t n = 1; n < out_amounts.size(); ++n)
|
||||||
out_amounts[n - 1] = out_amounts[n];
|
out_amounts[n - 1] = out_amounts[n];
|
||||||
out_amounts.resize(out_amounts.size() - 1);
|
out_amounts.pop_back();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -661,7 +661,7 @@ bool t_command_parser_executor::sync_info(const std::vector<std::string>& args)
|
|||||||
|
|
||||||
bool t_command_parser_executor::version(const std::vector<std::string>& args)
|
bool t_command_parser_executor::version(const std::vector<std::string>& args)
|
||||||
{
|
{
|
||||||
std::cout << "Monero '" << MONERO_RELEASE_NAME << "' (v" << MONERO_VERSION_FULL << ")" << std::endl;
|
std::cout << "Wownero '" << MONERO_RELEASE_NAME << "' (v" << MONERO_VERSION_FULL << ")" << std::endl;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1567,7 +1567,7 @@ bool simple_wallet::save_known_rings(const std::vector<std::string> &args)
|
|||||||
|
|
||||||
bool simple_wallet::version(const std::vector<std::string> &args)
|
bool simple_wallet::version(const std::vector<std::string> &args)
|
||||||
{
|
{
|
||||||
message_writer() << "Monero '" << MONERO_RELEASE_NAME << "' (v" << MONERO_VERSION_FULL << ")";
|
message_writer() << "Wownero '" << MONERO_RELEASE_NAME << "' (v" << MONERO_VERSION_FULL << ")";
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1707,13 +1707,13 @@ bool simple_wallet::set_refresh_type(const std::vector<std::string> &args/* = st
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool simple_wallet::set_confirm_missing_payment_id(const std::vector<std::string> &args/* = std::vector<std::string>()*/)
|
bool simple_wallet::set_confirm_subaddress(const std::vector<std::string> &args/* = std::vector<std::string>()*/)
|
||||||
{
|
{
|
||||||
const auto pwd_container = get_and_verify_password();
|
const auto pwd_container = get_and_verify_password();
|
||||||
if (pwd_container)
|
if (pwd_container)
|
||||||
{
|
{
|
||||||
parse_bool_and_use(args[1], [&](bool r) {
|
parse_bool_and_use(args[1], [&](bool r) {
|
||||||
m_wallet->confirm_missing_payment_id(r);
|
m_wallet->confirm_subaddress(r);
|
||||||
m_wallet->rewrite(m_wallet_file, pwd_container->password());
|
m_wallet->rewrite(m_wallet_file, pwd_container->password());
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -1950,10 +1950,10 @@ bool simple_wallet::help(const std::vector<std::string> &args/* = std::vector<st
|
|||||||
"Commands:\n" <<
|
"Commands:\n" <<
|
||||||
tr(" \"balance\" - Show balance.\n") <<
|
tr(" \"balance\" - Show balance.\n") <<
|
||||||
tr(" \"address\" - Show wallet's address.\n") <<
|
tr(" \"address\" - Show wallet's address.\n") <<
|
||||||
tr(" \"integrated_address\" - Show receiving address with an integrated payment ID.\n") <<
|
tr(" \"address new [optional note]\" - Create new sub-address with optional note, spaces are allowed.\n") <<
|
||||||
tr(" \"transfer [address|integrated_address] [amount]\" - Send WOW to an address.\n") <<
|
tr(" \"address all\" - Show all sub-addresses.\n") <<
|
||||||
|
tr(" \"transfer [address] [amount]\" - Send WOW to an address.\n") <<
|
||||||
tr(" \"show_transfers [in|out|pending|failed|pool]\" - Show transactions.\n") <<
|
tr(" \"show_transfers [in|out|pending|failed|pool]\" - Show transactions.\n") <<
|
||||||
tr(" \"payments [payment ID]\" - Show transaction of a given payment ID.\n") <<
|
|
||||||
tr(" \"sweep_all [address]\" - Send whole balance to another wallet.\n") <<
|
tr(" \"sweep_all [address]\" - Send whole balance to another wallet.\n") <<
|
||||||
tr(" \"seed\" - Show secret 25 words that can be used to recover this wallet.\n") <<
|
tr(" \"seed\" - Show secret 25 words that can be used to recover this wallet.\n") <<
|
||||||
tr(" \"refresh\" - Synchronize wallet with the Wownero network.\n") <<
|
tr(" \"refresh\" - Synchronize wallet with the Wownero network.\n") <<
|
||||||
@ -2083,13 +2083,9 @@ simple_wallet::simple_wallet()
|
|||||||
boost::bind(&simple_wallet::print_address, this, _1),
|
boost::bind(&simple_wallet::print_address, this, _1),
|
||||||
tr("address [ new <label text with white spaces allowed> | all | <index_min> [<index_max>] | label <index> <label text with white spaces allowed>]"),
|
tr("address [ new <label text with white spaces allowed> | all | <index_min> [<index_max>] | label <index> <label text with white spaces allowed>]"),
|
||||||
tr("If no arguments are specified or <index> is specified, the wallet shows the default or specified address. If \"all\" is specified, the wallet shows all the existing addresses in the currently selected account. If \"new \" is specified, the wallet creates a new address with the provided label text (which can be empty). If \"label\" is specified, the wallet sets the label of the address specified by <index> to the provided label text."));
|
tr("If no arguments are specified or <index> is specified, the wallet shows the default or specified address. If \"all\" is specified, the wallet shows all the existing addresses in the currently selected account. If \"new \" is specified, the wallet creates a new address with the provided label text (which can be empty). If \"label\" is specified, the wallet sets the label of the address specified by <index> to the provided label text."));
|
||||||
m_cmd_binder.set_handler("integrated_address",
|
|
||||||
boost::bind(&simple_wallet::print_integrated_address, this, _1),
|
|
||||||
tr("integrated_address [<payment_id> | <address>]"),
|
|
||||||
tr("Encode a payment ID into an integrated address for the current wallet public address (no argument uses a random payment ID), or decode an integrated address to standard address and payment ID"));
|
|
||||||
m_cmd_binder.set_handler("address_book",
|
m_cmd_binder.set_handler("address_book",
|
||||||
boost::bind(&simple_wallet::address_book, this, _1),
|
boost::bind(&simple_wallet::address_book, this, _1),
|
||||||
tr("address_book [(add ((<address> [pid <id>])|<integrated address>) [<description possibly with whitespaces>])|(delete <index>)]"),
|
tr("address_book [(add ((<address> [pid <id>])) [<description possibly with whitespaces>])|(delete <index>)]"),
|
||||||
tr("Print all entries in the address book, optionally adding/deleting an entry to/from it."));
|
tr("Print all entries in the address book, optionally adding/deleting an entry to/from it."));
|
||||||
m_cmd_binder.set_handler("save",
|
m_cmd_binder.set_handler("save",
|
||||||
boost::bind(&simple_wallet::save, this, _1),
|
boost::bind(&simple_wallet::save, this, _1),
|
||||||
@ -2341,8 +2337,8 @@ bool simple_wallet::set_variable(const std::vector<std::string> &args)
|
|||||||
success_msg_writer() << "store-tx-info = " << m_wallet->store_tx_info();
|
success_msg_writer() << "store-tx-info = " << m_wallet->store_tx_info();
|
||||||
success_msg_writer() << "auto-refresh = " << m_wallet->auto_refresh();
|
success_msg_writer() << "auto-refresh = " << m_wallet->auto_refresh();
|
||||||
success_msg_writer() << "refresh-type = " << get_refresh_type_name(m_wallet->get_refresh_type());
|
success_msg_writer() << "refresh-type = " << get_refresh_type_name(m_wallet->get_refresh_type());
|
||||||
success_msg_writer() << "priority = " << priority<< " (" << priority_string << ")";
|
success_msg_writer() << "priority = " << m_wallet->get_default_priority();
|
||||||
success_msg_writer() << "confirm-missing-payment-id = " << m_wallet->confirm_missing_payment_id();
|
success_msg_writer() << "confirm-subaddress = " << m_wallet->confirm_subaddress();
|
||||||
success_msg_writer() << "ask-password = " << m_wallet->ask_password();
|
success_msg_writer() << "ask-password = " << m_wallet->ask_password();
|
||||||
success_msg_writer() << "unit = " << cryptonote::get_unit(cryptonote::get_default_decimal_point());
|
success_msg_writer() << "unit = " << cryptonote::get_unit(cryptonote::get_default_decimal_point());
|
||||||
success_msg_writer() << "min-outputs-count = " << m_wallet->get_min_output_count();
|
success_msg_writer() << "min-outputs-count = " << m_wallet->get_min_output_count();
|
||||||
@ -2395,8 +2391,8 @@ bool simple_wallet::set_variable(const std::vector<std::string> &args)
|
|||||||
CHECK_SIMPLE_VARIABLE("store-tx-info", set_store_tx_info, tr("0 or 1"));
|
CHECK_SIMPLE_VARIABLE("store-tx-info", set_store_tx_info, tr("0 or 1"));
|
||||||
CHECK_SIMPLE_VARIABLE("auto-refresh", set_auto_refresh, tr("0 or 1"));
|
CHECK_SIMPLE_VARIABLE("auto-refresh", set_auto_refresh, tr("0 or 1"));
|
||||||
CHECK_SIMPLE_VARIABLE("refresh-type", set_refresh_type, tr("full (slowest, no assumptions); optimize-coinbase (fast, assumes the whole coinbase is paid to a single address); no-coinbase (fastest, assumes we receive no coinbase transaction), default (same as optimize-coinbase)"));
|
CHECK_SIMPLE_VARIABLE("refresh-type", set_refresh_type, tr("full (slowest, no assumptions); optimize-coinbase (fast, assumes the whole coinbase is paid to a single address); no-coinbase (fastest, assumes we receive no coinbase transaction), default (same as optimize-coinbase)"));
|
||||||
CHECK_SIMPLE_VARIABLE("priority", set_default_priority, tr("0, 1, 2, 3, or 4, or one of ") << join_priority_strings(", "));
|
CHECK_SIMPLE_VARIABLE("priority", set_default_priority, tr("0, 1, 2, 3, or 4"));
|
||||||
CHECK_SIMPLE_VARIABLE("confirm-missing-payment-id", set_confirm_missing_payment_id, tr("0 or 1"));
|
CHECK_SIMPLE_VARIABLE("confirm-subaddress", set_confirm_subaddress, tr("0 or 1"));
|
||||||
CHECK_SIMPLE_VARIABLE("ask-password", set_ask_password, tr("0 or 1"));
|
CHECK_SIMPLE_VARIABLE("ask-password", set_ask_password, tr("0 or 1"));
|
||||||
CHECK_SIMPLE_VARIABLE("unit", set_unit, tr("wownero, millinero, micronero, nanonero, piconero"));
|
CHECK_SIMPLE_VARIABLE("unit", set_unit, tr("wownero, millinero, micronero, nanonero, piconero"));
|
||||||
CHECK_SIMPLE_VARIABLE("min-outputs-count", set_min_output_count, tr("unsigned integer"));
|
CHECK_SIMPLE_VARIABLE("min-outputs-count", set_min_output_count, tr("unsigned integer"));
|
||||||
@ -3505,6 +3501,8 @@ bool simple_wallet::open_wallet(const boost::program_options::variables_map& vm)
|
|||||||
prefix = tr("Opened wallet");
|
prefix = tr("Opened wallet");
|
||||||
message_writer(console_color_white, true) <<
|
message_writer(console_color_white, true) <<
|
||||||
prefix << ": " << m_wallet->get_account().get_public_address_str(m_wallet->nettype());
|
prefix << ": " << m_wallet->get_account().get_public_address_str(m_wallet->nettype());
|
||||||
|
message_writer(console_color_yellow, true) << "\n" << tr("When receiving WOW, "
|
||||||
|
"create a new sub-address for each transaction with the command “address new”. \nUse “address all” to see all sub-addresses.\n");
|
||||||
if (m_wallet->get_account().get_device()) {
|
if (m_wallet->get_account().get_device()) {
|
||||||
message_writer(console_color_white, true) << "Wallet is on device: " << m_wallet->get_account().get_device().get_name();
|
message_writer(console_color_white, true) << "Wallet is on device: " << m_wallet->get_account().get_device().get_name();
|
||||||
}
|
}
|
||||||
@ -4381,7 +4379,7 @@ bool simple_wallet::transfer_main(int transfer_type, const std::vector<std::stri
|
|||||||
std::string extra_nonce;
|
std::string extra_nonce;
|
||||||
set_payment_id_to_tx_extra_nonce(extra_nonce, payment_id);
|
set_payment_id_to_tx_extra_nonce(extra_nonce, payment_id);
|
||||||
r = add_extra_nonce_to_tx_extra(extra, extra_nonce);
|
r = add_extra_nonce_to_tx_extra(extra, extra_nonce);
|
||||||
success_msg_writer() << tr("WARNING: Payment id is unencrypted, which might potentially compromise your privacy. An integrated address is recommended instead.\n");
|
success_msg_writer() << tr("\nWARNING: Payment IDs will be deprecated soon. Sub-addresses are recommended instead.\n");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -4392,6 +4390,7 @@ bool simple_wallet::transfer_main(int transfer_type, const std::vector<std::stri
|
|||||||
std::string extra_nonce;
|
std::string extra_nonce;
|
||||||
set_encrypted_payment_id_to_tx_extra_nonce(extra_nonce, payment_id8);
|
set_encrypted_payment_id_to_tx_extra_nonce(extra_nonce, payment_id8);
|
||||||
r = add_extra_nonce_to_tx_extra(extra, extra_nonce);
|
r = add_extra_nonce_to_tx_extra(extra, extra_nonce);
|
||||||
|
success_msg_writer() << tr("\nWARNING: Payment IDs will be deprecated soon. Sub-addresses are recommended instead.\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4468,10 +4467,10 @@ bool simple_wallet::transfer_main(int transfer_type, const std::vector<std::stri
|
|||||||
dsts.push_back(de);
|
dsts.push_back(de);
|
||||||
}
|
}
|
||||||
|
|
||||||
// prompt is there is no payment id and confirmation is required
|
// prompt if regular address
|
||||||
if (!payment_id_seen && m_wallet->confirm_missing_payment_id() && dsts.size() > num_subaddresses)
|
if (!payment_id_seen && m_wallet->confirm_subaddress() && dsts.size() > num_subaddresses)
|
||||||
{
|
{
|
||||||
std::string accepted = input_line(tr("No payment id is included with this transaction. Is this okay? (Y/Yes/N/No): "));
|
std::string accepted = input_line(tr("\nSending to a regular address may degrade privacy. Ask recipient for a sub-address instead. Continue anyway? (Y/Yes/N/No): "));
|
||||||
if (std::cin.eof())
|
if (std::cin.eof())
|
||||||
return true;
|
return true;
|
||||||
if (!command_line::is_yes(accepted))
|
if (!command_line::is_yes(accepted))
|
||||||
@ -4868,6 +4867,7 @@ bool simple_wallet::sweep_main(uint64_t below, const std::vector<std::string> &a
|
|||||||
set_payment_id_to_tx_extra_nonce(extra_nonce, payment_id);
|
set_payment_id_to_tx_extra_nonce(extra_nonce, payment_id);
|
||||||
r = add_extra_nonce_to_tx_extra(extra, extra_nonce);
|
r = add_extra_nonce_to_tx_extra(extra, extra_nonce);
|
||||||
payment_id_seen = true;
|
payment_id_seen = true;
|
||||||
|
success_msg_writer() << tr("\nWARNING: Payment IDs will be deprecated soon. Sub-addresses are recommended instead.\n");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -4879,6 +4879,7 @@ bool simple_wallet::sweep_main(uint64_t below, const std::vector<std::string> &a
|
|||||||
set_encrypted_payment_id_to_tx_extra_nonce(extra_nonce, payment_id8);
|
set_encrypted_payment_id_to_tx_extra_nonce(extra_nonce, payment_id8);
|
||||||
r = add_extra_nonce_to_tx_extra(extra, extra_nonce);
|
r = add_extra_nonce_to_tx_extra(extra, extra_nonce);
|
||||||
payment_id_seen = true;
|
payment_id_seen = true;
|
||||||
|
success_msg_writer() << tr("\nWARNING: Payment IDs will be deprecated soon. Sub-addresses are recommended instead.\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4917,10 +4918,10 @@ bool simple_wallet::sweep_main(uint64_t below, const std::vector<std::string> &a
|
|||||||
payment_id_seen = true;
|
payment_id_seen = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// prompt is there is no payment id and confirmation is required
|
// prompt if regular address
|
||||||
if (!payment_id_seen && m_wallet->confirm_missing_payment_id() && !info.is_subaddress)
|
if (!payment_id_seen && m_wallet->confirm_subaddress() && !info.is_subaddress)
|
||||||
{
|
{
|
||||||
std::string accepted = input_line(tr("No payment id is included with this transaction. Is this okay? (Y/Yes/N/No): "));
|
std::string accepted = input_line(tr("\nSending to a regular address may degrade privacy. Ask recipient for a sub-address instead. Continue anyway? (Y/Yes/N/No): "));
|
||||||
if (std::cin.eof())
|
if (std::cin.eof())
|
||||||
return true;
|
return true;
|
||||||
if (!command_line::is_yes(accepted))
|
if (!command_line::is_yes(accepted))
|
||||||
@ -5116,10 +5117,10 @@ bool simple_wallet::sweep_single(const std::vector<std::string> &args_)
|
|||||||
payment_id_seen = true;
|
payment_id_seen = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// prompt if there is no payment id and confirmation is required
|
// prompt if regular address
|
||||||
if (!payment_id_seen && m_wallet->confirm_missing_payment_id() && !info.is_subaddress)
|
if (!payment_id_seen && m_wallet->confirm_subaddress() && !info.is_subaddress)
|
||||||
{
|
{
|
||||||
std::string accepted = input_line(tr("No payment id is included with this transaction. Is this okay? (Y/Yes/N/No): "));
|
std::string accepted = input_line(tr("\nSending to a regular address may degrade privacy. Ask recipient for a sub-address instead. Continue anyway? (Y/Yes/N/No): "));
|
||||||
if (std::cin.eof())
|
if (std::cin.eof())
|
||||||
return true;
|
return true;
|
||||||
if (!command_line::is_yes(accepted))
|
if (!command_line::is_yes(accepted))
|
||||||
@ -6718,56 +6719,7 @@ bool simple_wallet::print_address(const std::vector<std::string> &args/* = std::
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------------------------
|
||||||
bool simple_wallet::print_integrated_address(const std::vector<std::string> &args/* = std::vector<std::string>()*/)
|
|
||||||
{
|
|
||||||
crypto::hash8 payment_id;
|
|
||||||
if (args.size() > 1)
|
|
||||||
{
|
|
||||||
fail_msg_writer() << tr("usage: integrated_address [payment ID]");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if (args.size() == 0)
|
|
||||||
{
|
|
||||||
if (m_current_subaddress_account != 0)
|
|
||||||
{
|
|
||||||
fail_msg_writer() << tr("Integrated addresses can only be created for account 0");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
payment_id = crypto::rand<crypto::hash8>();
|
|
||||||
success_msg_writer() << tr("Random payment ID: ") << payment_id;
|
|
||||||
success_msg_writer() << tr("Matching integrated address: ") << m_wallet->get_account().get_public_integrated_address_str(payment_id, m_wallet->nettype());
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
if(tools::wallet2::parse_short_payment_id(args.back(), payment_id))
|
|
||||||
{
|
|
||||||
if (m_current_subaddress_account != 0)
|
|
||||||
{
|
|
||||||
fail_msg_writer() << tr("Integrated addresses can only be created for account 0");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
success_msg_writer() << m_wallet->get_account().get_public_integrated_address_str(payment_id, m_wallet->nettype());
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
address_parse_info info;
|
|
||||||
if(get_account_address_from_str(info, m_wallet->nettype(), args.back()))
|
|
||||||
{
|
|
||||||
if (info.has_payment_id)
|
|
||||||
{
|
|
||||||
success_msg_writer() << boost::format(tr("Integrated address: %s, payment ID: %s")) %
|
|
||||||
get_account_address_as_str(m_wallet->nettype(), false, info.address) % epee::string_tools::pod_to_hex(info.payment_id);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
success_msg_writer() << (info.is_subaddress ? tr("Subaddress: ") : tr("Standard address: ")) << get_account_address_as_str(m_wallet->nettype(), info.is_subaddress, info.address);
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
fail_msg_writer() << tr("failed to parse payment ID or address");
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
//----------------------------------------------------------------------------------------------------
|
|
||||||
bool simple_wallet::address_book(const std::vector<std::string> &args/* = std::vector<std::string>()*/)
|
bool simple_wallet::address_book(const std::vector<std::string> &args/* = std::vector<std::string>()*/)
|
||||||
{
|
{
|
||||||
if (args.size() == 0)
|
if (args.size() == 0)
|
||||||
@ -6775,7 +6727,7 @@ bool simple_wallet::address_book(const std::vector<std::string> &args/* = std::v
|
|||||||
}
|
}
|
||||||
else if (args.size() == 1 || (args[0] != "add" && args[0] != "delete"))
|
else if (args.size() == 1 || (args[0] != "add" && args[0] != "delete"))
|
||||||
{
|
{
|
||||||
fail_msg_writer() << tr("usage: address_book [(add (<address> [pid <long or short payment id>])|<integrated address> [<description possibly with whitespaces>])|(delete <index>)]");
|
fail_msg_writer() << tr("usage: address_book [(add (<address> [pid <long or short payment id>]) [<description possibly with whitespaces>])|(delete <index>)]");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else if (args[0] == "add")
|
else if (args[0] == "add")
|
||||||
|
@ -121,7 +121,7 @@ namespace cryptonote
|
|||||||
bool set_store_tx_info(const std::vector<std::string> &args = std::vector<std::string>());
|
bool set_store_tx_info(const std::vector<std::string> &args = std::vector<std::string>());
|
||||||
bool set_auto_refresh(const std::vector<std::string> &args = std::vector<std::string>());
|
bool set_auto_refresh(const std::vector<std::string> &args = std::vector<std::string>());
|
||||||
bool set_refresh_type(const std::vector<std::string> &args = std::vector<std::string>());
|
bool set_refresh_type(const std::vector<std::string> &args = std::vector<std::string>());
|
||||||
bool set_confirm_missing_payment_id(const std::vector<std::string> &args = std::vector<std::string>());
|
bool set_confirm_subaddress(const std::vector<std::string> &args = std::vector<std::string>());
|
||||||
bool set_ask_password(const std::vector<std::string> &args = std::vector<std::string>());
|
bool set_ask_password(const std::vector<std::string> &args = std::vector<std::string>());
|
||||||
bool set_unit(const std::vector<std::string> &args = std::vector<std::string>());
|
bool set_unit(const std::vector<std::string> &args = std::vector<std::string>());
|
||||||
bool set_min_output_count(const std::vector<std::string> &args = std::vector<std::string>());
|
bool set_min_output_count(const std::vector<std::string> &args = std::vector<std::string>());
|
||||||
@ -167,7 +167,6 @@ namespace cryptonote
|
|||||||
void print_accounts();
|
void print_accounts();
|
||||||
void print_accounts(const std::string& tag);
|
void print_accounts(const std::string& tag);
|
||||||
bool print_address(const std::vector<std::string> &args = std::vector<std::string>());
|
bool print_address(const std::vector<std::string> &args = std::vector<std::string>());
|
||||||
bool print_integrated_address(const std::vector<std::string> &args = std::vector<std::string>());
|
|
||||||
bool address_book(const std::vector<std::string> &args = std::vector<std::string>());
|
bool address_book(const std::vector<std::string> &args = std::vector<std::string>());
|
||||||
bool save(const std::vector<std::string> &args);
|
bool save(const std::vector<std::string> &args);
|
||||||
bool save_watch_only(const std::vector<std::string> &args);
|
bool save_watch_only(const std::vector<std::string> &args);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#define DEF_MONERO_VERSION_TAG "@VERSIONTAG@"
|
#define DEF_MONERO_VERSION_TAG "@VERSIONTAG@"
|
||||||
#define DEF_MONERO_VERSION "0.3.0.0-master"
|
#define DEF_MONERO_VERSION "0.3.0.1-master"
|
||||||
#define DEF_MONERO_RELEASE_NAME "Cool Cage"
|
#define DEF_MONERO_RELEASE_NAME "Cool Cage"
|
||||||
#define DEF_MONERO_VERSION_FULL DEF_MONERO_VERSION "-" DEF_MONERO_VERSION_TAG
|
#define DEF_MONERO_VERSION_FULL DEF_MONERO_VERSION "-" DEF_MONERO_VERSION_TAG
|
||||||
|
|
||||||
|
@ -744,14 +744,6 @@ std::string WalletImpl::address(uint32_t accountIndex, uint32_t addressIndex) co
|
|||||||
return m_wallet->get_subaddress_as_str({accountIndex, addressIndex});
|
return m_wallet->get_subaddress_as_str({accountIndex, addressIndex});
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string WalletImpl::integratedAddress(const std::string &payment_id) const
|
|
||||||
{
|
|
||||||
crypto::hash8 pid;
|
|
||||||
if (!tools::wallet2::parse_short_payment_id(payment_id, pid)) {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
return m_wallet->get_integrated_address_as_str(pid);
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string WalletImpl::secretViewKey() const
|
std::string WalletImpl::secretViewKey() const
|
||||||
{
|
{
|
||||||
|
@ -88,7 +88,6 @@ public:
|
|||||||
std::string errorString() const;
|
std::string errorString() const;
|
||||||
bool setPassword(const std::string &password);
|
bool setPassword(const std::string &password);
|
||||||
std::string address(uint32_t accountIndex = 0, uint32_t addressIndex = 0) const;
|
std::string address(uint32_t accountIndex = 0, uint32_t addressIndex = 0) const;
|
||||||
std::string integratedAddress(const std::string &payment_id) const;
|
|
||||||
std::string secretViewKey() const;
|
std::string secretViewKey() const;
|
||||||
std::string publicViewKey() const;
|
std::string publicViewKey() const;
|
||||||
std::string secretSpendKey() const;
|
std::string secretSpendKey() const;
|
||||||
|
@ -373,16 +373,6 @@ struct Wallet
|
|||||||
virtual void hardForkInfo(uint8_t &version, uint64_t &earliest_height) const = 0;
|
virtual void hardForkInfo(uint8_t &version, uint64_t &earliest_height) const = 0;
|
||||||
//! check if hard fork rules should be used
|
//! check if hard fork rules should be used
|
||||||
virtual bool useForkRules(uint8_t version, int64_t early_blocks) const = 0;
|
virtual bool useForkRules(uint8_t version, int64_t early_blocks) const = 0;
|
||||||
/*!
|
|
||||||
* \brief integratedAddress - returns integrated address for current wallet address and given payment_id.
|
|
||||||
* if passed "payment_id" param is an empty string or not-valid payment id string
|
|
||||||
* (16 characters hexadecimal string) - random payment_id will be generated
|
|
||||||
*
|
|
||||||
* \param payment_id - 16 characters hexadecimal string or empty string if new random payment id needs to be
|
|
||||||
* generated
|
|
||||||
* \return - 106 characters string representing integrated address
|
|
||||||
*/
|
|
||||||
virtual std::string integratedAddress(const std::string &payment_id) const = 0;
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* \brief secretViewKey - returns secret view key
|
* \brief secretViewKey - returns secret view key
|
||||||
|
@ -651,7 +651,7 @@ wallet2::wallet2(network_type nettype, bool restricted):
|
|||||||
m_auto_refresh(true),
|
m_auto_refresh(true),
|
||||||
m_refresh_from_block_height(0),
|
m_refresh_from_block_height(0),
|
||||||
m_explicit_refresh_from_block_height(true),
|
m_explicit_refresh_from_block_height(true),
|
||||||
m_confirm_missing_payment_id(true),
|
m_confirm_subaddress(true),
|
||||||
m_confirm_non_default_ring_size(true),
|
m_confirm_non_default_ring_size(true),
|
||||||
m_ask_password(true),
|
m_ask_password(true),
|
||||||
m_min_output_count(0),
|
m_min_output_count(0),
|
||||||
@ -907,11 +907,6 @@ std::string wallet2::get_subaddress_as_str(const cryptonote::subaddress_index& i
|
|||||||
return cryptonote::get_account_address_as_str(m_nettype, !index.is_zero(), address);
|
return cryptonote::get_account_address_as_str(m_nettype, !index.is_zero(), address);
|
||||||
}
|
}
|
||||||
//----------------------------------------------------------------------------------------------------
|
//----------------------------------------------------------------------------------------------------
|
||||||
std::string wallet2::get_integrated_address_as_str(const crypto::hash8& payment_id) const
|
|
||||||
{
|
|
||||||
return cryptonote::get_account_integrated_address_as_str(m_nettype, get_address(), payment_id);
|
|
||||||
}
|
|
||||||
//----------------------------------------------------------------------------------------------------
|
|
||||||
void wallet2::add_subaddress_account(const std::string& label)
|
void wallet2::add_subaddress_account(const std::string& label)
|
||||||
{
|
{
|
||||||
uint32_t index_major = (uint32_t)get_num_subaddress_accounts();
|
uint32_t index_major = (uint32_t)get_num_subaddress_accounts();
|
||||||
@ -2631,8 +2626,8 @@ bool wallet2::store_keys(const std::string& keys_file_name, const epee::wipeable
|
|||||||
value2.SetUint64(m_refresh_from_block_height);
|
value2.SetUint64(m_refresh_from_block_height);
|
||||||
json.AddMember("refresh_height", value2, json.GetAllocator());
|
json.AddMember("refresh_height", value2, json.GetAllocator());
|
||||||
|
|
||||||
value2.SetInt(m_confirm_missing_payment_id ? 1 :0);
|
value2.SetInt(m_confirm_subaddress ? 1 :0);
|
||||||
json.AddMember("confirm_missing_payment_id", value2, json.GetAllocator());
|
json.AddMember("confirm_subaddress", value2, json.GetAllocator());
|
||||||
|
|
||||||
value2.SetInt(m_confirm_non_default_ring_size ? 1 :0);
|
value2.SetInt(m_confirm_non_default_ring_size ? 1 :0);
|
||||||
json.AddMember("confirm_non_default_ring_size", value2, json.GetAllocator());
|
json.AddMember("confirm_non_default_ring_size", value2, json.GetAllocator());
|
||||||
@ -2742,7 +2737,7 @@ bool wallet2::load_keys(const std::string& keys_file_name, const epee::wipeable_
|
|||||||
m_default_priority = 0;
|
m_default_priority = 0;
|
||||||
m_auto_refresh = true;
|
m_auto_refresh = true;
|
||||||
m_refresh_type = RefreshType::RefreshDefault;
|
m_refresh_type = RefreshType::RefreshDefault;
|
||||||
m_confirm_missing_payment_id = true;
|
m_confirm_subaddress = true;
|
||||||
m_confirm_non_default_ring_size = true;
|
m_confirm_non_default_ring_size = true;
|
||||||
m_ask_password = true;
|
m_ask_password = true;
|
||||||
m_min_output_count = 0;
|
m_min_output_count = 0;
|
||||||
@ -2845,8 +2840,8 @@ bool wallet2::load_keys(const std::string& keys_file_name, const epee::wipeable_
|
|||||||
}
|
}
|
||||||
GET_FIELD_FROM_JSON_RETURN_ON_ERROR(json, refresh_height, uint64_t, Uint64, false, 0);
|
GET_FIELD_FROM_JSON_RETURN_ON_ERROR(json, refresh_height, uint64_t, Uint64, false, 0);
|
||||||
m_refresh_from_block_height = field_refresh_height;
|
m_refresh_from_block_height = field_refresh_height;
|
||||||
GET_FIELD_FROM_JSON_RETURN_ON_ERROR(json, confirm_missing_payment_id, int, Int, false, true);
|
GET_FIELD_FROM_JSON_RETURN_ON_ERROR(json, confirm_subaddress, int, Int, false, true);
|
||||||
m_confirm_missing_payment_id = field_confirm_missing_payment_id;
|
m_confirm_subaddress = field_confirm_subaddress;
|
||||||
GET_FIELD_FROM_JSON_RETURN_ON_ERROR(json, confirm_non_default_ring_size, int, Int, false, true);
|
GET_FIELD_FROM_JSON_RETURN_ON_ERROR(json, confirm_non_default_ring_size, int, Int, false, true);
|
||||||
m_confirm_non_default_ring_size = field_confirm_non_default_ring_size;
|
m_confirm_non_default_ring_size = field_confirm_non_default_ring_size;
|
||||||
GET_FIELD_FROM_JSON_RETURN_ON_ERROR(json, ask_password, int, Int, false, true);
|
GET_FIELD_FROM_JSON_RETURN_ON_ERROR(json, ask_password, int, Int, false, true);
|
||||||
|
@ -629,7 +629,6 @@ namespace tools
|
|||||||
std::vector<crypto::public_key> get_subaddress_spend_public_keys(uint32_t account, uint32_t begin, uint32_t end) const;
|
std::vector<crypto::public_key> get_subaddress_spend_public_keys(uint32_t account, uint32_t begin, uint32_t end) const;
|
||||||
std::string get_subaddress_as_str(const cryptonote::subaddress_index& index) const;
|
std::string get_subaddress_as_str(const cryptonote::subaddress_index& index) const;
|
||||||
std::string get_address_as_str() const { return get_subaddress_as_str({0, 0}); }
|
std::string get_address_as_str() const { return get_subaddress_as_str({0, 0}); }
|
||||||
std::string get_integrated_address_as_str(const crypto::hash8& payment_id) const;
|
|
||||||
void add_subaddress_account(const std::string& label);
|
void add_subaddress_account(const std::string& label);
|
||||||
size_t get_num_subaddress_accounts() const { return m_subaddress_labels.size(); }
|
size_t get_num_subaddress_accounts() const { return m_subaddress_labels.size(); }
|
||||||
size_t get_num_subaddresses(uint32_t index_major) const { return index_major < m_subaddress_labels.size() ? m_subaddress_labels[index_major].size() : 0; }
|
size_t get_num_subaddresses(uint32_t index_major) const { return index_major < m_subaddress_labels.size() ? m_subaddress_labels[index_major].size() : 0; }
|
||||||
@ -852,8 +851,8 @@ namespace tools
|
|||||||
void set_default_priority(uint32_t p) { m_default_priority = p; }
|
void set_default_priority(uint32_t p) { m_default_priority = p; }
|
||||||
bool auto_refresh() const { return m_auto_refresh; }
|
bool auto_refresh() const { return m_auto_refresh; }
|
||||||
void auto_refresh(bool r) { m_auto_refresh = r; }
|
void auto_refresh(bool r) { m_auto_refresh = r; }
|
||||||
bool confirm_missing_payment_id() const { return m_confirm_missing_payment_id; }
|
bool confirm_subaddress() const { return m_confirm_subaddress; }
|
||||||
void confirm_missing_payment_id(bool always) { m_confirm_missing_payment_id = always; }
|
void confirm_subaddress(bool always) { m_confirm_subaddress = always; }
|
||||||
bool ask_password() const { return m_ask_password; }
|
bool ask_password() const { return m_ask_password; }
|
||||||
void ask_password(bool always) { m_ask_password = always; }
|
void ask_password(bool always) { m_ask_password = always; }
|
||||||
void set_min_output_count(uint32_t count) { m_min_output_count = count; }
|
void set_min_output_count(uint32_t count) { m_min_output_count = count; }
|
||||||
@ -1197,7 +1196,7 @@ namespace tools
|
|||||||
// If m_refresh_from_block_height is explicitly set to zero we need this to differentiate it from the case that
|
// If m_refresh_from_block_height is explicitly set to zero we need this to differentiate it from the case that
|
||||||
// m_refresh_from_block_height was defaulted to zero.*/
|
// m_refresh_from_block_height was defaulted to zero.*/
|
||||||
bool m_explicit_refresh_from_block_height;
|
bool m_explicit_refresh_from_block_height;
|
||||||
bool m_confirm_missing_payment_id;
|
bool m_confirm_subaddress;
|
||||||
bool m_confirm_non_default_ring_size;
|
bool m_confirm_non_default_ring_size;
|
||||||
bool m_ask_password;
|
bool m_ask_password;
|
||||||
uint32_t m_min_output_count;
|
uint32_t m_min_output_count;
|
||||||
|
@ -1099,69 +1099,6 @@ namespace tools
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
//------------------------------------------------------------------------------------------------------------------------------
|
//------------------------------------------------------------------------------------------------------------------------------
|
||||||
bool wallet_rpc_server::on_make_integrated_address(const wallet_rpc::COMMAND_RPC_MAKE_INTEGRATED_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_MAKE_INTEGRATED_ADDRESS::response& res, epee::json_rpc::error& er)
|
|
||||||
{
|
|
||||||
if (!m_wallet) return not_open(er);
|
|
||||||
try
|
|
||||||
{
|
|
||||||
crypto::hash8 payment_id;
|
|
||||||
if (req.payment_id.empty())
|
|
||||||
{
|
|
||||||
payment_id = crypto::rand<crypto::hash8>();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (!tools::wallet2::parse_short_payment_id(req.payment_id,payment_id))
|
|
||||||
{
|
|
||||||
er.code = WALLET_RPC_ERROR_CODE_WRONG_PAYMENT_ID;
|
|
||||||
er.message = "Invalid payment ID";
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
res.integrated_address = m_wallet->get_integrated_address_as_str(payment_id);
|
|
||||||
res.payment_id = epee::string_tools::pod_to_hex(payment_id);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
catch (const std::exception& e)
|
|
||||||
{
|
|
||||||
handle_rpc_exception(std::current_exception(), er, WALLET_RPC_ERROR_CODE_UNKNOWN_ERROR);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
//------------------------------------------------------------------------------------------------------------------------------
|
|
||||||
bool wallet_rpc_server::on_split_integrated_address(const wallet_rpc::COMMAND_RPC_SPLIT_INTEGRATED_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_SPLIT_INTEGRATED_ADDRESS::response& res, epee::json_rpc::error& er)
|
|
||||||
{
|
|
||||||
if (!m_wallet) return not_open(er);
|
|
||||||
try
|
|
||||||
{
|
|
||||||
cryptonote::address_parse_info info;
|
|
||||||
|
|
||||||
if(!get_account_address_from_str(info, m_wallet->nettype(), req.integrated_address))
|
|
||||||
{
|
|
||||||
er.code = WALLET_RPC_ERROR_CODE_WRONG_ADDRESS;
|
|
||||||
er.message = "Invalid address";
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if(!info.has_payment_id)
|
|
||||||
{
|
|
||||||
er.code = WALLET_RPC_ERROR_CODE_WRONG_ADDRESS;
|
|
||||||
er.message = "Address is not an integrated address";
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
res.standard_address = get_account_address_as_str(m_wallet->nettype(), info.is_subaddress, info.address);
|
|
||||||
res.payment_id = epee::string_tools::pod_to_hex(info.payment_id);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
catch (const std::exception& e)
|
|
||||||
{
|
|
||||||
handle_rpc_exception(std::current_exception(), er, WALLET_RPC_ERROR_CODE_UNKNOWN_ERROR);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
//------------------------------------------------------------------------------------------------------------------------------
|
|
||||||
bool wallet_rpc_server::on_store(const wallet_rpc::COMMAND_RPC_STORE::request& req, wallet_rpc::COMMAND_RPC_STORE::response& res, epee::json_rpc::error& er)
|
bool wallet_rpc_server::on_store(const wallet_rpc::COMMAND_RPC_STORE::request& req, wallet_rpc::COMMAND_RPC_STORE::response& res, epee::json_rpc::error& er)
|
||||||
{
|
{
|
||||||
if (!m_wallet) return not_open(er);
|
if (!m_wallet) return not_open(er);
|
||||||
@ -3040,6 +2977,7 @@ just_dir:
|
|||||||
wrpc.send_stop_signal();
|
wrpc.send_stop_signal();
|
||||||
});
|
});
|
||||||
LOG_PRINT_L0(tools::wallet_rpc_server::tr("Starting wallet RPC server"));
|
LOG_PRINT_L0(tools::wallet_rpc_server::tr("Starting wallet RPC server"));
|
||||||
|
LOG_PRINT_L0(tools::wallet_rpc_server::tr("WARNING: Payment IDs/integrated addresses will be deprecated soon. Use sub-addresses."));
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
wrpc.run();
|
wrpc.run();
|
||||||
|
@ -95,8 +95,6 @@ namespace tools
|
|||||||
MAP_JON_RPC_WE("get_bulk_payments", on_get_bulk_payments, wallet_rpc::COMMAND_RPC_GET_BULK_PAYMENTS)
|
MAP_JON_RPC_WE("get_bulk_payments", on_get_bulk_payments, wallet_rpc::COMMAND_RPC_GET_BULK_PAYMENTS)
|
||||||
MAP_JON_RPC_WE("incoming_transfers", on_incoming_transfers, wallet_rpc::COMMAND_RPC_INCOMING_TRANSFERS)
|
MAP_JON_RPC_WE("incoming_transfers", on_incoming_transfers, wallet_rpc::COMMAND_RPC_INCOMING_TRANSFERS)
|
||||||
MAP_JON_RPC_WE("query_key", on_query_key, wallet_rpc::COMMAND_RPC_QUERY_KEY)
|
MAP_JON_RPC_WE("query_key", on_query_key, wallet_rpc::COMMAND_RPC_QUERY_KEY)
|
||||||
MAP_JON_RPC_WE("make_integrated_address", on_make_integrated_address, wallet_rpc::COMMAND_RPC_MAKE_INTEGRATED_ADDRESS)
|
|
||||||
MAP_JON_RPC_WE("split_integrated_address", on_split_integrated_address, wallet_rpc::COMMAND_RPC_SPLIT_INTEGRATED_ADDRESS)
|
|
||||||
MAP_JON_RPC_WE("stop_wallet", on_stop_wallet, wallet_rpc::COMMAND_RPC_STOP_WALLET)
|
MAP_JON_RPC_WE("stop_wallet", on_stop_wallet, wallet_rpc::COMMAND_RPC_STOP_WALLET)
|
||||||
MAP_JON_RPC_WE("rescan_blockchain", on_rescan_blockchain, wallet_rpc::COMMAND_RPC_RESCAN_BLOCKCHAIN)
|
MAP_JON_RPC_WE("rescan_blockchain", on_rescan_blockchain, wallet_rpc::COMMAND_RPC_RESCAN_BLOCKCHAIN)
|
||||||
MAP_JON_RPC_WE("set_tx_notes", on_set_tx_notes, wallet_rpc::COMMAND_RPC_SET_TX_NOTES)
|
MAP_JON_RPC_WE("set_tx_notes", on_set_tx_notes, wallet_rpc::COMMAND_RPC_SET_TX_NOTES)
|
||||||
@ -160,8 +158,6 @@ namespace tools
|
|||||||
bool on_sweep_all(const wallet_rpc::COMMAND_RPC_SWEEP_ALL::request& req, wallet_rpc::COMMAND_RPC_SWEEP_ALL::response& res, epee::json_rpc::error& er);
|
bool on_sweep_all(const wallet_rpc::COMMAND_RPC_SWEEP_ALL::request& req, wallet_rpc::COMMAND_RPC_SWEEP_ALL::response& res, epee::json_rpc::error& er);
|
||||||
bool on_sweep_single(const wallet_rpc::COMMAND_RPC_SWEEP_SINGLE::request& req, wallet_rpc::COMMAND_RPC_SWEEP_SINGLE::response& res, epee::json_rpc::error& er);
|
bool on_sweep_single(const wallet_rpc::COMMAND_RPC_SWEEP_SINGLE::request& req, wallet_rpc::COMMAND_RPC_SWEEP_SINGLE::response& res, epee::json_rpc::error& er);
|
||||||
bool on_relay_tx(const wallet_rpc::COMMAND_RPC_RELAY_TX::request& req, wallet_rpc::COMMAND_RPC_RELAY_TX::response& res, epee::json_rpc::error& er);
|
bool on_relay_tx(const wallet_rpc::COMMAND_RPC_RELAY_TX::request& req, wallet_rpc::COMMAND_RPC_RELAY_TX::response& res, epee::json_rpc::error& er);
|
||||||
bool on_make_integrated_address(const wallet_rpc::COMMAND_RPC_MAKE_INTEGRATED_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_MAKE_INTEGRATED_ADDRESS::response& res, epee::json_rpc::error& er);
|
|
||||||
bool on_split_integrated_address(const wallet_rpc::COMMAND_RPC_SPLIT_INTEGRATED_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_SPLIT_INTEGRATED_ADDRESS::response& res, epee::json_rpc::error& er);
|
|
||||||
bool on_store(const wallet_rpc::COMMAND_RPC_STORE::request& req, wallet_rpc::COMMAND_RPC_STORE::response& res, epee::json_rpc::error& er);
|
bool on_store(const wallet_rpc::COMMAND_RPC_STORE::request& req, wallet_rpc::COMMAND_RPC_STORE::response& res, epee::json_rpc::error& er);
|
||||||
bool on_get_payments(const wallet_rpc::COMMAND_RPC_GET_PAYMENTS::request& req, wallet_rpc::COMMAND_RPC_GET_PAYMENTS::response& res, epee::json_rpc::error& er);
|
bool on_get_payments(const wallet_rpc::COMMAND_RPC_GET_PAYMENTS::request& req, wallet_rpc::COMMAND_RPC_GET_PAYMENTS::response& res, epee::json_rpc::error& er);
|
||||||
bool on_get_bulk_payments(const wallet_rpc::COMMAND_RPC_GET_BULK_PAYMENTS::request& req, wallet_rpc::COMMAND_RPC_GET_BULK_PAYMENTS::response& res, epee::json_rpc::error& er);
|
bool on_get_bulk_payments(const wallet_rpc::COMMAND_RPC_GET_BULK_PAYMENTS::request& req, wallet_rpc::COMMAND_RPC_GET_BULK_PAYMENTS::response& res, epee::json_rpc::error& er);
|
||||||
|
@ -873,53 +873,6 @@ namespace wallet_rpc
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
struct COMMAND_RPC_MAKE_INTEGRATED_ADDRESS
|
|
||||||
{
|
|
||||||
struct request
|
|
||||||
{
|
|
||||||
std::string payment_id;
|
|
||||||
|
|
||||||
BEGIN_KV_SERIALIZE_MAP()
|
|
||||||
KV_SERIALIZE(payment_id)
|
|
||||||
END_KV_SERIALIZE_MAP()
|
|
||||||
};
|
|
||||||
|
|
||||||
struct response
|
|
||||||
{
|
|
||||||
std::string integrated_address;
|
|
||||||
std::string payment_id;
|
|
||||||
|
|
||||||
BEGIN_KV_SERIALIZE_MAP()
|
|
||||||
KV_SERIALIZE(integrated_address)
|
|
||||||
KV_SERIALIZE(payment_id)
|
|
||||||
END_KV_SERIALIZE_MAP()
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
struct COMMAND_RPC_SPLIT_INTEGRATED_ADDRESS
|
|
||||||
{
|
|
||||||
struct request
|
|
||||||
{
|
|
||||||
std::string integrated_address;
|
|
||||||
|
|
||||||
BEGIN_KV_SERIALIZE_MAP()
|
|
||||||
KV_SERIALIZE(integrated_address)
|
|
||||||
END_KV_SERIALIZE_MAP()
|
|
||||||
};
|
|
||||||
|
|
||||||
struct response
|
|
||||||
{
|
|
||||||
std::string standard_address;
|
|
||||||
std::string payment_id;
|
|
||||||
bool is_subaddress;
|
|
||||||
|
|
||||||
BEGIN_KV_SERIALIZE_MAP()
|
|
||||||
KV_SERIALIZE(standard_address)
|
|
||||||
KV_SERIALIZE(payment_id)
|
|
||||||
KV_SERIALIZE(is_subaddress)
|
|
||||||
END_KV_SERIALIZE_MAP()
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
struct COMMAND_RPC_STOP_WALLET
|
struct COMMAND_RPC_STOP_WALLET
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user