From f796a2dac40c6f3331dbfb29ad0e25bd66d3cbe5 Mon Sep 17 00:00:00 2001 From: moneromooo-monero Date: Mon, 7 Jan 2019 14:41:49 +0000 Subject: [PATCH 01/17] core_tests: add a --list_tests command line switch --- tests/core_tests/chaingen.h | 4 +++- tests/core_tests/chaingen_main.cpp | 14 ++++++++++---- 2 files changed, 13 insertions(+), 5 deletions(-) diff --git a/tests/core_tests/chaingen.h b/tests/core_tests/chaingen.h index b428c7371..7c09baf44 100644 --- a/tests/core_tests/chaingen.h +++ b/tests/core_tests/chaingen.h @@ -669,7 +669,9 @@ inline bool do_replay_file(const std::string& filename) } #define GENERATE_AND_PLAY(genclass) \ - if (filter.empty() || boost::regex_match(std::string(#genclass), match, boost::regex(filter))) \ + if (list_tests) \ + std::cout << #genclass << std::endl; \ + else if (filter.empty() || boost::regex_match(std::string(#genclass), match, boost::regex(filter))) \ { \ std::vector events; \ ++tests_count; \ diff --git a/tests/core_tests/chaingen_main.cpp b/tests/core_tests/chaingen_main.cpp index b1e7f8237..cb35cfde2 100644 --- a/tests/core_tests/chaingen_main.cpp +++ b/tests/core_tests/chaingen_main.cpp @@ -44,6 +44,7 @@ namespace const command_line::arg_descriptor arg_generate_and_play_test_data = {"generate_and_play_test_data", ""}; const command_line::arg_descriptor arg_test_transactions = {"test_transactions", ""}; const command_line::arg_descriptor arg_filter = { "filter", "Regular expression filter for which tests to run" }; + const command_line::arg_descriptor arg_list_tests = {"list_tests", ""}; } int main(int argc, char* argv[]) @@ -64,6 +65,7 @@ int main(int argc, char* argv[]) command_line::add_arg(desc_options, arg_generate_and_play_test_data); command_line::add_arg(desc_options, arg_test_transactions); command_line::add_arg(desc_options, arg_filter); + command_line::add_arg(desc_options, arg_list_tests); po::variables_map vm; bool r = command_line::handle_error_helper(desc_options, [&]() @@ -87,6 +89,7 @@ int main(int argc, char* argv[]) size_t tests_count = 0; std::vector failed_tests; std::string tests_folder = command_line::get_arg(vm, arg_test_data_path); + bool list_tests = false; if (command_line::get_arg(vm, arg_generate_test_data)) { GENERATE("chain001.dat", gen_simple_chain_001); @@ -95,7 +98,7 @@ int main(int argc, char* argv[]) { PLAY("chain001.dat", gen_simple_chain_001); } - else if (command_line::get_arg(vm, arg_generate_and_play_test_data)) + else if (command_line::get_arg(vm, arg_generate_and_play_test_data) || (list_tests = command_line::get_arg(vm, arg_list_tests))) { GENERATE_AND_PLAY(gen_simple_chain_001); GENERATE_AND_PLAY(gen_simple_chain_split_1); @@ -251,9 +254,12 @@ int main(int argc, char* argv[]) GENERATE_AND_PLAY(gen_bp_tx_invalid_borromean_type); el::Level level = (failed_tests.empty() ? el::Level::Info : el::Level::Error); - MLOG(level, "\nREPORT:"); - MLOG(level, " Test run: " << tests_count); - MLOG(level, " Failures: " << failed_tests.size()); + if (!list_tests) + { + MLOG(level, "\nREPORT:"); + MLOG(level, " Test run: " << tests_count); + MLOG(level, " Failures: " << failed_tests.size()); + } if (!failed_tests.empty()) { MLOG(level, "FAILED TESTS:"); From 7bce433b89eabf69c9ffc4442a3421259188c86e Mon Sep 17 00:00:00 2001 From: moneromooo-monero Date: Mon, 7 Jan 2019 16:31:13 +0000 Subject: [PATCH 02/17] blockchain: don't propagate exception past dtor Coverity 190660 --- src/cryptonote_core/blockchain.cpp | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/cryptonote_core/blockchain.cpp b/src/cryptonote_core/blockchain.cpp index fb970f3b8..5b81129bb 100644 --- a/src/cryptonote_core/blockchain.cpp +++ b/src/cryptonote_core/blockchain.cpp @@ -130,7 +130,8 @@ Blockchain::Blockchain(tx_memory_pool& tx_pool) : //------------------------------------------------------------------ Blockchain::~Blockchain() { - deinit(); + try { deinit(); } + catch (const std::exception &e) { /* ignore */ } } //------------------------------------------------------------------ bool Blockchain::have_tx(const crypto::hash &id) const From 37430e0a5bef1b5cb39bef8bf7322ebee60df9ea Mon Sep 17 00:00:00 2001 From: moneromooo-monero Date: Mon, 7 Jan 2019 16:36:37 +0000 Subject: [PATCH 03/17] message_store: init me field Coverity 190651 --- src/wallet/message_store.h | 1 + 1 file changed, 1 insertion(+) diff --git a/src/wallet/message_store.h b/src/wallet/message_store.h index 7d26f7889..637bd29a1 100644 --- a/src/wallet/message_store.h +++ b/src/wallet/message_store.h @@ -135,6 +135,7 @@ namespace mms { monero_address_known = false; memset(&monero_address, 0, sizeof(cryptonote::account_public_address)); + me = false; index = 0; auto_config_public_key = crypto::null_pkey; auto_config_secret_key = crypto::null_skey; From 84ca8550d2c7a9b03036be918fc4830803bf1c4f Mon Sep 17 00:00:00 2001 From: moneromooo-monero Date: Fri, 18 Jan 2019 19:51:29 +0000 Subject: [PATCH 04/17] bulletproofs: speed up vector_power_sum found by sarang --- src/ringct/bulletproofs.cc | 28 ++++++++++++++++++++++------ 1 file changed, 22 insertions(+), 6 deletions(-) diff --git a/src/ringct/bulletproofs.cc b/src/ringct/bulletproofs.cc index d485fb748..b5fd626dc 100644 --- a/src/ringct/bulletproofs.cc +++ b/src/ringct/bulletproofs.cc @@ -202,20 +202,36 @@ static rct::keyV vector_powers(const rct::key &x, size_t n) } /* Given a scalar, return the sum of its powers from 0 to n-1 */ -static rct::key vector_power_sum(const rct::key &x, size_t n) +static rct::key vector_power_sum(rct::key x, size_t n) { if (n == 0) return rct::zero(); rct::key res = rct::identity(); if (n == 1) return res; - rct::key prev = x; - for (size_t i = 1; i < n; ++i) + + const bool is_power_of_2 = (n & (n - 1)) == 0; + if (is_power_of_2) { - if (i > 1) - sc_mul(prev.bytes, prev.bytes, x.bytes); - sc_add(res.bytes, res.bytes, prev.bytes); + sc_add(res.bytes, res.bytes, x.bytes); + while (n > 2) + { + sc_mul(x.bytes, x.bytes, x.bytes); + sc_muladd(res.bytes, x.bytes, res.bytes, res.bytes); + n /= 2; + } } + else + { + rct::key prev = x; + for (size_t i = 1; i < n; ++i) + { + if (i > 1) + sc_mul(prev.bytes, prev.bytes, x.bytes); + sc_add(res.bytes, res.bytes, prev.bytes); + } + } + return res; } From 31abdddd1be4231638cb951b8d8d67ece4313aea Mon Sep 17 00:00:00 2001 From: selsta Date: Wed, 9 Jan 2019 05:32:04 +0100 Subject: [PATCH 05/17] device_ledger: remove full_name variable This variable was never set, resulting in the device name always showing as "disconnected". --- src/device/device_ledger.cpp | 2 +- src/device/device_ledger.hpp | 1 - 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/src/device/device_ledger.cpp b/src/device/device_ledger.cpp index bfb41bbe4..20dc79929 100644 --- a/src/device/device_ledger.cpp +++ b/src/device/device_ledger.cpp @@ -322,7 +322,7 @@ namespace hw { } const std::string device_ledger::get_name() const { - if (this->full_name.empty() || !this->connected()) { + if (!this->connected()) { return std::string("name).append(">"); } return this->name; diff --git a/src/device/device_ledger.hpp b/src/device/device_ledger.hpp index 2f5beb044..9f731cde9 100644 --- a/src/device/device_ledger.hpp +++ b/src/device/device_ledger.hpp @@ -85,7 +85,6 @@ namespace hw { //IO hw::io::device_io_hid hw_device; - std::string full_name; unsigned int length_send; unsigned char buffer_send[BUFFER_SEND_SIZE]; unsigned int length_recv; From cd0b5a1a4c47a1cd02000ffa1d4980821b3d536f Mon Sep 17 00:00:00 2001 From: selsta Date: Wed, 9 Jan 2019 09:20:53 +0100 Subject: [PATCH 06/17] device: proper handling of user input (1) If the user denies something on the Ledger, a proper error message is now shown. (2) Ledger doesn't time out anymore while waiting on user input. (3) Lower the timeout to 2 seconds, this is enough for normal Ledger <-> System communication. --- src/device/device_io.hpp | 2 +- src/device/device_io_hid.cpp | 8 ++++++-- src/device/device_io_hid.hpp | 2 +- src/device/device_ledger.cpp | 39 +++++++++++++++++++++++++++++++----- src/device/device_ledger.hpp | 1 + 5 files changed, 43 insertions(+), 9 deletions(-) diff --git a/src/device/device_io.hpp b/src/device/device_io.hpp index 96163a211..1d5e3564c 100644 --- a/src/device/device_io.hpp +++ b/src/device/device_io.hpp @@ -50,7 +50,7 @@ namespace hw { virtual void disconnect() = 0; virtual bool connected() const = 0; - virtual int exchange(unsigned char *command, unsigned int cmd_len, unsigned char *response, unsigned int max_resp_len) = 0; + virtual int exchange(unsigned char *command, unsigned int cmd_len, unsigned char *response, unsigned int max_resp_len, bool user_input) = 0; }; }; }; diff --git a/src/device/device_io_hid.cpp b/src/device/device_io_hid.cpp index 1aadfb9ea..36c7a241b 100644 --- a/src/device/device_io_hid.cpp +++ b/src/device/device_io_hid.cpp @@ -148,7 +148,7 @@ namespace hw { return this->usb_device != NULL; } - int device_io_hid::exchange(unsigned char *command, unsigned int cmd_len, unsigned char *response, unsigned int max_resp_len) { + int device_io_hid::exchange(unsigned char *command, unsigned int cmd_len, unsigned char *response, unsigned int max_resp_len, bool user_input) { unsigned char buffer[400]; unsigned char padding_buffer[MAX_BLOCK+1]; unsigned int result; @@ -177,7 +177,11 @@ namespace hw { //get first response memset(buffer, 0, sizeof(buffer)); - hid_ret = hid_read_timeout(this->usb_device, buffer, MAX_BLOCK, this->timeout); + if (!user_input) { + hid_ret = hid_read_timeout(this->usb_device, buffer, MAX_BLOCK, this->timeout); + } else { + hid_ret = hid_read(this->usb_device, buffer, MAX_BLOCK); + } ASSERT_X(hid_ret>=0, "Unable to read hidapi response. Error "+std::to_string(result)+": "+ safe_hid_error(this->usb_device)); result = (unsigned int)hid_ret; io_hid_log(1, buffer, result); diff --git a/src/device/device_io_hid.hpp b/src/device/device_io_hid.hpp index bb0f0a814..c47eefad2 100644 --- a/src/device/device_io_hid.hpp +++ b/src/device/device_io_hid.hpp @@ -100,7 +100,7 @@ namespace hw { void connect(void *params); void connect(unsigned int vid, unsigned int pid, boost::optional interface_number, boost::optional usage_page); bool connected() const; - int exchange(unsigned char *command, unsigned int cmd_len, unsigned char *response, unsigned int max_resp_len); + int exchange(unsigned char *command, unsigned int cmd_len, unsigned char *response, unsigned int max_resp_len, bool user_input); void disconnect(); void release(); }; diff --git a/src/device/device_ledger.cpp b/src/device/device_ledger.cpp index 20dc79929..bfbcf691d 100644 --- a/src/device/device_ledger.cpp +++ b/src/device/device_ledger.cpp @@ -176,7 +176,7 @@ namespace hw { #define INS_GET_RESPONSE 0xc0 - device_ledger::device_ledger(): hw_device(0x0101, 0x05, 64, 120000) { + device_ledger::device_ledger(): hw_device(0x0101, 0x05, 64, 2000) { this->id = device_id++; this->reset_buffer(); this->mode = NONE; @@ -235,6 +235,9 @@ namespace hw { /* IO */ /* ======================================================================= */ + #define IO_SW_DENY 0x6982 + #define IO_SECRET_KEY 0x02 + void device_ledger::logCMD() { if (apdu_verbose) { char strbuffer[1024]; @@ -283,7 +286,12 @@ namespace hw { void device_ledger::send_simple(unsigned char ins, unsigned char p1) { this->length_send = set_command_header_noopt(ins, p1); - this->exchange(); + if (ins == INS_GET_KEY && p1 == IO_SECRET_KEY) { + // export view key user input + this->exchange_wait_on_input(); + } else { + this->exchange(); + } } bool device_ledger::reset() { @@ -294,7 +302,7 @@ namespace hw { unsigned int device_ledger::exchange(unsigned int ok, unsigned int mask) { logCMD(); - this->length_recv = hw_device.exchange(this->buffer_send, this->length_send, this->buffer_recv, BUFFER_SEND_SIZE); + this->length_recv = hw_device.exchange(this->buffer_send, this->length_send, this->buffer_recv, BUFFER_SEND_SIZE, false); ASSERT_X(this->length_recv>=2, "Communication error, less than tow bytes received"); this->length_recv -= 2; @@ -305,6 +313,25 @@ namespace hw { return this->sw; } + unsigned int device_ledger::exchange_wait_on_input(unsigned int ok, unsigned int mask) { + logCMD(); + unsigned int deny = 0; + this->length_recv = hw_device.exchange(this->buffer_send, this->length_send, this->buffer_recv, BUFFER_SEND_SIZE, true); + ASSERT_X(this->length_recv>=2, "Communication error, less than two bytes received"); + + this->length_recv -= 2; + this->sw = (this->buffer_recv[length_recv]<<8) | this->buffer_recv[length_recv+1]; + if (this->sw == IO_SW_DENY) { + // cancel on device + deny = 1; + } else { + ASSERT_SW(this->sw,ok,msk); + } + + logRESP(); + return deny; + } + void device_ledger::reset_buffer() { this->length_send = 0; memset(this->buffer_send, 0, BUFFER_SEND_SIZE); @@ -1260,7 +1287,8 @@ namespace hw { this->buffer_send[4] = offset-5; this->length_send = offset; - this->exchange(); + // check fee user input + CHECK_AND_ASSERT_THROW_MES(this->exchange_wait_on_input() == 0, "Fee denied on device."); //pseudoOuts if (type == rct::RCTTypeSimple) { @@ -1328,7 +1356,8 @@ namespace hw { this->buffer_send[4] = offset-5; this->length_send = offset; - this->exchange(); + // check transaction user input + CHECK_AND_ASSERT_THROW_MES(this->exchange_wait_on_input() == 0, "Transaction denied on device."); #ifdef DEBUG_HWDEVICE hw::ledger::log_hexbuffer("Prehash AKV input", (char*)&this->buffer_recv[64], 3*32); #endif diff --git a/src/device/device_ledger.hpp b/src/device/device_ledger.hpp index 9f731cde9..de38d5c27 100644 --- a/src/device/device_ledger.hpp +++ b/src/device/device_ledger.hpp @@ -94,6 +94,7 @@ namespace hw { void logCMD(void); void logRESP(void); unsigned int exchange(unsigned int ok=0x9000, unsigned int mask=0xFFFF); + unsigned int exchange_wait_on_input(unsigned int ok=0x9000, unsigned int mask=0xFFFF); void reset_buffer(void); int set_command_header(unsigned char ins, unsigned char p1 = 0x00, unsigned char p2 = 0x00); int set_command_header_noopt(unsigned char ins, unsigned char p1 = 0x00, unsigned char p2 = 0x00); From 6c77e9e4ea404e2975b393c1f26e59b25792911b Mon Sep 17 00:00:00 2001 From: erciccione Date: Fri, 11 Jan 2019 15:19:56 +0100 Subject: [PATCH 07/17] translations: update and sync all language files --- translations/monero.ts | 4577 ++++++++++++++------------ translations/monero_fr.ts | 6391 ++++++++++++++++++++----------------- translations/monero_it.ts | 5289 +++++++++++++++++++----------- translations/monero_ja.ts | 5236 +++++++++++++++++++----------- translations/monero_sv.ts | 4564 +++++++++++++++++--------- 5 files changed, 15529 insertions(+), 10528 deletions(-) diff --git a/translations/monero.ts b/translations/monero.ts index 23eadff84..45d85abbd 100644 --- a/translations/monero.ts +++ b/translations/monero.ts @@ -1,6 +1,6 @@ - + Monero::AddressBookImpl @@ -134,383 +134,384 @@ Monero::WalletImpl - + payment id has invalid format, expected 16 or 64 character hex string: - + Failed to add short payment id: - - + + daemon is busy. Please try again later. - - + + no connection to daemon. Please make sure daemon is running. - - + + RPC error: - + failed to get outputs to mix: %s - - + + not enough outputs for specified ring size - - + + found outputs to use - + Please sweep unmixable outputs. - - + + not enough money to transfer, available only %s, sent amount %s - + failed to parse address - + failed to parse secret spend key - + Neither view key nor spend key supplied, cancelled - + failed to parse secret view key - + failed to verify secret spend key - + spend key does not match address - + failed to verify secret view key - + view key does not match address - - + + failed to generate new wallet: - + Electrum seed is empty - + Electrum-style word list failed verification - + Failed to send import wallet request - + Failed to load unsigned transactions - + Failed to load transaction from file - + Wallet is view only - + failed to save file - + Key images can only be imported with a trusted daemon - + Failed to import key images: - + Failed to get subaddress label: - + Failed to set subaddress label: - + Failed to get multisig info: - + + Failed to make multisig: - + Failed to finalize multisig wallet creation - + Failed to finalize multisig wallet creation: - + Failed to export multisig images: - + Failed to parse imported multisig images - + Failed to import multisig images: - + Failed to check for partial multisig key images: - + Failed to restore multisig transaction: - + Invalid destination address - + Invalid output: - - + + Failed to mark outputs as spent + + + + + Failed to mark output as spent + + + + + Failed to mark output as unspent + + + + + not enough money to transfer, overall balance only %s, sent amount %s - - + + not enough money to transfer, available only %s, transaction amount %s = %s + %s (fee) - - + + output amount - - + + transaction was not constructed - - + + transaction %s was rejected by daemon with status: - - + + one of destinations is zero - - + + failed to find a suitable way to split transactions - - + + unknown transfer error: - - + + internal error: - - + + unexpected error: - - + + unknown error - + failed to get outputs to mix - - - - - - - + + + + + + + Failed to parse txid - + no tx keys found for this txid - - + + Failed to parse tx key - - - + + + Failed to parse address - + Address must not be a subaddress - + The wallet must be in multisig ready state - + Given string is not a key - + Rescan spent can only be used with a trusted daemon - - Failed to set blackballed outputs - - - - - + + Failed to parse output amount - - + + Failed to parse output offset - - Failed to blackball output - - - - - Failed to unblackball output - - - - - + + Failed to parse key image - + Failed to get ring - + Failed to get rings - + Failed to set ring @@ -541,12 +542,12 @@ command_line - + yes - + no @@ -603,955 +604,803 @@ cryptonote::simple_wallet - + Daemon uses a different RPC major version (%u) than the wallet (%u): %s. Either update one of them, or use --allow-mismatched-daemon-version. - + Enter the number corresponding to the language of your choice: - + There is currently a %u block backlog at that fee level. Is this okay? (Y/Yes/N/No): - - + + Spending from address index %d - + Sending %s. - + Your transaction needs to be split into %llu transactions. This will result in a transaction fee being applied to each transaction, for a total fee of %s - + The transaction fee is %s - + , of which %s is dust from change - + A total of %s from dust change will be sent to dust address - + . This transaction will unlock on block %llu, in approximately %s days (assuming 2 minutes per block) - + Not enough money in unlocked balance - + No address given - + missing lockedblocks parameter - + bad locked_blocks parameter - + failed to parse Payment ID - + failed to parse key image - + No outputs found - + Multiple transactions are created, which is not supposed to happen - + The transaction uses multiple or no inputs, which is not supposed to happen - + Money successfully sent, transaction: - + missing threshold amount - + invalid amount threshold - - donations are not enabled on the testnet or on the stagenet - - - - - usage: donate [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <amount> [<payment_id>] - - - - + Claimed change does not go to a paid address - + Claimed change is larger than payment to the change address - + Change goes to more than one address - + sending %s to %s - + dummy output(s) - + with no destinations - + no change - + Loaded %lu transactions, for %s, fee %s, %s, %s, with min ring size %lu, %s. %sIs this okay? (Y/Yes/N/No): - + (Y/Yes/N/No): - - - + + + Is this okay? (Y/Yes/N/No): - + Daemon is local, assuming trusted - + Password for new watch-only wallet - + false - + Commands: - + Unknown command: - + Command usage: - + Command description: - + wallet is watch-only and has no spend key - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + + + + command not supported by HW wallet - - + + wallet is watch-only and has no seed - + wallet is multisig but not yet finalized - - + + wallet is non-deterministic and has no seed - + Failed to retrieve seed - + wallet is multisig and has no seed - + Incorrect password - - - + + + + Your original password was incorrect. - + Error with wallet rewrite: - - usage: payment_id - - - - - + + Random payment ID: - - Cannot connect to daemon - - - - + Current fee is %s %s per %s - + Error: failed to estimate backlog array size: - + Error: bad estimated backlog array size - + (current) - + %u block (%u minutes) backlog at priority %u%s - + %u to %u block (%u to %u minutes) backlog at priority %u - + No backlog at priority - - + + This wallet is already multisig - - + + wallet is watch-only and cannot be made multisig - - + + This wallet has been used before, please use a new wallet to create a multisig wallet - + Send this multisig info to all other participants, then use make_multisig <threshold> <info1> [<info2>...] with others' multisig info - + This includes the PRIVATE view key, so needs to be disclosed only to that multisig wallet's participants - - usage: make_multisig <threshold> <multisiginfo1> [<multisiginfo2>...] - - - - + Invalid threshold - + + Another step is needed - - Send this multisig info to all other participants, then use finalize_multisig <info1> [<info2>...] with others' multisig info - - - - + Error creating multisig: - + Error creating multisig: new wallet is not multisig - + multisig address: - - - + + + + This wallet is not multisig - + + This wallet is already finalized - - usage: finalize_multisig <multisiginfo1> [<multisiginfo2>...] - - - - + Failed to finalize multisig - + Failed to finalize multisig: - - - - - + + + + + This multisig wallet is not yet finalized - - usage: export_multisig_info <filename> - - - - - - + + + failed to save file - + Error exporting multisig info: - + Multisig info exported to - - usage: import_multisig_info <filename1> [<filename2>...] - one for each other participant - - - - - - - + + + + failed to read file - + Multisig info imported - + Failed to import multisig info: - + Failed to update spent status after importing multisig info: - + Untrusted daemon, spent status may be incorrect. Use a trusted daemon and run "rescan_spent" - - - + + + This is not a multisig wallet - - usage: sign_multisig <filename> - - - - + + Failed to sign multisig transaction - + Multisig error: - + Failed to sign multisig transaction: - - - + + + Transaction successfully signed to file - + It may be relayed to the network with submit_multisig - - usage: submit_multisig <filename> - - - - - + + Failed to load multisig transaction from file - - + + Multisig transaction signed by only %u signers, needs %u more signatures - - + + Transaction successfully submitted, transaction - - + + You can check its status by using the `show_transfers` command. - - - - - - - - - + + + + + + + + + + + unknown error - - usage: export_raw_multisig <filename> - - - - + Failed to export multisig transaction to file - + Saved exported multisig transaction file(s): - - - + + + unexpected error: - - usage: print_ring <key_image> | <txid> - - - - - + + Invalid key image - + Invalid txid - + Key image either not spent, or spent with mixin 0 - + Failed to get key image ring: - + File doesn't exist - + Invalid ring specification: - + Invalid key image: - + Invalid ring type, expected relative or abosolute: - - + + Error reading line: - + Invalid ring: - + Invalid relative ring: - + Invalid absolute ring: - + Failed to set ring for key image: - + Continuing. - - usage: set_ring <filename> | ( <key_image> absolute|relative <index> [<index>...] ) - - - - + Missing absolute or relative keyword - - + + invalid index: must be a strictly positive unsigned integer - + invalid index: indices wrap - + invalid index: indices should be in strictly ascending order - + failed to set ring - + Bad argument: - + should be "add" - + Failed to open file - - Failed to blackball output: - - - - - - Failed to unblackball output: - - - - - Blackballed: - - - - - not blackballed: - - - - + Failed to save known rings: - - + + wallet is watch-only and cannot transfer - - - + + + ring size must be an integer >= - - + + WARNING: this is a non default ring size, which may harm your privacy. Default is recommended. - + could not change default ring size - - - + + + priority must be either 0, 1, 2, 3, or 4, or one of: - + could not change default priority - + invalid unit - - + + invalid count: must be an unsigned integer - + invalid value - - + + Invalid height - - start_mining [<number_of_threads>] [bg_mining] [ignore_battery] - - - - + Start mining in the daemon (bg_mining and ignore_battery are optional booleans). - + Stop mining in the daemon. - - set_daemon <host>[:<port>] [trusted|untrusted] - - - - + Set another daemon to connect to. - + Save the current blockchain data. - + Synchronize the transactions and balance. - - balance [detail] - - - - + Show the wallet's balance of the currently selected account. - - incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] - - - - - Show the incoming transfers, all or filtered by availability and address index. - -Output format: -Amount, Spent("T"|"F"), "locked"|"unlocked", RingCT, Global Index, Transaction Hash, Address Index, [Public Key, Key Image] - - - - - payments <PID_1> [<PID_2> ... <PID_N>] - - - - + Show the payments for the given payment IDs. - + Show the blockchain height. - - locked_sweep_all [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> <lockblocks> [<payment_id>] - - - - + Send all unlocked balance to an address and lock it for <lockblocks> (max. 1000000). If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. <priority> is the priority of the sweep. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. - + Send all unmixable outputs to yourself with ring_size 1 - - sweep_below <amount_threshold> [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> [<payment_id>] - - - - + Send all unlocked outputs below the threshold to an address. - + Send a single output of the given key image to an address without change. - - donate [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <amount> [<payment_id>] - - - - + Donate <amount> to the development team (donate.getmonero.org). - - sign_transfer [export_raw] - - - - + Sign a transaction from a file. If the parameter "export_raw" is specified, transaction raw hex data suitable for the daemon RPC /sendrawtransaction is exported. - + Submit a signed transaction from a file. - - set_log <level>|{+,-,}<categories> - - - - + Change the current log detail (level must be <0-4>). - - account - account new <label text with white spaces allowed> - account switch <index> - account label <index> <label text with white spaces allowed> - account tag <tag_name> <account_index_1> [<account_index_2> ...] - account untag <account_index_1> [<account_index_2> ...] - account tag_description <tag_name> <description> - - - - + If no arguments are specified, the wallet shows all the existing accounts along with their balances. If the "new" argument is specified, the wallet creates a new account with its label initialized by the provided label text (which can be empty). If the "switch" argument is specified, the wallet switches to the account specified by <index>. @@ -1562,423 +1411,234 @@ If the "tag_description" argument is specified, the tag <tag_name&g - - address [ new <label text with white spaces allowed> | all | <index_min> [<index_max>] | label <index> <label text with white spaces allowed>] - - - - + 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. - - integrated_address [<payment_id> | <address>] - - - - + 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 - - address_book [(add ((<address> [pid <id>])|<integrated address>) [<description possibly with whitespaces>])|(delete <index>)] - - - - + Print all entries in the address book, optionally adding/deleting an entry to/from it. - + Save the wallet data. - + Save a watch-only keys file. - + Display the private view key. - + Display the private spend key. - + Display the Electrum-style mnemonic seed - - set <option> [<value>] - - - - + Display the encrypted Electrum-style mnemonic seed. - + Rescan the blockchain for spent outputs. - - get_tx_key <txid> - - - - + Get the transaction key (r) for a given <txid>. - - set_tx_key <txid> <tx_key> - - - - + Set the transaction key (r) for a given <txid> in case the tx was made by some other device or 3rd party wallet. - - check_tx_key <txid> <txkey> <address> - - - - + Check the amount going to <address> in <txid>. - - get_tx_proof <txid> <address> [<message>] - - - - + Generate a signature proving funds sent to <address> in <txid>, optionally with a challenge string <message>, using either the transaction secret key (when <address> is not your wallet's address) or the view secret key (otherwise), which does not disclose the secret key. - - check_tx_proof <txid> <address> <signature_file> [<message>] - - - - + Check the proof for funds going to <address> in <txid> with the challenge string <message> if any. - - get_spend_proof <txid> [<message>] - - - - + Generate a signature proving that you generated <txid> using the spend secret key, optionally with a challenge string <message>. - - check_spend_proof <txid> <signature_file> [<message>] - - - - + Check a signature proving that the signer generated <txid>, optionally with a challenge string <message>. - - get_reserve_proof (all|<amount>) [<message>] - - - - + Generate a signature proving that you own at least this much, optionally with a challenge string <message>. If 'all' is specified, you prove the entire sum of all of your existing accounts' balances. Otherwise, you prove the reserve of the smallest possible amount above <amount> available in your current account. - - check_reserve_proof <address> <signature_file> [<message>] - - - - + Check a signature proving that the owner of <address> holds at least this much, optionally with a challenge string <message>. - - show_transfers [in|out|pending|failed|pool|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] - - - - - Show the incoming/outgoing transfers within an optional height range. - -Output format: -In or Coinbase: Block Number, "block"|"in", Time, Amount, Transaction Hash, Payment ID, Subaddress Index, "-", Note\ -Out: Block Number, "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Destinations, Input addresses**, "-", Note -Pool: "pool", "in", Time, Amount, Transaction Hash, Payment Id, Subaddress Index, "-", Note, Double Spend Note\ -Pending or Failed: "failed"|"pending", "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Input addresses**, "-", Note - -* Excluding change and fee. -** Set of address indices used as inputs in this transfer. - - - - - unspent_outputs [index=<N1>[,<N2>,...]] [<min_amount> [<max_amount>]] - - - - + Show the unspent outputs of a specified address within an optional amount range. - + Rescan the blockchain from scratch, losing any information which can not be recovered from the blockchain itself. - - set_tx_note <txid> [free text note] - - - - + Set an arbitrary string note for a <txid>. - - get_tx_note <txid> - - - - + Get a string note for a txid. - - set_description [free text note] - - - - + Set an arbitrary description for the wallet. - + Get the description of the wallet. - + Show the wallet's status. - + Show the wallet's information. - - sign <file> - - - - + Sign the contents of a file. - - verify <filename> <address> <signature> - - - - + Verify a signature on the contents of a file. - - export_key_images <file> - - - - - Export a signed set of key images to a <file>. - - - - - import_key_images <file> - - - - + Import a signed key images list and verify their spent status. - - hw_reconnect - - - - + Attempts to reconnect HW wallet. - - export_outputs <file> - - - - + Export a set of outputs owned by this wallet. - - import_outputs <file> - - - - + Import a set of outputs owned by this wallet. - - show_transfer <txid> - - - - + Show information about a transfer to/from this address. - + Change the wallet's password. - + Generate a new random full size payment id. These will be unencrypted on the blockchain, see integrated_address for encrypted short payment ids. - + Print the information about the current fee and transaction backlog. - + Export data needed to create a multisig wallet - - make_multisig <threshold> <string1> [<string>...] - - - - + Turn this wallet into a multisig wallet - - finalize_multisig <string> [<string>...] - - - - + Turn this wallet into a multisig wallet, extra step for N-1/N wallets - - export_multisig_info <filename> - - - - + Export multisig info for other participants - - import_multisig_info <filename> [<filename>...] - - - - + Import multisig info from other participants - - sign_multisig <filename> - - - - + Sign a multisig transaction from a file - - submit_multisig <filename> - - - - + Submit a signed multisig transaction from a file - - export_raw_multisig_tx <filename> - - - - + Export a signed multisig transaction to a file - - print_ring <key_image> | <txid> - - - - + Print the ring(s) used to spend a given key image or transaction (if the ring size is > 1) Output format: @@ -1986,499 +1646,450 @@ Key Image, "absolute", list of rings - - set_ring <filename> | ( <key_image> absolute|relative <index> [<index>...] ) - - - - + Set the ring used for a given key image, so it can be reused in a fork - - save_known_rings - - - - + Save known rings to the shared rings database - - Blackball output(s) so they never get selected as fake outputs in a ring - - - - - Unblackballs an output so it may get selected as a fake output in a ring - - - - - Checks whether an output is blackballed - - - - - version - - - - + Returns version information - - help [<command>] - - - - + Show the help section or the documentation about a <command>. - + needs an argument - + set seed: needs an argument. available options: language - - - - - - - - - - - - + + + + + + + + + + + + + 0 or 1 - + integer >= - + 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) - + 0, 1, 2, 3, or 4, or one of - + 0|1|2 (or never|action|decrypt) - + monero, millinero, micronero, nanonero, piconero - - - + + + unsigned integer - - - + + + + amount - + block height - + <major>:<minor> - + set: unrecognized argument(s) - - usage: set_log <log_level_number_0-4> | <categories> - - - - - wrong number range, use: set_log <log_level_number_0-4> | <categories> - - - - + Wallet name not valid. Please try again or use Ctrl-C to quit. - + Attempting to generate or restore wallet, but specified file(s) exist. Exiting to not risk overwriting. - + Wallet and key files found, loading... - + Key file found but not wallet file. Regenerating... - + Key file not found. Failed to open wallet: - + No wallet found with that name. Confirm creation of new wallet named: - + Generating new wallet... - - NOTE: the following 25 words can be used to recover access to your wallet. Write them down and store them somewhere safe and secure. Please do not store them in your email or on file storage services outside of your immediate control. - - - - - + Can't specify more than one of --testnet and --stagenet - + can't specify more than one of --generate-new-wallet="wallet_name", --wallet-file="wallet_name", --generate-from-view-key="wallet_name", --generate-from-spend-key="wallet_name", --generate-from-keys="wallet_name", --generate-from-multisig-keys="wallet_name", --generate-from-json="jsonfilename" and --generate-from-device="wallet_name" - + can't specify both --restore-deterministic-wallet or --restore-multisig-wallet and --non-deterministic - + --restore-multisig-wallet uses --generate-new-wallet, not --wallet-file - + --restore-deterministic-wallet uses --generate-new-wallet, not --wallet-file - + specify a recovery parameter with the --electrum-seed="multisig seed here" - + specify a recovery parameter with the --electrum-seed="words list here" - + Multisig seed failed verification - + Electrum-style word list failed verification - - - - - - - - - - + + + + + + + + + + No data supplied, cancelled - - - - - - - - - - - - + + + + + + + + + + + + failed to parse address - - + + This address is a subaddress which cannot be used here. - - + + failed to parse view key secret key - - + + failed to verify view key secret key - - - + + + view key does not match standard address - - - - - - + + + + + + account creation failed - - - + + + failed to parse spend key secret key - - + + failed to verify spend key secret key - - + + spend key does not match standard address - + Error: expected M/N, but got: - + Error: expected N > 1 and N <= M, but got: - + Error: M/N is currently unsupported. - + Generating master wallet from %u of %u multisig wallet keys - + failed to parse secret view key - + failed to verify secret view key - + Secret spend key (%u of %u): - + Error: M/N is currently unsupported - + No restore height is specified. - + Assumed you are creating a new account, restore will be done from current estimated blockchain height. - + Use --restore-height if you want to restore an already setup account from a specific height - + account creation aborted - + specify a wallet path with --generate-new-wallet (not --wallet-file) - - + + bad m_restore_height parameter: - + date format must be YYYY-MM-DD - + Restore height is: - + Restore height - + Still apply restore height? (Y/Yes/N/No): - + can't specify --subaddress-lookahead and --wallet-file at the same time - + failed to open account - - - - - + + + + + wallet is null - + Warning: using an untrusted daemon at %s, privacy will be lessened - + Failed to initialize ring database: privacy enhancing features will be inactive - + wallet failed to connect to daemon: - + Daemon either is not started or wrong port was passed. Please make sure daemon is running or change the daemon address using the 'set_daemon' command. - + List of available languages for your wallet's seed: - + If your display freezes, exit blind with ^C, then run again with --use-english-language-names - - + + invalid language choice entered. Please try again. - + invalid password - + You had been using a deprecated version of the wallet. Please use the new seed that we provide. - - + + Generated new wallet: - + View key: - - - - + + + + failed to generate new wallet: - + Your wallet has been generated! To start synchronizing with the daemon, use the "refresh" command. Use the "help" command to see the list of available commands. @@ -2490,1427 +2101,694 @@ your wallet again (your wallet keys are NOT at risk in any case). - + Generated new wallet on hw device: - + failed to generate new mutlisig wallet - + Generated new %u/%u multisig wallet: - + wallet file path not valid: - + Key file not found. Failed to open wallet - + Opened watch-only wallet - + Opened %u/%u multisig wallet%s - + Opened wallet - + You had been using a deprecated version of the wallet. Please proceed to upgrade your wallet. - + You had been using a deprecated version of the wallet. Your wallet file format is being upgraded now. - + failed to load wallet: - + Use the "help" command to see the list of available commands. - + Use "help <command>" to see a command's documentation. - + failed to deinitialize wallet - + Wallet data saved - + wallet is multisig and cannot save a watch-only version - + failed to read wallet password - + Watch only wallet saved as: - + Failed to save watch only wallet: - - - + + + this command requires a trusted daemon. Enable with --trusted-daemon - - invalid arguments. Please use start_mining [<number_of_threads>] [do_bg_mining] [ignore_battery] - - - - + Mining started in daemon - + mining has NOT been started: - + Mining stopped in daemon - + mining has NOT been stopped: - - missing daemon URL argument - - - - + Unexpected array length - Exited simple_wallet::set_daemon() - + Expected trusted or untrusted, got - + trusted - + untrusted - + This does not seem to be a valid daemon URL. - + Blockchain saved - + blockchain can't be saved: - - + + Height - - + + txid - - + + idx - + NOTE: this transaction uses an encrypted payment ID: consider using subaddresses instead - + WARNING: this transaction uses an unencrypted payment ID: consider using subaddresses instead - + spent - + Enter password - + Starting refresh... - + Refresh done, blocks received: - - + + daemon is busy. Please try again later. - - + + no connection to daemon. Please make sure daemon is running. - - + + RPC error: - + refresh error: - + internal error: - + refresh failed: - + Blocks received: - + (Some owned outputs have partial key images - import_multisig_info needed) - + (Some owned outputs have missing key images - import_key_images needed) - + Currently selected account: [ - + ] - + (No tag assigned) - + Tag: - + Balance: - + unlocked balance: - + Balance per address: - + Address - - + + Balance - - + + Unlocked balance - + Outputs - - + + + Label - + %8u %6s %21s %21s %7u %21s - - usage: balance [detail] - - - - - - usage: incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] - - - - + pubkey - + key image - + spent - - + + + unlocked - + ringct - + global index - + tx id - - + + addr index - + T - + F - + locked - + RingCT - + - - + No incoming transfers - + No incoming available transfers - + No incoming unavailable transfers - - expected at least one payment ID - - - - + payment - + transaction - + height - + unlock time - + No payments with id - + payment ID has invalid format, expected 16 or 64 character hex string: - - - - + + + + failed to get blockchain height: - + failed to get spent status - - - - - - failed to connect to the daemon - - - - + Transaction %llu/%llu: txid=%s - + failed to find construction data for tx input - + Input %llu/%llu: amount=%s - + failed to get output: - + output key's originating block height shouldn't be higher than the blockchain height - + Originating block heights: - + | - - + + | - + Warning: Some input keys being spent are from - + the same transaction - + blocks that are temporally very close - + , which can break the anonymity of ring signature. Make sure this is intentional! - - - + + + Ring size must not be 0 - - - + + + ring size %u is too small, minimum is %u - - - + + + ring size %u is too large, maximum is %u - + wrong number of arguments - + payment id failed to encode - + failed to parse short payment ID from URI - - + + Invalid last argument: - + a single transaction cannot use more than one payment id - + failed to parse payment id, though it was detected - - usage: %s [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] [outputs=<N>] <address> [<payment_id>] - - - - - + + Failed to parse number of outputs - - + + Amount of outputs should be greater than 0 - + payment id has invalid format, expected 16 or 64 character hex string: - - + + Unencrypted payment IDs are bad for privacy: ask the recipient to use subaddresses instead - + bad locked_blocks parameter: - - - Locked blocks too high, max 1000000 (˜4 yrs) - - - - - + + a single transaction cannot use more than one payment id: - - - - + + + + failed to set up payment id, though it was decoded correctly - - - - - amount is wrong: + + + Send this multisig info to all other participants, then use exchange_multisig_keys <info1> [<info2>...] with others' multisig info - - expected number from 0 to + + Multisig wallet has been successfully created. Current wallet type: - - - - No payment id is included with this transaction. Is this okay? (Y/Yes/N/No): + + Failed to perform multisig keys exchange: - - - - - - - - - transaction cancelled. + + Failed to load multisig transaction from MMS - - - No outputs found, or daemon is not ready + + Failed to mark output spent: - - - Is this okay anyway? (Y/Yes/N/No): + + Failed to mark output unspent: - - Failed to check for backlog: + + Spent: - - - -Transaction + + Not spent: - - - WARNING: Outputs of multiple addresses are being used together, which might potentially compromise your privacy. - + + Failed to check whether output is spent: - - . + + Please confirm the transaction on the device - - - - - - - - - Failed to write transaction(s) to file + + Device name not specified - - - - - - - - - Unsigned transaction(s) successfully written to file: + + Device reconnect failed - - No unmixable outputs found + + Device reconnect failed: - - Sweeping + + Show the incoming transfers, all or filtered by availability and address index. + +Output format: +Amount, Spent("T"|"F"), "locked"|"unlocked", RingCT, Global Index, Transaction Hash, Address Index, [Public Key, Key Image] - - - Sweeping %s in %llu transactions for a total fee of %s. Is this okay? (Y/Yes/N/No): - - - - - - - Sweeping %s for a total fee of %s. Is this okay? (Y/Yes/N/No): - - - - - Normal - - - - - Type: - - - - - Network type: - - - - - Testnet - - - - - Stagenet - - - - - Mainnet - - - - - usage: sign <filename> - - - - - wallet is watch-only and cannot sign - - - - - This wallet is multisig and cannot sign - - - - - usage: verify <filename> <address> <signature> - - - - - Bad signature from - - - - - Good signature from - - - - - usage: export_key_images <filename> - - - - - wallet is watch-only and cannot export key images - - - - - Signed key images exported to - - - - - usage: import_key_images <filename> - - - - - command only supported by HW wallet - - - - - Failed to reconnect device - - - - - Failed to reconnect device: - - - - - usage: export_outputs <filename> - - - - - Outputs exported to - - - - - usage: import_outputs <filename> - - - - - usage: show_transfer <txid> - - - - - Double spend seen on the network: this transaction may or may not end up being mined - - - - - Transaction ID not found - - - - - Transaction successfully saved to - - - - - - , txid - - - - - Failed to save transaction to - - - - - true - - - - - failed to parse refresh type - - - - - Enter optional seed offset passphrase, empty to see raw seed - - - - - Enter seed offset passphrase, empty if none - - - - - You may want to remove the file "%s" and try again - - - - - Discarding %s of unmixable outputs that cannot be spent, which can be undone by "rescan_spent". Is this okay? (Y/Yes/N/No): - - - - - Donating %s %s to The Monero Project (donate.getmonero.org or %s). - - - - - This is a multisig wallet, it can only sign with sign_multisig - - - - - This is a watch only wallet - - - - - usage: sign_transfer [export_raw] - - - - - Failed to sign transaction - - - - - Failed to sign transaction: - - - - - Transaction raw hex data exported to - - - - - Failed to load transaction from file - - - - - usage: get_tx_key <txid> - - - - - - - - - - - - - - failed to parse txid - - - - - Tx key: - - - - - no tx keys found for this txid - - - - - usage: set_tx_key <txid> <tx_key> - - - - - - - failed to parse tx_key - - - - - Tx key successfully stored. - - - - - Failed to store tx key: - - - - - usage: get_tx_proof <txid> <address> [<message>] - - - - - - - signature file saved to: - - - - - - - failed to save signature file - - - - - - - error: - - - - - usage: check_tx_key <txid> <txkey> <address> - - - - - - failed to parse tx key - - - - - - received - - - - - - in txid - - - - - - WARNING: this transaction is not yet included in the blockchain! - - - - - - WARNING: failed to determine number of confirmations! - - - - - - received nothing in txid - - - - - usage: check_tx_proof <txid> <address> <signature_file> [<message>] - - - - - - - failed to load signature file - - - - - - Good signature - - - - - - - Bad signature - - - - - usage: get_spend_proof <txid> [<message>] - - - - - wallet is watch-only and cannot generate the proof - - - - - usage: check_spend_proof <txid> <signature_file> [<message>] - - - - - usage: get_reserve_proof (all|<amount>) [<message>] - - - - - The reserve proof can be generated only by a full wallet - - - - - usage: check_reserve_proof <address> <signature_file> [<message>] - - - - - Address must not be a subaddress - - - - - usage: show_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] - - - - - bad min_height parameter: - - - - - bad max_height parameter: - - - - - block - - - - - in - - - - - - out - - - - - [Double spend seen on the network: this transaction may or may not end up being mined] - - - - - failed - - - - - pending - - - - - usage: unspent_outputs [index=<N1>[,<N2>,...]] [<min_amount> [<max_amount>]] - - - - - <min_amount> should be smaller than <max_amount> - - - - - There is no unspent output in the specified address - - - - - -Amount: - - - - - , number of keys: - - - - - - - - - - -Min block height: - - - - - -Max block height: - - - - - -Min amount found: - - - - - -Max amount found: - - - - - -Total count: - - - - - -Bin size: - - - - - -Outputs per *: - - - - - count - ^ - - - - - - | - - - - - + - - - - - +--> block height - - - - - - ^ - - - - - ^ - - - - - - - - - - - Warning: this will lose any information which can not be recovered from the blockchain. - - - - - This includes destination addresses, tx secret keys, tx notes, etc - - - - - Rescan anyway ? (Y/Yes/N/No): - - - - - Good signature -- total: %s, spent: %s, unspent: %s - - - - - usage: blackball <amount>/<offset> | <filename> [add] - - - - - First line is not an amount - - - - - Invalid output: - - - - - Invalid output key, and file doesn't exist - - - - - usage: unblackball <amount>/<offset> - - - - - - Invalid output - - - - - usage: blackballed <amount>/<offset> - - - - - WARNING: from v8, ring size will be fixed and this setting will be ignored. - - - - - invalid argument: must be either 0/never, 1/action, or 2/encrypt/decrypt - - - - - transfer [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] (<URI> | <address> <amount>) [<payment_id>] - - - - - Transfer <amount> to <address>. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) - - - - - locked_transfer [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] (<URI> | <addr> <amount>) <lockblocks> [<payment_id>] - - - - - Transfer <amount> to <address> and lock it for <lockblocks> (max. 1000000). If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) - - - - - sweep_all [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] [outputs=<N>] <address> [<payment_id>] - - - - - Send all unlocked balance to an address. If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. If the parameter "outputs=<N>" is specified and N > 0, wallet splits the transaction into N even outputs. - - - - - sweep_single [<priority>] [<ring_size>] [outputs=<N>] <key_image> <address> [<payment_id>] - - - - + Available options: seed language Set the wallet's seed language. @@ -3921,7 +2799,7 @@ Outputs per *: store-tx-info <1|0> Whether to store outgoing tx info (destination address, payment ID, tx secret key) for future reference. default-ring-size <n> - Set the default ring size (default and minimum is 5). + Set the default ring size (obsolete). auto-refresh <1|0> Whether to automatically synchronize new blocks from the daemon. refresh-type <full|optimize-coinbase|no-coinbase|default> @@ -3958,286 +2836,1670 @@ subaddress-lookahead <major>:<minor> - - blackball <amount>/<offset> | <filename> [add] + + Show the incoming/outgoing transfers within an optional height range. + +Output format: +In or Coinbase: Block Number, "block"|"in", Time, Amount, Transaction Hash, Payment ID, Subaddress Index, "-", Note +Out: Block Number, "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Destinations, Input addresses**, "-", Note +Pool: "pool", "in", Time, Amount, Transaction Hash, Payment Id, Subaddress Index, "-", Note, Double Spend Note +Pending or Failed: "failed"|"pending", "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Input addresses**, "-", Note + +* Excluding change and fee. +** Set of address indices used as inputs in this transfer. - - unblackball <amount>/<offset> + + export_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] [output=<filepath>] - - blackballed <amount>/<offset> + + Export to CSV the incoming/outgoing transfers within an optional height range. - + + Export a signed set of key images to a <filename>. + + + + + Synchronizes key images with the hw wallet. + + + + + Performs extra multisig keys exchange rounds. Needed for arbitrary M/N multisig wallets + + + + + Interface with the MMS (Multisig Messaging System) +<subcommand> is one of: + init, info, signer, list, next, sync, transfer, delete, send, receive, export, note, show, set, help + send_signer_config, start_auto_config, stop_auto_config, auto_config +Get help about a subcommand with: help mms <subcommand>, or mms help <subcommand> + + + + + Initialize and configure the MMS for M/N = number of required signers/number of authorized signers multisig + + + + + Display current MMS configuration + + + + + Set or modify authorized signer info (single-word label, transport address, Monero address), or list all signers + + + + + List all messages + + + + + Evaluate the next possible multisig-related action(s) according to wallet state, and execute or offer for choice +By using 'sync' processing of waiting messages with multisig sync info can be forced regardless of wallet state + + + + + Force generation of multisig sync info regardless of wallet state, to recover from special situations like "stale data" errors + + + + + Initiate transfer with MMS support; arguments identical to normal 'transfer' command arguments, for info see there + + + + + Delete a single message by giving its id, or delete all messages by using 'all' + + + + + Send a single message by giving its id, or send all waiting messages + + + + + Check right away for new messages to receive + + + + + Write the content of a message to a file "mms_message_content" + + + + + Send a one-line message to an authorized signer, identified by its label, or show any waiting unread notes + + + + + Show detailed info about a single message + + + + + Available options: + auto-send <1|0> + Whether to automatically send newly generated messages right away. + + + + + + Send completed signer config to all other authorized signers + + + + + Start auto-config at the auto-config manager's wallet by issuing auto-config tokens and optionally set others' labels + + + + + Delete any auto-config tokens and abort a auto-config process + + + + + Start auto-config by using the token received from the auto-config manager + + + + + Mark output(s) as spent so they never get selected as fake outputs in a ring + + + + + Marks an output as unspent so it may get selected as a fake output in a ring + + + + + Checks whether an output is marked as spent + + + + + <device_name[:device_spec]> + + + + + wrong number range, use: %s + + + + + NOTE: the following %s can be used to recover access to your wallet. Write them down and store them somewhere safe and secure. Please do not store them in your email or on file storage services outside of your immediate control. + + + + + + string + + + + + 25 words + + + + + Device requires attention + + + + + Enter device PIN + + + + + Failed to read device PIN + + + + + Please enter the device passphrase on the device + + + + + Enter device passphrase + + + + + Failed to read device passphrase + + + + + The first refresh has finished for the HW-based wallet with received money. hw_key_images_sync is needed. + + + + + Do you want to do it now? (Y/Yes/N/No): + + + + + hw_key_images_sync skipped. Run command manually before a transfer. + + + + + Invalid keyword: + + + + + Heights: + + + + + + Locked blocks too high, max 1000000 (˜4 yrs) + + + + + + + + + amount is wrong: + + + + + + expected number from 0 to + + + + + + + No payment id is included with this transaction. Is this okay? (Y/Yes/N/No): + + + + + + + + + + + + transaction cancelled. + + + + + + No outputs found, or daemon is not ready + + + + + + Is this okay anyway? (Y/Yes/N/No): + + + + + Failed to check for backlog: + + + + + + +Transaction + + + + + + WARNING: Outputs of multiple addresses are being used together, which might potentially compromise your privacy. + + + + + + . + + + + + Unsigned transaction(s) successfully written to MMS + + + + + + + + + + + + Failed to write transaction(s) to file + + + + + + + + + + + + Unsigned transaction(s) successfully written to file: + + + + + + Failed to cold sign transaction with HW wallet + + + + + No unmixable outputs found + + + + + Sweeping + + + + + + Sweeping %s in %llu transactions for a total fee of %s. Is this okay? (Y/Yes/N/No): + + + + + + + Sweeping %s for a total fee of %s. Is this okay? (Y/Yes/N/No): + + + + + Failed to parse donation address: + + + + + Donating %s %s to %s. + + + + + usage: export_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] [output=<path>] + + + + + direction + + + + + timestamp + + + + + running balance + + + + + hash + + + + + payment ID + + + + + fee + + + + + destination + + + + + index + + + + + note + + + + + CSV exported to + + + + + MMS received new message + + + + + Normal + + + + + + Type: + + + + + Network type: + + + + + Testnet + + + + + Stagenet + + + + + Mainnet + + + + + (Y/Yes/N/No): + + + + + Choose processing: + + + + + Sign tx + + + + + Send the tx for submission to + + + + + Send the tx for signing to + + + + + Submit tx + + + + + unknown + + + + + Choice: + + + + + Wrong choice + + + + + Id + + + + + I/O + + + + + Authorized Signer + + + + + Message Type + + + + + Height + + + + + R + + + + + Message State + + + + + Since + + + + + ago + + + + + # + + + + + Transport Address + + + + + Auto-Config Token + + + + + Monero Address + + + + + + + <not set> + + + + + Message + + + + + In/out: + + + + + State: + + + + + %s since %s, %s ago + + + + + Sent: Never + + + + + Sent: %s, %s ago + + + + + Authorized signer: + + + + + Content size: + + + + + bytes + + + + + Content: + + + + + (binary data) + + + + + Send these messages now? + + + + + Queued for sending. + + + + + Invalid message id + + + + + usage: mms init <required_signers>/<authorized_signers> <own_label> <own_transport_address> + + + + + The MMS is already initialized. Re-initialize by deleting all signer info and messages? + + + + + Error in the number of required signers and/or authorized signers + + + + + The MMS is not active. + + + + + Invalid signer number + + + + + mms signer [<number> <label> [<transport_address> [<monero_address>]]] + + + + + Invalid Monero address + + + + + Wallet state does not allow changing Monero addresses anymore + + + + + Usage: mms list + + + + + Usage: mms next [sync] + + + + + No next step: + + + + + prepare_multisig + + + + + make_multisig + + + + + exchange_multisig_keys + + + + + + export_multisig_info + + + + + import_multisig_info + + + + + sign_multisig + + + + + submit_multisig + + + + + Send tx + + + + + Process signer config + + + + + Replace current signer config with the one displayed above? + + + + + Process auto config data + + + + + Nothing ready to process + + + + + Usage: mms sync + + + + + Usage: mms delete (<message_id> | all) + + + + + Delete all messages? + + + + + Usage: mms send [<message_id>] + + + + + Usage: mms receive + + + + + Usage: mms export <message_id> + + + + + Message content saved to: + + + + + Failed to to save message content + + + + + Usage: mms note [<label> <text>] + + + + + No signer found with label + + + + + Usage: mms show <message_id> + + + + + Usage: mms set <option_name> [<option_value>] + + + + + Wrong option value + + + + + Auto-send is on + + + + + Auto-send is off + + + + + Unknown option + + + + + Usage: mms help [<subcommand>] + + + + + Usage: mms send_signer_config + + + + + Signer config not yet complete + + + + + Usage: mms start_auto_config [<label> <label> ...] + + + + + There are signers without a label set. Complete labels before auto-config or specify them as parameters here. + + + + + Auto-config is already running. Cancel and restart? + + + + + Usage: mms stop_auto_config + + + + + Delete any auto-config tokens and stop auto-config? + + + + + Usage: mms auto_config <auto_config_token> + + + + + Invalid auto-config token + + + + + Auto-config already running. Cancel and restart? + + + + + The MMS is not active. Activate using the "mms init" command + + + + + Invalid MMS subcommand + + + + + + Error in MMS command: + + + + + wallet is watch-only and cannot sign + + + + + This wallet is multisig and cannot sign + + + + + Bad signature from + + + + + Good signature from + + + + + wallet is watch-only and cannot export key images + + + + + Signed key images exported to + + + + + + command only supported by HW wallet + + + + + hw wallet does not support cold KI sync + + + + + Please confirm the key image sync on the device + + + + + Key images synchronized to height + + + + + Running untrusted daemon, cannot determine which transaction output is spent. Use a trusted daemon with --trusted-daemon and run rescan_spent + + + + + spent, + + + + + unspent + + + + + Failed to import key images + + + + + Failed to import key images: + + + + + Failed to reconnect device + + + + + Failed to reconnect device: + + + + + Outputs exported to + + + + + Double spend seen on the network: this transaction may or may not end up being mined + + + + + Transaction ID not found + + + + + Transaction successfully saved to + + + + + + , txid + + + + + Failed to save transaction to + + + + + true + + + + + failed to parse refresh type + + + + + Enter optional seed offset passphrase, empty to see raw seed + + + + + Enter seed offset passphrase, empty if none + + + + + You may want to remove the file "%s" and try again + + + + + Discarding %s of unmixable outputs that cannot be spent, which can be undone by "rescan_spent". Is this okay? (Y/Yes/N/No): + + + + + Donating %s %s to The Monero Project (donate.getmonero.org or %s). + + + + + This is a multisig wallet, it can only sign with sign_multisig + + + + + This is a watch only wallet + + + + + Failed to sign transaction + + + + + Failed to sign transaction: + + + + + Transaction raw hex data exported to + + + + + Failed to load transaction from file + + + + + + + + + + + + + + failed to parse txid + + + + + Tx key: + + + + + no tx keys found for this txid + + + + + + + failed to parse tx_key + + + + + Tx key successfully stored. + + + + + Failed to store tx key: + + + + + + + signature file saved to: + + + + + + + failed to save signature file + + + + + + + error: + + + + + + failed to parse tx key + + + + + + received + + + + + + in txid + + + + + + WARNING: this transaction is not yet included in the blockchain! + + + + + + WARNING: failed to determine number of confirmations! + + + + + + received nothing in txid + + + + + + + failed to load signature file + + + + + + Good signature + + + + + + + Bad signature + + + + + wallet is watch-only and cannot generate the proof + + + + + The reserve proof can be generated only by a full wallet + + + + + Address must not be a subaddress + + + + + usage: show_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] + + + + + bad min_height parameter: + + + + + bad max_height parameter: + + + + + + block + + + + + in + + + + + [Double spend seen on the network: this transaction may or may not end up being mined] + + + + + <min_amount> should be smaller than <max_amount> + + + + + There is no unspent output in the specified address + + + + + +Amount: + + + + + , number of keys: + + + + + + + + + + +Min block height: + + + + + +Max block height: + + + + + +Min amount found: + + + + + +Max amount found: + + + + + +Total count: + + + + + +Bin size: + + + + + +Outputs per *: + + + + + count + ^ + + + + + + | + + + + + + + + + + + +--> block height + + + + + + ^ + + + + + ^ + + + + + + + + + + + Warning: this will lose any information which can not be recovered from the blockchain. + + + + + This includes destination addresses, tx secret keys, tx notes, etc + + + + + Rescan anyway ? (Y/Yes/N/No): + + + + + Good signature -- total: %s, spent: %s, unspent: %s + + + + + First line is not an amount + + + + + Invalid output: + + + + + Invalid output key, and file doesn't exist + + + + + + Invalid output + + + + + WARNING: from v8, ring size will be fixed and this setting will be ignored. + + + + + invalid argument: must be either 0/never, 1/action, or 2/encrypt/decrypt + + + + + Transfer <amount> to <address>. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) + + + + + Transfer <amount> to <address> and lock it for <lockblocks> (max. 1000000). If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) + + + + + Send all unlocked balance to an address. If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. If the parameter "outputs=<N>" is specified and N > 0, wallet splits the transaction into N even outputs. + + + + Password needed (%s) - use the refresh command - - usage: sweep_single [<priority>] [<ring_size>] [outputs=<N>] <key_image> <address> [<payment_id>] - - - - + wallet - + (no daemon) - + (out of sync) - + (Untitled account) - - - - - - + + + + + + failed to parse index: - - + + specify an index between 0 and - - usage: - account - account new <label text with white spaces allowed> - account switch <index> - account label <index> <label text with white spaces allowed> - account tag <tag_name> <account_index_1> [<account_index_2> ...] - account untag <account_index_1> [<account_index_2> ...] - account tag_description <tag_name> <description> - - - - + Grand total: Balance: - + , unlocked balance: - + Untagged accounts: - + Tag %s is unregistered. - + Accounts with tag: - + Tag's description: - + Account - + %c%8u %6s %21s %21s %21s - + ---------------------------------------------------------------------------------- - + %15s %21s %21s - + Primary address - + (used) - + (Untitled address) - + <index_min> is already out of bound - + <index_max> exceeds the bound - - usage: address [ new <label text with white spaces allowed> | all | <index_min> [<index_max>] | label <index> <label text with white spaces allowed> ] - - - - - usage: integrated_address [payment ID] - - - - - + + Integrated addresses can only be created for account 0 - + Matching integrated address: - + Integrated address: %s, payment ID: %s - + Subaddress: - + Standard address: - + failed to parse payment ID or address - - usage: address_book [(add (<address> [pid <long or short payment id>])|<integrated address> [<description possibly with whitespaces>])|(delete <index>)] - - - - + failed to parse payment ID - + failed to parse index - + Address book is empty. - + Index: - - + + Address: - + Payment ID: - - + + Description: - - usage: set_tx_note [txid] free text note - - - - - usage: get_tx_note [txid] - - - - - usage: get_description - - - - + no description found - + description found: - + Filename: - + Watch only - + %u/%u multisig%s - + %s change to %s - - + + This transaction has %u confirmations @@ -4295,365 +4557,505 @@ Grand total: - - Error finalizing multisig - - - - + Generated multisig wallets for address - + Error creating multisig wallets: - + This program generates a set of multisig wallets - use this simpler scheme only if all the participants trust each other - + Error: Can't specify more than one of --testnet and --stagenet - + Error: expected N/M, but got: - - + + Error: either --scheme or both of --threshold and --participants may be given - + Error: expected N > 1 and N <= M, but got N==%u and M==%d - + Error: --filename-base is required + + + mms::message_store - - Error: unsupported scheme: only N/N and N-1/N are supported + + Use PyBitmessage instance at URL <arg> + + + + + Specify <arg> as username:password for PyBitmessage API + + + + + Auto-config cannot proceed because auto config data from other signers is not complete + + + + + The signer config is not complete. + + + + + Wallet can't go multisig because key sets from other signers are missing or not complete. + + + + + Wallet can't start another key exchange round because key sets from other signers are missing or not complete. + + + + + Syncing not done because multisig sync data from other signers are missing or not complete. + + + + + There are waiting messages, but nothing is ready to process under normal circumstances + + + + + +Use "mms next sync" if you want to force processing of the waiting sync data + + + + + +Use "mms note" to display the waiting notes + + + + + There are no messages waiting to be processed. + + + + + key set + + + + + additional key set + + + + + multisig sync data + + + + + partially signed tx + + + + + fully signed tx + + + + + note + + + + + signer config + + + + + auto-config data + + + + + unknown message type + + + + + in + + + + + out + + + + + unknown message direction + + + + + ready to send + + + + + sent + + + + + waiting + + + + + processed + + + + + cancelled + + + + + unknown message state sw - + Generate new wallet and save it to <arg> - + Generate new wallet from device and save it to <arg> - + Generate incoming-only wallet from view key - + Generate deterministic wallet from spend key - + Generate wallet from private keys - + Generate a master wallet from multisig wallet keys - + Language for mnemonic - + Specify Electrum seed for wallet recovery/creation - + Recover wallet using Electrum-style mnemonic seed - + Recover multisig wallet using Electrum-style mnemonic seed - + Generate non-deterministic view and spend keys - + failed to read wallet password - + Enter a new password for the wallet - + Wallet password - + invalid argument: must be either 0/1, true/false, y/n, yes/no - + DNSSEC validation passed - + WARNING: DNSSEC validation was unsuccessful, this address may not be correct! - + For URL: - + Monero Address = - + Is this OK? (Y/n) - + you have cancelled the transfer request - + failed to parse index: - + invalid format for subaddress lookahead; must be <major>:<minor> - + no connection to daemon. Please make sure daemon is running. - + RPC error: - + failed to get random outputs to mix: - - + + Not enough money in unlocked balance - + Failed to find a way to create transactions. This is usually due to dust which is so small it cannot pay for itself in fees, or trying to send more money than the unlocked balance, or not leaving enough for fees - + not enough outputs for specified ring size - + output amount - + found outputs to use - + Please use sweep_unmixable. - + transaction was not constructed - + transaction %s was rejected by daemon with status: - + Reason: - + one of destinations is zero - + failed to find a suitable way to split transactions - + unknown transfer error: - + Multisig error: - + internal error: - + unexpected error: - + There was an error, which could mean the node may be trying to get you to retry creating a transaction, and zero in on which outputs you own. Or it could be a bona fide error. It may be prudent to disconnect from this node, and not try to send a transaction immediately. Alternatively, connect to another node so the original node cannot correlate information. - + File %s likely stores wallet private keys! Use a different file name. - + File %s already exists. Are you sure to overwrite it? (Y/Yes/N/No): - + seconds - + minutes - + hours - + days - + months - + a long time - + This is the command line monero wallet. It needs to connect to a monero daemon to work correctly. WARNING: Do not reuse your Monero keys on another fork, UNLESS this fork has key reuse mitigations built in. Doing so will harm your privacy. - + Unknown command: - + Allow communicating with a daemon that uses a different RPC version - + Restore from specific blockchain height - + The newly created transaction will not be relayed to the monero network - + Create an address file for new wallets - + Display English language names - - + + daemon is busy. Please try again later. - + possibly lost connection to daemon - + Error: - + Failed to initialize wallet @@ -4661,228 +5063,233 @@ WARNING: Do not reuse your Monero keys on another fork, UNLESS this fork has key tools::wallet2 - + Use daemon instance at <host>:<port> - + Use daemon instance at host <arg> instead of localhost - + Wallet password file - + Use daemon instance at port <arg> instead of 18081 - + For testnet. Daemon must also be launched with --testnet flag - + can't specify daemon host or port more than once - + can't specify more than one of --password and --password-file - + the password file specified could not be read - + Failed to load file - + Wallet password (escape/quote as needed) - + Enable commands which rely on a trusted daemon - + Disable commands which rely on a trusted daemon - + Specify username[:password] for daemon RPC client - + For stagenet. Daemon must also be launched with --stagenet flag - + Set shared ring database path - + Number of rounds for the key derivation function - + HW device to use - + + HW device wallet derivation path (e.g., SLIP-10) + + + + --trusted-daemon and --untrusted-daemon are both seen, assuming untrusted - + Daemon is local, assuming trusted - + no password specified; use --prompt-for-password to prompt for a password - + Enter a new password for the wallet - + Wallet password - + Failed to parse JSON - + Version %u too new, we can only grok up to %u - + failed to parse view key secret key - - - + + + failed to verify view key secret key - + failed to parse spend key secret key - - - + + + failed to verify spend key secret key - + Electrum-style word list failed verification - + At least one of either an Electrum-style word list, private view key, or private spend key must be specified - + Both Electrum-style word list and private key(s) specified - + invalid address - + view key does not match standard address - + spend key does not match standard address - + Cannot generate deprecated wallets from JSON - + failed to parse address: - + Address must be specified in order to create watch-only wallet - + failed to generate new wallet: - + Password is needed to compute key image for incoming monero - + Invalid password: password is needed to compute key image for incoming monero - - - + + + Primary account - + No funds received in this tx. - + failed to read file - + Set subaddress lookahead sizes to <major>:<minor> @@ -4935,80 +5342,80 @@ WARNING: Do not reuse your Monero keys on another fork, UNLESS this fork has key - + Transaction not possible. Available only %s, transaction amount %s = %s + %s (fee) - + This is the RPC monero wallet. It needs to connect to a monero daemon to work correctly. - + Can't specify more than one of --testnet and --stagenet - + Can't specify more than one of --wallet-file and --generate-from-json - + Must specify --wallet-file or --generate-from-json or --wallet-dir - + Loading wallet... - - + + Saving wallet... - - + + Successfully saved - + Successfully loaded - + Wallet initialization failed: - + Failed to initialize wallet RPC server - + Starting wallet RPC server - + Failed to run wallet: - + Stopped wallet RPC server - + Failed to save wallet: @@ -5016,9 +5423,9 @@ daemon to work correctly. wallet_args - - - + + + Wallet options @@ -5073,6 +5480,16 @@ daemon to work correctly. Logging to %s + + + WARNING: You may not have a high enough lockable memory limit + + + + + see ulimit -l + + Usage: diff --git a/translations/monero_fr.ts b/translations/monero_fr.ts index 238ba17df..6576043d3 100644 --- a/translations/monero_fr.ts +++ b/translations/monero_fr.ts @@ -1,6 +1,6 @@ - + Monero::AddressBookImpl @@ -29,7 +29,7 @@ Attempting to save transaction to file, but specified file(s) exist. Exiting to not risk overwriting. File: - Tentative d'enregistrement d'une transaction dans un fichier, mais le fichier spécifié existe déjà. Sortie pour ne pas risquer de l'écraser. Fichier : + Tentative d'enregistrement d'une transaction dans un fichier, mais le fichier spécifié existe déjà. Sortie pour ne pas risquer de l'écraser. Fichier : @@ -49,17 +49,17 @@ transaction %s was rejected by daemon with status: - la transaction %s a été rejetée par le démon avec le statut : + la transaction %s a été rejetée par le démon avec le statut : . Reason: - . Raison : + . Raison : Unknown exception: - Exception inconnue : + Exception inconnue : @@ -134,383 +134,384 @@ Monero::WalletImpl - + payment id has invalid format, expected 16 or 64 character hex string: - format d'identifiant de paiement invalide, 16 ou 64 caractères hexadécimaux attendus : + format d'identifiant de paiement invalide, 16 ou 64 caractères hexadécimaux attendus : - + Failed to add short payment id: - Échec de l'ajout de l'ID de paiement court : + Échec de l'ajout de l'ID de paiement court : - - + + daemon is busy. Please try again later. le démon est occupé. Veuillez réessayer plus tard. - - + + no connection to daemon. Please make sure daemon is running. pas de connexion au démon. Veuillez vous assurer que le démon fonctionne. - - + + RPC error: - Erreur RPC : + Erreur RPC : - - + + not enough outputs for specified ring size pas assez de sorties pour la taille de cercle spécifiée - - + + found outputs to use sorties à utiliser trouvées - + Please sweep unmixable outputs. Veuillez balayer les sorties non mélangeables. - - + + not enough money to transfer, available only %s, sent amount %s pas assez de fonds pour le transfert, montant disponible %s, montant envoyé %s - + failed to parse address échec de l'analyse de l'adresse - + failed to parse secret spend key échec de l'analyse de la clé secrète de dépense - + failed to parse secret view key échec de l'analyse de la clé secrète d'audit - + failed to verify secret spend key échec de la vérification de la clé secrète de dépense - + spend key does not match address la clé de dépense ne correspond pas à l'adresse - + failed to verify secret view key échec de la vérification de la clé secrète d'audit - + view key does not match address la clé d'audit ne correspond pas à l'adresse - - + + failed to generate new wallet: - échec de la génération du nouveau portefeuille : + échec de la génération du nouveau portefeuille : - + Failed to send import wallet request Échec de l'envoi de la requête d'importation de portefeuille - + Failed to load unsigned transactions Échec du chargement des transaction non signées - + Failed to load transaction from file Échec du chargement de la transaction du fichier - + Wallet is view only Portefeuille d'audit uniquement - + failed to save file échec de l'enregistrement du fichier - + Key images can only be imported with a trusted daemon Les images de clé ne peuvent être importées qu'avec un démon de confiance - + Failed to import key images: - Échec de l'importation des images de clé : + Échec de l'importation des images de clé : - + Failed to get subaddress label: - Échec de la récupération de l'étiquette de sous-adresse : + Échec de la récupération de l'étiquette de sous-adresse : - + Failed to set subaddress label: - Échec de l'affectation de l'étiquette de sous-adresse : + Échec de l'affectation de l'étiquette de sous-adresse : - + Neither view key nor spend key supplied, cancelled Ni clé d'audit ni clé de dépense fournie, annulation - + Electrum seed is empty La phrase Electrum est vide - + Electrum-style word list failed verification Échec de la vérification de la liste de mots de style Electrum - + Failed to get multisig info: Échec de la récupération des infos multisig : - + + Failed to make multisig: Échec de la création multisig : - + Failed to finalize multisig wallet creation Échec de la finalisation de la création du portefeuille multisig - + Failed to finalize multisig wallet creation: Échec de la finalisation de la création du portefeuille multisig : - + Failed to export multisig images: Échec de l'exportation des images multisig : - + Failed to parse imported multisig images Échec de l'analyse des images multisig importées - + Failed to import multisig images: Échec de l'importation des images multisig : - + Failed to check for partial multisig key images: Échec de la vérification des images de clé multisig partielles : - + Failed to restore multisig transaction: Échec de la restauration de la transaction multisig : - + Invalid destination address Adresse de destination invalide - + failed to get outputs to mix: %s échec de la récupération de sorties à mélanger : %s - - + + not enough money to transfer, overall balance only %s, sent amount %s pas assez de fonds pour le transfer, solde global disponible %s, montant envoyé %s - - + + not enough money to transfer, available only %s, transaction amount %s = %s + %s (fee) pas assez de fonds pour le transfert, montant disponible %s, montant envoyé %s = %s + %s (frais) - - + + output amount montant de la sortie - - + + transaction was not constructed la transaction n'a pas été construite - - + + transaction %s was rejected by daemon with status: - la transaction %s a été rejetée par le démon avec le statut : + la transaction %s a été rejetée par le démon avec le statut : - - + + one of destinations is zero une des destinations est zéro - - + + failed to find a suitable way to split transactions échec de la recherche d'une façon adéquate de scinder les transactions - - + + unknown transfer error: - erreur de transfert inconnue : + erreur de transfert inconnue : - - + + internal error: - erreur interne : + erreur interne : - - + + unexpected error: - erreur inattendue : + erreur inattendue : - - + + unknown error erreur inconnue - + failed to get outputs to mix échec de la récupération de sorties à mélanger - - - - - - - + + + + + + + Failed to parse txid Échec de l'analyse de l'ID de transaction - + no tx keys found for this txid aucune clé de transaction trouvée pour cet ID de transaction - - + + Failed to parse tx key Échec de l'analyse de la clé de transaction - - - + + + Failed to parse address Échec de l'analyse de l'adresse - + Address must not be a subaddress L'adresse ne doit pas être une sous-adresse - + The wallet must be in multisig ready state Le portefeuille doit être multisig et prêt - + Given string is not a key La chaîne entrée n'est pas une clé - + Rescan spent can only be used with a trusted daemon Réexaminer les dépenses ne peut se faire qu'avec un démon de confiance - + Invalid output: Sortie invalide : - - Failed to set blackballed outputs - Échec de l'affectation des sorties blackboulées + + Failed to mark outputs as spent + - - + + Failed to mark output as spent + + + + + Failed to mark output as unspent + + + + + Failed to parse output amount Échec de l'analyse du montant de la sortie - - + + Failed to parse output offset Échec de l'analyse de l'offset de la sortie - - Failed to blackball output - Échec du blackboulage de la sortie - - - - Failed to unblackball output - Échec du déblackboulage de la sortie - - - - + + Failed to parse key image Échec de l'analyse de l'image de clé - + Failed to get ring Échec de la récupération du cercle - + Failed to get rings Échec de la récupération des cercles - + Failed to set ring Échec de l'affectation du cercle @@ -541,12 +542,12 @@ command_line - + yes oui - + no non @@ -603,2265 +604,312 @@ cryptonote::simple_wallet - + Commands: - Commandes : + Commandes : - + failed to read wallet password échec de la lecture du mot de passe du portefeuille - + invalid password mot de passe invalide - + set seed: needs an argument. available options: language - set seed : requiert un argument. options disponibles : language + set seed : requiert un argument. options disponibles : language - + set: unrecognized argument(s) - set : argument(s) non reconnu(s) + set : argument(s) non reconnu(s) - + wallet file path not valid: - chemin du fichier portefeuille non valide : + chemin du fichier portefeuille non valide : - + Attempting to generate or restore wallet, but specified file(s) exist. Exiting to not risk overwriting. Tentative de génération ou de restauration d'un portefeuille, mais le fichier spécifié existe déjà. Sortie pour ne pas risquer de l'écraser. - - usage: payment_id - usage : payment_id - - - + needs an argument requiert un argument - - - - - - - - - - - - + + + + + + + + + + + + + 0 or 1 0 ou 1 - - - + + + unsigned integer entier non signé - - NOTE: the following 25 words can be used to recover access to your wallet. Write them down and store them somewhere safe and secure. Please do not store them in your email or on file storage services outside of your immediate control. - - VEUILLEZ NOTER : les 25 mots suivants peuvent être utilisés pour restaurer votre portefeuille. Veuillez les écrire sur papier et les garder dans un endroit sûr. Ne les gardez pas dans un courriel ou dans un service de stockage de fichiers hors de votre contrôle. - - - - + --restore-deterministic-wallet uses --generate-new-wallet, not --wallet-file --restore-deterministic-wallet utilise --generate-new-wallet, pas --wallet-file - + specify a recovery parameter with the --electrum-seed="words list here" spécifiez un paramètre de récupération avec --electrum-seed="liste de mots ici" - + specify a wallet path with --generate-new-wallet (not --wallet-file) spécifiez un chemin de portefeuille avec --generate-new-wallet (pas --wallet-file) - + wallet failed to connect to daemon: - échec de la connexion du portefeuille au démon : + échec de la connexion du portefeuille au démon : - + Daemon uses a different RPC major version (%u) than the wallet (%u): %s. Either update one of them, or use --allow-mismatched-daemon-version. - Le démon utilise une version majeure de RPC (%u) différente de celle du portefeuille (%u) : %s. Mettez l'un des deux à jour, ou utilisez --allow-mismatched-daemon-version. + Le démon utilise une version majeure de RPC (%u) différente de celle du portefeuille (%u) : %s. Mettez l'un des deux à jour, ou utilisez --allow-mismatched-daemon-version. - + List of available languages for your wallet's seed: - Liste des langues disponibles pour la phrase mnémonique de votre portefeuille : + Liste des langues disponibles pour la phrase mnémonique de votre portefeuille : - + Enter the number corresponding to the language of your choice: - Entrez le nombre correspondant à la langue de votre choix : + Entrez le nombre correspondant à la langue de votre choix : - + You had been using a deprecated version of the wallet. Please use the new seed that we provide. Vous avez utilisé une version obsolète du portefeuille. Veuillez dorénavant utiliser la nouvelle phrase mnémonique que nous fournissons. - - + + Generated new wallet: - Nouveau portefeuille généré : + Nouveau portefeuille généré : - - - - + + + + failed to generate new wallet: - échec de la génération du nouveau portefeuille : + échec de la génération du nouveau portefeuille : - + Opened watch-only wallet Ouverture du portefeuille d'audit - + Opened wallet Ouverture du portefeuille - + You had been using a deprecated version of the wallet. Please proceed to upgrade your wallet. Vous avez utilisé une version obsolète du portefeuille. Veuillez procéder à la mise à jour de votre portefeuille. - + You had been using a deprecated version of the wallet. Your wallet file format is being upgraded now. Vous avez utilisé une version obsolète du portefeuille. Le format de votre fichier portefeuille est en cours de mise à jour. - + failed to load wallet: - échec du chargement du portefeuille : + échec du chargement du portefeuille : - + Use the "help" command to see the list of available commands. Utilisez la commande "help" pour voir la liste des commandes disponibles. - + Wallet data saved Données du portefeuille sauvegardées - + Mining started in daemon La mine a démarré dans le démon - + mining has NOT been started: - la mine n'a PAS démarré : + la mine n'a PAS démarré : - + Mining stopped in daemon La mine a été stoppée dans le démon - + mining has NOT been stopped: - la mine n'a PAS été stoppée : + la mine n'a PAS été stoppée : - + Blockchain saved Chaîne de blocs sauvegardée - - + + Height Hauteur - + spent dépensé - + Starting refresh... Démarrage du rafraîchissement... - + Refresh done, blocks received: - Rafraîchissement effectué, blocs reçus : + Rafraîchissement effectué, blocs reçus : - + payment id has invalid format, expected 16 or 64 character hex string: - format d'identifiant de paiement invalide, 16 ou 64 caractères hexadécimaux attendus : + format d'identifiant de paiement invalide, 16 ou 64 caractères hexadécimaux attendus : - + bad locked_blocks parameter: - mauvais paramètre locked_blocks : + mauvais paramètre locked_blocks : - - + + a single transaction cannot use more than one payment id: - une unique transaction ne peut pas utiliser plus d'un ID de paiement : + une unique transaction ne peut pas utiliser plus d'un ID de paiement : - - - - + + + + failed to set up payment id, though it was decoded correctly échec de la définition de l'ID de paiement, bien qu'il ait été décodé correctement - - - - - - - - - transaction cancelled. - transaction annulée. + + + Send this multisig info to all other participants, then use exchange_multisig_keys <info1> [<info2>...] with others' multisig info + - - - Is this okay anyway? (Y/Yes/N/No): - Est-ce correct quand même ? (Y/Yes/Oui/N/No/Non) : - - - - There is currently a %u block backlog at that fee level. Is this okay? (Y/Yes/N/No): - Il y a actuellement un arriéré de %u blocs à ce niveau de frais. Est-ce correct quand même ? (Y/Yes/Oui/N/No/Non) : - - - - Failed to check for backlog: - Échec de la vérification du backlog : - - - - - -Transaction - -Transaction - - - - - Spending from address index %d - - Dépense depuis l'adresse d'index %d - - - - - - WARNING: Outputs of multiple addresses are being used together, which might potentially compromise your privacy. - - ATTENTION : Des sorties de multiples adresses sont utilisées ensemble, ce qui pourrait potentiellement compromettre votre confidentialité. - - - - - Sending %s. - Envoi de %s. - - - - Your transaction needs to be split into %llu transactions. This will result in a transaction fee being applied to each transaction, for a total fee of %s - Votre transaction doit être scindée en %llu transactions. Il en résulte que des frais de transaction doivent être appliqués à chaque transaction, pour un total de %s - - - - The transaction fee is %s - Les frais de transaction sont de %s - - - - , of which %s is dust from change - , dont %s est de la poussière de monnaie rendue - - - - . - . - - - - A total of %s from dust change will be sent to dust address - Un total de %s de poussière de monnaie rendue sera envoyé à une adresse de poussière - - - - . -This transaction will unlock on block %llu, in approximately %s days (assuming 2 minutes per block) - . -Cette transaction sera déverrouillée au bloc %llu, dans approximativement %s jours (en supposant 2 minutes par bloc) - - - - - - - - - - - Failed to write transaction(s) to file - Échec de l'écriture de(s) transaction(s) dans le fichier - - - - - - - - - - - Unsigned transaction(s) successfully written to file: - Transaction(s) non signée(s) écrite(s) dans le fichier avec succès : - - - - No unmixable outputs found - Aucune sortie non mélangeable trouvée - - - - No address given - Aucune adresse fournie - - - - failed to parse Payment ID - échec de l'analyse de l'ID de paiement - - - - failed to parse key image - échec de l'analyse de l'image de clé - - - - No outputs found - Pas de sorties trouvées - - - - Multiple transactions are created, which is not supposed to happen - De multiples transactions sont crées, ce qui n'est pas supposé arriver - - - - The transaction uses multiple or no inputs, which is not supposed to happen - La transaction utilise aucune ou de multiples entrées, ce qui n'est pas supposé arriver - - - - missing threshold amount - montant seuil manquant - - - - invalid amount threshold - montant seuil invalide - - - - usage: donate [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <amount> [<payment_id>] - usage : donate [index=<N1>[,<N2>,...]] [<priorité>] [<taille_cercle>] <montant> [<ID_paiement>] - - - - Claimed change does not go to a paid address - La monnaie réclamée ne va pas à une adresse payée - - - - Claimed change is larger than payment to the change address - La monnaie réclamée est supérieure au paiement à l'adresse de monnaie - - - - sending %s to %s - envoi de %s à %s - - - - dummy output(s) - sortie(s) factice(s) - - - - with no destinations - sans destination - - - - Loaded %lu transactions, for %s, fee %s, %s, %s, with min ring size %lu, %s. %sIs this okay? (Y/Yes/N/No): - %lu transactions chargées, pour %s, frais %s, %s, %s, taille de cercle minimum %lu, %s. %sEst-ce correct ? (Y/Yes/Oui/N/No/Non) : - - - - This is a multisig wallet, it can only sign with sign_multisig - Ceci est un portefeuille multisig, il ne peut signer qu'avec sign_multisig - - - - Failed to sign transaction - Échec de signature de transaction - - - - Failed to sign transaction: - Échec de signature de transaction : - - - - Transaction raw hex data exported to - Données brutes hex de la transaction exportées vers - - - - Failed to load transaction from file - Échec du chargement de la transaction du fichier - - - - - RPC error: - Erreur RPC : - - - - wallet is watch-only and has no spend key - c'est un portefeuille d'audit et il n'a pas de clé de dépense - - - - - - Your original password was incorrect. - Votre mot de passe original est incorrect. - - - - Error with wallet rewrite: - Erreur avec la réécriture du portefeuille : - - - - invalid unit - unité invalide - - - - - invalid count: must be an unsigned integer - nombre invalide : un entier non signé est attendu - - - - invalid value - valeur invalide - - - - usage: set_log <log_level_number_0-4> | <categories> - usage : set_log <niveau_de_journalisation_0-4> | <catégories> - - - - (Y/Yes/N/No): - (Y/Yes/Oui/N/No/Non) : - - - - - bad m_restore_height parameter: - mauvais paramètre m_restore_height : - - - - date format must be YYYY-MM-DD - le format de date doit être AAAA-MM-JJ - - - - Restore height is: - La hauteur de restauration est : - - - - - - Is this okay? (Y/Yes/N/No): - Est-ce correct ? (Y/Yes/Oui/N/No/Non) : - - - - Daemon is local, assuming trusted - Le démon est local, supposons qu'il est de confiance - - - - Password for new watch-only wallet - Mot de passe pour le nouveau portefeuille d'audit - - - - internal error: - erreur interne : - - - - - - unexpected error: - erreur inattendue : - - - - - - - - - - - - unknown error - erreur inconnue - - - - refresh failed: - échec du rafraîchissement : - - - - Blocks received: - Blocs reçus : - - - - unlocked balance: - solde débloqué : - - - - - - amount - montant - - - - false - faux - - - - Unknown command: - Commande inconnue : - - - - Command usage: - Usage de la commande : - - - - Command description: - Description de la commande : - - - - wallet is multisig but not yet finalized - le portefeuille est multisig mais pas encore finalisé - - - - Failed to retrieve seed - Échec de la récupération de la phrase mnémonique - - - - wallet is multisig and has no seed - le portefeuille est multisig et n'a pas de phrase mnémonique - - - - Cannot connect to daemon - Impossible de se connecter au démon - - - - Error: failed to estimate backlog array size: - Erreur : échec de l'estimation de la taille du tableau d'arriéré : - - - - Error: bad estimated backlog array size - Erreur : mauvaise estimation de la taille du tableau d'arriéré - - - - (current) - (actuel) - - - - %u block (%u minutes) backlog at priority %u%s - arriéré de %u bloc(s) (%u minutes) à la priorité %u%s - - - - %u to %u block (%u to %u minutes) backlog at priority %u - arriéré de %u à %u bloc(s) (%u à %u minutes) à la priorité %u - - - - No backlog at priority - Pas d'arriéré à la priorité - - - - - This wallet is already multisig - Le portefeuille est déjà multisig - - - - - wallet is watch-only and cannot be made multisig - c'est un portefeuille d'audit et il ne peut pas être tranformé en multisig - - - - - This wallet has been used before, please use a new wallet to create a multisig wallet - Ce portefeuille a été utilisé auparavant, veuillez utiliser un nouveau portefeuille pour créer un portefeuille multisig - - - - Send this multisig info to all other participants, then use make_multisig <threshold> <info1> [<info2>...] with others' multisig info - Envoyez ces infos multisig à tous les autres participants, ensuite utilisez make_multisig <seuil> <info1> [<info2>...] avec les infos multisig des autres - - - - This includes the PRIVATE view key, so needs to be disclosed only to that multisig wallet's participants - Ceci inclut la clé PRIVÉE d'audit, donc ne doit être divulgué qu'aux participants de ce portefeuille multisig - - - - usage: make_multisig <threshold> <multisiginfo1> [<multisiginfo2>...] - usage : make_multisig <seuil> <multisiginfo1> [<multisiginfo2>...] - - - - Invalid threshold - Seuil invalide - - - - Another step is needed - Une autre étape est nécessaire - - - - Send this multisig info to all other participants, then use finalize_multisig <info1> [<info2>...] with others' multisig info - Envoyez ces infos multisig à tous les autres participants, ensuite utilisez finalize_multisig <info1> [<info2>...] avec les infos multisig des autres - - - - Error creating multisig: - Erreur de création multisig : - - - - Error creating multisig: new wallet is not multisig - Erreur de création multisig : le nouveau portefeuille n'est pas multisig - - - - multisig address: - adresse multisig : - - - - - - This wallet is not multisig - Ce portefeuille n'est pas multisig - - - - This wallet is already finalized - Ce portefeuille est déjà finalisé - - - - usage: finalize_multisig <multisiginfo1> [<multisiginfo2>...] - usage : finalize_multisig <multisiginfo1> [<multisiginfo2>...] - - - - Failed to finalize multisig - Échec de finalisation multisig - - - - Failed to finalize multisig: - Échec de finalisation multisig : - - - - - - - - This multisig wallet is not yet finalized - Ce portefeuille multisig n'est pas encore finalisé - - - - usage: export_multisig_info <filename> - usage : export_multisig_info <nom_fichier> - - - - Error exporting multisig info: - Erreur d'importation des infos multisig : - - - - Multisig info exported to - Infos multisig exportées vers - - - - usage: import_multisig_info <filename1> [<filename2>...] - one for each other participant - usage : import_multisig_info <nom_fichier1> [<nom_fichier2>...] - un pour chaque autre participant - - - - Multisig info imported - Infos multisig importées - - - - Failed to import multisig info: - Échec de l'importation des infos multisig : - - - - Failed to update spent status after importing multisig info: - Échec de la mise à jour de l'état des dépenses après l'importation des infos multisig : - - - - Untrusted daemon, spent status may be incorrect. Use a trusted daemon and run "rescan_spent" - Pas un démon de confiance, l'état des dépenses peut être incorrect. Utilisez un démon de confiance et executez "rescan_spent" - - - - - - This is not a multisig wallet - Ceci n'est pas un portefeuille multisig - - - - usage: sign_multisig <filename> - usage : sign_multisig <nom_fichier> - - - - Failed to sign multisig transaction - Échec de la signature de la transaction multisig + + Multisig wallet has been successfully created. Current wallet type: + - Multisig error: - Erreur multisig : + Failed to perform multisig keys exchange: + - - Failed to sign multisig transaction: - Échec de la signature de la transaction multisig : + + Failed to load multisig transaction from MMS + - - It may be relayed to the network with submit_multisig - Elle peut être transmise au réseau avec submit_multisig + + Failed to mark output spent: + - - usage: submit_multisig <filename> - usage : submit_multisig <nom_fichier> + + Failed to mark output unspent: + - - - Failed to load multisig transaction from file - Échec du chargement de la transaction multisig du fichier + + Spent: + - - - Multisig transaction signed by only %u signers, needs %u more signatures - Transaction multisig signée par %u signataire(s) seulement, nécessite %u signature(s) de plus + + Not spent: + - - - Transaction successfully submitted, transaction - Transaction transmise avec succès, transaction + + Failed to check whether output is spent: + - - - You can check its status by using the `show_transfers` command. - Vous pouvez vérifier son statut en utilisant la commane 'show_transfers'. - - - - usage: export_raw_multisig <filename> - usage : export_raw_multisig <nom_fichier> - - - - Failed to export multisig transaction to file - Échec de l'exportation de la transaction multisig vers le fichier - - - - Saved exported multisig transaction file(s): - Transaction multisig enregistrée dans le(s) fichier(s) : - - - - - - ring size must be an integer >= - la taille de cercle doit être un nombre entier >= - - - - could not change default ring size - échec du changement de la taille de cercle par défaut - - - - - Invalid height - Hauteur invalide - - - - start_mining [<number_of_threads>] [bg_mining] [ignore_battery] - start_mining [<nombre_de_threads>] [mine_arrière_plan] [ignorer_batterie] - - - - Start mining in the daemon (bg_mining and ignore_battery are optional booleans). - Démarrer la mine dans le démon (mine_arrière_plan et ignorer_batterie sont des booléens facultatifs). - - - - Stop mining in the daemon. - Arrêter la mine dans le démon. - - - - Set another daemon to connect to. - Spécifier un autre démon auquel se connecter. - - - - Save the current blockchain data. - Sauvegarder les données actuelles de la châine de blocs. - - - - Synchronize the transactions and balance. - Synchroniser les transactions et le solde. - - - - balance [detail] - solde [détail] - - - - Show the wallet's balance of the currently selected account. - Afficher le solde du compte actuellement sélectionné. - - - - incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] - incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] - - - - Show the incoming transfers, all or filtered by availability and address index. - -Output format: -Amount, Spent("T"|"F"), "locked"|"unlocked", RingCT, Global Index, Transaction Hash, Address Index, [Public Key, Key Image] - Afficher les transferts entrants, tous ou filtrés par disponibilité et index d'adresse. - - - - payments <PID_1> [<PID_2> ... <PID_N>] - payments <PID_1> [<PID_2> ... <PID_N>] - - - - Show the payments for the given payment IDs. - Afficher les paiements pour les IDs de paiement donnés. - - - - Show the blockchain height. - Afficher la hauteur de la chaîne de blocs. - - - - Send all unmixable outputs to yourself with ring_size 1 - Envoyer toutes les sorties non mélangeables à vous-même avec une taille de cercle de 1 - - - - sweep_below <amount_threshold> [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> [<payment_id>] - sweep_below <montant_seuil> [index=<N1>[,<N2>,...]] [<priorité>] [<taille_cercle>] <adresse> [<ID_paiement>] - - - - Send all unlocked outputs below the threshold to an address. - Envoyer toutes les sorties débloquées d'un montant inférieur au seuil à une adresse. - - - - Send a single output of the given key image to an address without change. - Envoyer une unique sortie ayant une image de clé donnée à une adresse sans rendu de monnaie. - - - - donate [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <amount> [<payment_id>] - donate [index=<N1>[,<N2>,...]] [<priorité>] [<taille_cercle>] <montant> [<ID_paiement>] - - - - Donate <amount> to the development team (donate.getmonero.org). - Donner <montant> à l'équipe de développement (donate.getmonero.org). - - - - Submit a signed transaction from a file. - Transmettre une transaction signée d'un fichier. - - - - set_log <level>|{+,-,}<categories> - set_log <niveau>|{+,-,}<catégories> - - - - Change the current log detail (level must be <0-4>). - Changer le niveau de détail du journal (le niveau doit être <0-4>). - - - - account - account new <label text with white spaces allowed> - account switch <index> - account label <index> <label text with white spaces allowed> - account tag <tag_name> <account_index_1> [<account_index_2> ...] - account untag <account_index_1> [<account_index_2> ...] - account tag_description <tag_name> <description> - account - account new <texte étiquette avec espaces autorisés> - account switch <index> - account label <index> <texte étiquette avec espaces autorisés> - account tag <mot_clé> <index_compte_1> [<index_compte_2> ...] - account untag <index_compte_1> [<index_compte_2> ...] - account tag_description <mot_clé> <description> - - - - If no arguments are specified, the wallet shows all the existing accounts along with their balances. -If the "new" argument is specified, the wallet creates a new account with its label initialized by the provided label text (which can be empty). -If the "switch" argument is specified, the wallet switches to the account specified by <index>. -If the "label" argument is specified, the wallet sets the label of the account specified by <index> to the provided label text. -If the "tag" argument is specified, a tag <tag_name> is assigned to the specified accounts <account_index_1>, <account_index_2>, .... -If the "untag" argument is specified, the tags assigned to the specified accounts <account_index_1>, <account_index_2> ..., are removed. -If the "tag_description" argument is specified, the tag <tag_name> is assigned an arbitrary text <description>. - Si aucun argument n'est spécifié, le portefeuille affiche tous les comptes existants ainsi que leurs soldes. -Si l'argument "new" est spécifié, le portefeuille crée un nouveau compte avec son étiquette initialisée par le texte fourni (qui peut être vide). -Si l'argument "switch" est spécifié, le portefeuille passe au compte spécifié par <index>. -Si l'argument "label" est spécifié, le portefeuille affecte le texte fourni à l'étiquette du compte spécifié par <index>. -Si l'argument "tag" est spécifié, un mot clé <mot_clé> est assigné aux comptes spécifiés <account_index_1>, <account_index_2>, .... -Si l'argument "untag" est spécifié, les mots clés assignés aux comptes spécifiés <account_index_1>, <account_index_2> ..., sont supprimés. -Si l'argument "tag_description" est spécifié, le texte arbitraire <description> est assigné au mot clé <mot_clé>. - - - - address [ new <label text with white spaces allowed> | all | <index_min> [<index_max>] | label <index> <label text with white spaces allowed>] - address [ new <texte étiquette avec espaces autorisés> | all | <index_min> [<index_max>] | label <index> <texte étiquette avec espaces autorisés>] - - - - integrated_address [<payment_id> | <address>] - integrated_address [<ID_paiement> | <adresse>] - - - - 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 - Encoder un ID de paiement dans une adresse intégrée pour l'adresse publique du portefeuille actuel (en l'absence d'argument un ID de paiement aléatoire est utilisé), ou décoder une adresse intégrée en une adresse standard et un ID de paiement - - - - address_book [(add ((<address> [pid <id>])|<integrated address>) [<description possibly with whitespaces>])|(delete <index>)] - address_book [(add ((<adresse> [pid <id>])|<adresse intégrée>) [<description avec éventuellement des espaces>])|(delete <index>)] - - - - Print all entries in the address book, optionally adding/deleting an entry to/from it. - Afficher toutes les entrées du carnet d'adresses, optionnellement en y ajoutant/supprimant une entrée. - - - - Save the wallet data. - Sauvegarder les données du portefeuille. - - - - Save a watch-only keys file. - Sauvegarder un fichier de clés d'audit. - - - - Display the private view key. - Afficher la clé privée d'audit. - - - - Display the private spend key. - Afficher la clé privée de dépense. - - - - Display the Electrum-style mnemonic seed - Afficher la phrase mnémonique de style Electrum - - - - set <option> [<value>] - set <option> [<valeur>] - - - - Display the encrypted Electrum-style mnemonic seed. - Afficher la phrase mnémonique de style Electrum chiffrée. - - - - Rescan the blockchain for spent outputs. - Rescanner la chaîne de blocs pour trouver les sorties dépensées. - - - - get_tx_key <txid> - get_tx_key <ID_transaction> - - - - Get the transaction key (r) for a given <txid>. - Obtenir la clé de transaction (r) pour un <ID_transaction> donné. - - - - check_tx_key <txid> <txkey> <address> - check_tx_key <ID_transaction> <clé_transaction> <adresse> - - - - Check the amount going to <address> in <txid>. - Vérifier le montant allant à <adresse> dans <ID_transaction>. - - - - get_tx_proof <txid> <address> [<message>] - get_tx_proof <ID_transaction> <adresse> [<message>] - - - - Generate a signature proving funds sent to <address> in <txid>, optionally with a challenge string <message>, using either the transaction secret key (when <address> is not your wallet's address) or the view secret key (otherwise), which does not disclose the secret key. - Générer une signature prouvant l'envoi de fonds à <adresse> dans <ID_transaction>, optionnellement avec un <message> comme challenge, en utilisant soit la clé secrète de transaction (quand <adresse> n'est pas l'adresse de votre portefeuille) soit la clé secrète d'audit (dans le cas contraire), tout en ne divulgant pas la clé secrète. - - - - check_tx_proof <txid> <address> <signature_file> [<message>] - check_tx_proof <ID_transaction> <adresse> <fichier_signature> [<message>] - - - - Check the proof for funds going to <address> in <txid> with the challenge string <message> if any. - Vérifier la validité de la preuve de fonds allant à <adresse> dans <ID_transaction> avec le <message> de challenge s'il y en a un. - - - - get_spend_proof <txid> [<message>] - get_spend_proof <ID_transaction> [<message>] - - - - Generate a signature proving that you generated <txid> using the spend secret key, optionally with a challenge string <message>. - Générer une signature prouvant que vous avez créé <ID_transaction> en utilisant la clé secrète de dépense, optionnellement avec un <message> comme challenge. - - - - check_spend_proof <txid> <signature_file> [<message>] - check_spend_proof <ID_transaction> <fichier_signature> [<message>] - - - - Check a signature proving that the signer generated <txid>, optionally with a challenge string <message>. - Vérifier la validité de la preuve que le signataire a créé <ID_transaction>, optionnellement avec un <message> comme challenge. - - - - get_reserve_proof (all|<amount>) [<message>] - get_reserve_proof (all|<montant>) [<message>] - - - - Generate a signature proving that you own at least this much, optionally with a challenge string <message>. -If 'all' is specified, you prove the entire sum of all of your existing accounts' balances. -Otherwise, you prove the reserve of the smallest possible amount above <amount> available in your current account. - Générer une signature prouvant que vous possédez au moins ce montant, optionnellement avec un <message> comme challenge. -Si 'all' est spécifié, vous prouvez la somme totale des soldes de tous vos comptes existants. -Sinon, vous prouvez le plus petit solde supérieur à <montant> dans votre compte actuel. - - - - check_reserve_proof <address> <signature_file> [<message>] - check_reserve_proof <adresse> <fichier_signature> [<message>] - - - - Check a signature proving that the owner of <address> holds at least this much, optionally with a challenge string <message>. - Vérifier la validité d'une signature prouvant que le propriétaire d'une <adresse> détient au moins un montant, optionnellement avec un <message> comme challenge. - - - - Show the incoming/outgoing transfers within an optional height range. - -Output format: -In or Coinbase: Block Number, "block"|"in", Time, Amount, Transaction Hash, Payment ID, Subaddress Index, "-", Note\ -Out: Block Number, "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Destinations, Input addresses**, "-", Note -Pool: "pool", "in", Time, Amount, Transaction Hash, Payment Id, Subaddress Index, "-", Note, Double Spend Note\ -Pending or Failed: "failed"|"pending", "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Input addresses**, "-", Note - -* Excluding change and fee. -** Set of address indices used as inputs in this transfer. - Afficher les transferts entrants/sortants dans un interval de hauteurs facultatif. - - - - unspent_outputs [index=<N1>[,<N2>,...]] [<min_amount> [<max_amount>]] - unspent_outputs [index=<N1>[,<N2>,...]] [<montant_min> [<montant_max>]] - - - - Show the unspent outputs of a specified address within an optional amount range. - Afficher les sorties non dépensées d'une adresse spécifique dans un interval de montants facultatif. - - - - set_tx_note <txid> [free text note] - set_tx_note <ID_transaction> [texte de la note] - - - - Set an arbitrary string note for a <txid>. - Définir un texte arbitraire comme note pour <ID_transaction>. - - - - get_tx_note <txid> - get_tx_note <ID_transaction> - - - - Get a string note for a txid. - Obtenir le texte de la note pour <ID_transaction>. - - - - set_description [free text note] - set_description [texte] - - - - Set an arbitrary description for the wallet. - Définir un texte arbitraire comme description du portefeuille. - - - - Get the description of the wallet. - Obtenir la description du portefeuille. - - - - Show the wallet's status. - Afficher l'état du portefeuille. - - - - Show the wallet's information. - Afficher les informations du portefeuille. - - - - sign <file> - sign <fichier> - - - - Sign the contents of a file. - Signer le contenu d'un fichier. - - - - verify <filename> <address> <signature> - verify <fichier> <adresse> <signature> - - - - Verify a signature on the contents of a file. - Vérifier la signature du contenu d'un fichier. - - - - export_key_images <file> - export_key_images <fichier> - - - - Export a signed set of key images to a <file>. - Exported un ensemble signé d'images de clé vers un <fichier>. - - - - import_key_images <file> - import_key_images <fichier> - - - - Import a signed key images list and verify their spent status. - Importer un ensemble signé d'images de clé et vérifier si elles correspondent à des dépenses. - - - - export_outputs <file> - export_outputs <fichier> - - - - Export a set of outputs owned by this wallet. - Exporter un ensemble de sorties possédées par ce portefeuille. - - - - import_outputs <file> - import_outputs <fichier> - - - - Import a set of outputs owned by this wallet. - Importer un ensemble de sorties possédées par ce portefeuille. - - - - show_transfer <txid> - show_transfer <ID_transaction> - - - - Show information about a transfer to/from this address. - Afficher les information à propos d'un transfert vers/depuis cette adresse. - - - - Change the wallet's password. - Changer le mot de passe du portefeuille. - - - - Generate a new random full size payment id. These will be unencrypted on the blockchain, see integrated_address for encrypted short payment ids. - Générer un nouvel ID de paiement long aléatoire. Ceux-ci sont en clair dans la chaîne de blocs, voir integrated_address pour les IDs de paiement courts cryptés. - - - - Print the information about the current fee and transaction backlog. - Afficher les informations à propos des frais et arriéré de transactions actuels. - - - - Export data needed to create a multisig wallet - Exporter les données nécessaires pour créer un portefeuille multisig - - - - make_multisig <threshold> <string1> [<string>...] - make_multisig <seuil> <chaîne_caractères1> [<chaîne_caractères>...] - - - - Turn this wallet into a multisig wallet - Transformer ce portefeuille en portefeuille multisig - - - - finalize_multisig <string> [<string>...] - finalize_multisig <chaîne_caractères> [<chaîne_caractères>...] + + Please confirm the transaction on the device + - Turn this wallet into a multisig wallet, extra step for N-1/N wallets - Transformer ce portefeuille en portefeuille multisig, étape supplémentaire pour les portefeuilles N-1/N + Device name not specified + - - export_multisig_info <filename> - export_multisig_info <fichier> + + Device reconnect failed + - - Export multisig info for other participants - Exporter les infos multisig pour les autres participants + + Device reconnect failed: + - - import_multisig_info <filename> [<filename>...] - import_multisig_info <fichier> [<fichier>...] + + Show the incoming transfers, all or filtered by availability and address index. + +Output format: +Amount, Spent("T"|"F"), "locked"|"unlocked", RingCT, Global Index, Transaction Hash, Address Index, [Public Key, Key Image] + - - Import multisig info from other participants - Importer les infos multisig des autres participants - - - - sign_multisig <filename> - sign_multisig <fichier> - - - - Sign a multisig transaction from a file - Signer une transaction multisig d'un fichier - - - - submit_multisig <filename> - submit_multisig <fichier> - - - - Submit a signed multisig transaction from a file - Transmettre une transaction multisig signée d'un fichier - - - - export_raw_multisig_tx <filename> - export_raw_multisig_tx <fichier> - - - - Export a signed multisig transaction to a file - Exporter une transaction multisig signée vers un fichier - - - - help [<command>] - help [<commande>] - - - - Show the help section or the documentation about a <command>. - Afficher la section d'aide ou la documentation d'une <commande>. - - - - integer >= - entier >= - - - - block height - hauteur de bloc - - - - No wallet found with that name. Confirm creation of new wallet named: - Aucun portefeuille avec ce nom trouvé. Confirmer la création d'un nouveau portefeuille nommé : - - - - can't specify both --restore-deterministic-wallet or --restore-multisig-wallet and --non-deterministic - impossible de spécifier à la fois --restore-deterministic-wallet ou --restore-multisig-wallet et --non-deterministic - - - - --restore-multisig-wallet uses --generate-new-wallet, not --wallet-file - --restore-multisig-wallet utilise --generate-new-wallet, pas --wallet-file - - - - specify a recovery parameter with the --electrum-seed="multisig seed here" - spécifiez un paramètre de récupération avec --electrum-seed="phrase mnémonique multisig ici" - - - - Multisig seed failed verification - Échec de la vérification de la phrase mnémonique multisig - - - - - This address is a subaddress which cannot be used here. - Cette adresse est une sous-adresse qui ne peut pas être utilisée ici. - - - - Error: expected M/N, but got: - Erreur : M/N attendu, mais lu : - - - - Error: expected N > 1 and N <= M, but got: - Erreur : N > 1 et N <= M attendu, mais lu : - - - - Error: M/N is currently unsupported. - Erreur : M/N n'est actuellement pas supporté. - - - - Generating master wallet from %u of %u multisig wallet keys - Génération du portefeuille principal à partir de %u de %u clés de portefeuille multisig - - - - failed to parse secret view key - échec de l'analyse de la clé secrète d'audit - - - - failed to verify secret view key - échec de la vérification de la clé secrète d'audit - - - - Secret spend key (%u of %u): - Clé secrète de dépense (%u de %u) : - - - - Error: M/N is currently unsupported - Erreur : M/N n'est actuellement pas supporté - - - - Restore height - Hauteur de restauration - - - - Still apply restore height? (Y/Yes/N/No): - Appliquer la hauteur de restauration quand même ? (Y/Yes/Oui/N/No/Non) : - - - - Warning: using an untrusted daemon at %s, privacy will be lessened - Attention : en n'utilisant %s qui n'est pas un démon de confiance, la confidentialité sera réduite - - - - Daemon either is not started or wrong port was passed. Please make sure daemon is running or change the daemon address using the 'set_daemon' command. - Le démon n'est pas lancé ou un mauvais port a été fourni. Veuillez vous assurer que le démon fonctionne ou changez l'adresse de démon avec la commande 'set_daemon'. - - - - Your wallet has been generated! -To start synchronizing with the daemon, use the "refresh" command. -Use the "help" command to see the list of available commands. -Use "help <command>" to see a command's documentation. -Always use the "exit" command when closing monero-wallet-cli to save -your current session's state. Otherwise, you might need to synchronize -your wallet again (your wallet keys are NOT at risk in any case). - - Votre portefeuille a été généré ! -Pour commencer la synchronisation avec le démon, utilisez la commande "refresh". -Utilisez la commande "help" pour voir la liste des commandes disponibles. -Utilisez "help <commande>" pour voir la documentation d'une commande. -Utilisez toujours la commande "exit" pour fermer monero-wallet-cli pour sauvegarder -l'état de votre session. Sinon, vous pourriez avoir besoin de synchroniser -votre portefeuille à nouveau (mais les clés de votre portefeuille ne risquent rien). - - - - - failed to generate new mutlisig wallet - échec de la génération du nouveau portefeuille multisig - - - - Generated new %u/%u multisig wallet: - Nouveau portefeuille multisig %u/%u généré : - - - - Opened %u/%u multisig wallet%s - Portefeuille multisig %u/%u ouvert%s - - - - Use "help <command>" to see a command's documentation. - - Utilisez "help <commande>" pour voir la documentation d'une commande. - - - - - wallet is multisig and cannot save a watch-only version - c'est un portefeuille multisig et il ne peut pas sauvegarder une version d'audit - - - - missing daemon URL argument - URL du démon manquante en argument - - - - Unexpected array length - Exited simple_wallet::set_daemon() - Taille de tableau inattendue - Sortie de simple_wallet::set_daemon() - - - - This does not seem to be a valid daemon URL. - Ceci semble ne pas être une URL de démon valide. - - - - - txid - ID transaction - - - - - idx - index - - - - (Some owned outputs have partial key images - import_multisig_info needed) - (Certaines sorties ont des images de clé partielles - import_multisig_info requis) - - - - Currently selected account: [ - Compte actuellement sélectionné : [ - - - - ] - ] - - - - Tag: - Mot clé : - - - - (No tag assigned) - (Pas de mot clé assigné) - - - - Balance per address: - Solde par adresse : - - - - Address - Adresse - - - - - Balance - Solde - - - - - Unlocked balance - Solde débloqué - - - - Outputs - Sorties - - - - - Label - Étiquette - - - - %8u %6s %21s %21s %7u %21s - %8u %6s %21s %21s %7u %21s - - - - usage: balance [detail] - usage : balance [detail] - - - - - usage: incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] - usage: incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] - - - - spent - dépensé - - - - global index - index global - - - - tx id - ID de transaction - - - - - addr index - index adresse - - - - No incoming transfers - Aucun transfert entrant - - - - No incoming available transfers - Aucun transfert entrant disponible - - - - No incoming unavailable transfers - Aucun transfert entrant non disponible - - - - expected at least one payment ID - au moins un ID de paiement attendu - - - - payment - paiement - - - - transaction - transaction - - - - height - hauteur - - - - unlock time - durée de déverrouillage - - - - No payments with id - Aucun paiement avec l'ID - - - - - - - failed to get blockchain height: - échec de la récupération de la hauteur de la chaîne de blocs : - - - - - - - - failed to connect to the daemon - échec de la connexion au démon - - - - -Transaction %llu/%llu: txid=%s - -Transaction %llu/%llu : ID=%s - - - - -Input %llu/%llu: amount=%s - -Entrée %llu/%llu : montant=%s - - - - failed to get output: - échec de la récupération de la sortie : - - - - output key's originating block height shouldn't be higher than the blockchain height - la hauteur du bloc d'origine de la clé de la sortie ne devrait pas être supérieure à celle de la chaîne de blocs - - - - -Originating block heights: - -Hauteurs des blocs d'origine : - - - - -| - -| - - - - - | - - | - - - - - -Warning: Some input keys being spent are from - -Attention : Certaines clés d'entrées étant dépensées sont issues de - - - - , which can break the anonymity of ring signature. Make sure this is intentional! - , ce qui peut casser l'anonymat du cercle de signature. Assurez-vous que c'est intentionnel ! - - - - - - Ring size must not be 0 - La taille de cercle ne doit pas être 0 - - - - - - ring size %u is too small, minimum is %u - la taille de cercle %u est trop petite, le minimum est %u - - - - wrong number of arguments - mauvais nombre d'arguments - - - - - - No payment id is included with this transaction. Is this okay? (Y/Yes/N/No): - Aucun ID de paiement n'est inclus dans cette transaction. Est-ce correct ? (Y/Yes/Oui/N/No/Non) : - - - - - No outputs found, or daemon is not ready - Aucune sortie trouvée, ou le démon n'est pas prêt - - - - command only supported by HW wallet - commande supportée uniquement par un portefeuille matériel - - - - Failed to reconnect device - Échec de la reconnexion à l'appareil - - - - Failed to reconnect device: - Échec de la reconnexion à l'appareil : - - - - Transaction successfully saved to - Transaction sauvegardée avec succès dans - - - - - , txid - , ID transaction - - - - Failed to save transaction to - Échec de la sauvegarde de la transaction dans - - - - - Sweeping %s in %llu transactions for a total fee of %s. Is this okay? (Y/Yes/N/No): - Balayage de %s dans %llu transactions pour des frais totaux de %s. Est-ce correct ? (Y/Yes/Oui/N/No/Non) : - - - - - - Sweeping %s for a total fee of %s. Is this okay? (Y/Yes/N/No): - Balayage de %s pour des frais totaux de %s. Est-ce correct ? (Y/Yes/Oui/N/No/Non) : - - - - This is a watch only wallet - Ceci est un portefeuille d'audit - - - - usage: show_transfer <txid> - usage : show_transfer <ID_de_transaction> - - - - Double spend seen on the network: this transaction may or may not end up being mined - Double dépense détectée sur le réseau : cette transaction sera peut-être invalidée - - - - Transaction ID not found - ID de transaction non trouvé - - - - true - vrai - - - - failed to parse refresh type - échec de l'analyse du type de rafraîchissement - - - - - - - - - - - - - - - - - - - - - - - - command not supported by HW wallet - commande non supportée par le portefeuille matériel - - - - - wallet is watch-only and has no seed - c'est un portefeuille d'audit et il n'a pas de phrase mnémonique - - - - - wallet is non-deterministic and has no seed - c'est un portefeuille non déterministe et il n'a pas de phrase mnémonique - - - - Enter optional seed offset passphrase, empty to see raw seed - Entrer une phrase de passe facultative pour le décalage de la phrase mnémonique, effacer pour voir la phrase mnémonique brute - - - - Incorrect password - Mot de passe invalide - - - - Current fee is %s %s per %s - Les frais sont actuellement de %s %s par %s - - - - usage: print_ring <key_image|txid> - usage : print_ring <image clé|ID transaction> - - - - - Invalid key image - Image de clé invalide - - - - Invalid txid - ID de transaction invalide - - - - Key image either not spent, or spent with mixin 0 - Image de clé soit non dépensée, soit dépensée avec 0 mélange - - - - Failed to get key image ring: - Échec de la récupération du cercle de l'image de clé : - - - - File doesn't exist - Le fichier d'existe pas - - - - Invalid ring specification: - Spécification de cercle invalide : - - - - Invalid key image: - Image de clé invalide : - - - - Invalid ring type, expected relative or abosolute: - Type de cercle invalide, "relative" ou "absolute" attendu : - - - - - Error reading line: - Erreur lors de la lecture de la ligne : - - - - Invalid ring: - Cercle invalide : - - - - Invalid relative ring: - Cercle relatif invalide : - - - - Invalid absolute ring: - Cercle absolu invalide : - - - - Failed to set ring for key image: - Échec de l'affectation du cercle pour l'image de clé : - - - - Continuing. - On continue. - - - - usage: set_ring <filename> | ( <key_image> absolute|relative <index> [<index>...] ) - usage : set_ring <nom_fichier> | ( <image_clé> absolute|relative <index> [<index>...] ) - - - - Missing absolute or relative keyword - Mot clé "absolute" ou "relative" manquant - - - - - invalid index: must be a strictly positive unsigned integer - index invalide : doit être un nombre entier strictement positif - - - - invalid index: indices wrap - index invalide : boucle des indices - - - - invalid index: indices should be in strictly ascending order - index invalide : les indices doivent être en ordre strictement croissant - - - - failed to set ring - échec de l'affectation du cercle - - - - usage: blackball <amount>/<offset> | <filename> [add] - usage : blackball <montant>/<offset> | <nom_fichier> [add] - - - - First line is not an amount - La première ligne n'est pas un montant - - - - Invalid output: - Sortie invalide : - - - - Bad argument: - Mauvais argument : - - - - should be "add" - devrait être "add" - - - - Failed to open file - Échec de l'ouverture du fichier - - - - Invalid output key, and file doesn't exist - Clé de sortie invalide, et le fichier n'existe pas - - - - Failed to blackball output: - Échec du blackboulage de la sortie : - - - - usage: unblackball <amount>/<offset> - usage : unblackball <montant>/<offset> - - - - - Invalid output - Sortie invalide - - - - - Failed to unblackball output: - Échec du déblackboulage de la sortie : - - - - usage: blackballed <amount>/<offset> - usage : blackballed <montant>/<offset> - - - - Blackballed: - Blackboulé : - - - - not blackballed: - non blackboulé : - - - - Failed to save known rings: - Échec de la sauvegarde des cercles connus : - - - - - wallet is watch-only and cannot transfer - c'est un portefeuille d'audit et il ne peut pas transférer - - - - - WARNING: this is a non default ring size, which may harm your privacy. Default is recommended. - ATTENTION : ceci c'est pas la taille de cercle par défaut, ce qui peut nuire à votre confidentialité. La valeur par défaut est recommandée. - - - - WARNING: from v8, ring size will be fixed and this setting will be ignored. - ATTENTION : ) partir de v8, la taille de cercle sera fixée et ce paramètre sera ignoré. - - - - - - priority must be either 0, 1, 2, 3, or 4, or one of: - la priorité doit être 0, 1, 2, 3, 4 ou l'une de : - - - - could not change default priority - échec du changement de la priorité par défaut - - - - invalid argument: must be either 0/never, 1/action, or 2/encrypt/decrypt - argument invalide : doit être soit 0/never, 1/action, ou 2/encrypt/decrypt - - - - set_daemon <host>[:<port>] [trusted|untrusted] - set_daemon <hôte>[:<port>] [trusted|untrusted] - - - - transfer [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] (<URI> | <address> <amount>) [<payment_id>] - transfer [index=<N1>[,<N2>,...]] [<priorité>] [<taille_cercle>] (<URI> | <adresse> <montant>) [<ID_paiement>] - - - - Transfer <amount> to <address>. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) - Transférer <montant> à <adresse> Si le paramètre "index=<N1>[,<N2>,...]" est spécifié, le portefeuille utilise les sorties reçues par les adresses de ces indices. Si il est omis, le portefeuille choisit les indices d'adresse à utiliser aléatoirement. Dans tous les cas, il essaye de ne pas combiner des sorties de multiples adresses. <priorité> est la priorité de la transaction. Plus la priorité est haute, plus les frais de transaction sont élévés. Les valeurs valides par ordre de priorité (de la plus basse à la plus haute) sont : unimportant, normal, elevated, priority. Si elle est omise, la valeur par défaut (voir la commande "set priority") est utilisée. <taille_cercle> est le nombre d'entrées à inclure pour l'intraçabilité. De multiples paiements peuvent être réalisés d'un coup en ajoutant <URI_2> ou <adresse_2> <montant_2> et cetera (avant l'ID de paiement, si il est inclus) - - - - locked_transfer [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] (<URI> | <addr> <amount>) <lockblocks> [<payment_id>] - locked_transfer [index=<N1>[,<N2>,...]] [<priorité>] [<taille_cercle>] (<URI> | <adresse> <montant>) <blocs_verrou> [<ID_paiement>] - - - - Transfer <amount> to <address> and lock it for <lockblocks> (max. 1000000). If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) - Transférer <montant> à <adresse> et le verrouiller pendant <blocs_verrou> (max 1000000). Si le paramètre "index=<N1>[,<N2>,...]" est spécifié, le portefeuille utilise les sorties reçues par les adresses de ces indices. Si il est omis, le portefeuille choisit les indices d'adresse à utiliser aléatoirement. Dans tous les cas, il essaye de ne pas combiner des sorties de multiples adresses. <priorité> est la priorité de la transaction. Plus la priorité est haute, plus les frais de transaction sont élévés. Les valeurs valides par ordre de priorité (de la plus basse à la plus haute) sont : unimportant, normal, elevated, priority. Si elle est omise, la valeur par défaut (voir la commande "set priority") est utilisée. <taille_cercle> est le nombre d'entrées à inclure pour l'intraçabilité. De multiples paiements peuvent être réalisés d'un coup en ajoutant <URI_2> ou <adresse_2> <montant_2> et cetera (avant l'ID de paiement, si il est inclus) - - - - locked_sweep_all [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> <lockblocks> [<payment_id>] - locked_sweep_all [index=<N1>[,<N2>,...]] [<priorité>] [<taille_cercle>] <adresse> <blocs_verrou> [<ID_paiement>] - - - - Send all unlocked balance to an address and lock it for <lockblocks> (max. 1000000). If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. <priority> is the priority of the sweep. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. - Transférer tout le solde débloqué à une adresse et le verrouiller pendant <blocs_verrou> (max 1000000). Si le paramètre "index=<N1>[,<N2>,...]" est spécifié, le portefeuille utilise les sorties reçues par ces indices d'adresse. Si il est omis, le portefeuille choisit un index d'adresse à utiliser aléatoirement. <priorité> est la priorité du balayage. Plus la priorité est haute, plus les frais de transaction sont élévés. Les valeurs valides par ordre de priorité (de la plus basse à la plus haute) sont : unimportant, normal, elevated, priority. Si elle est omise, la valeur par défaut (voir la commande "set priority") est utilisée. <taille_cercle> est le nombre d'entrées à inclure pour l'intraçabilité. - - - - sweep_all [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] [outputs=<N>] <address> [<payment_id>] - sweep_all [index=<N1>[,<N2>,...]] [<priorité>] [<taille_cercle>] [outputs=<N>] <adresse> [<ID_paiement>] - - - - Send all unlocked balance to an address. If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. If the parameter "outputs=<N>" is specified and N > 0, wallet splits the transaction into N even outputs. - Envoyer tout le solde débloqué à une adresse. Si le paramètre "index<N1>[,<N2>,...]" est spécifié, le portefeuille balaye les sorties reçues par ces indices d'adresse. Si il est omis, le portefeuille choisit un index d'adresse à utiliser aléatoirement. Si le paramètre "outputs=<N>" est spécifié et N > 0, le portefeuille scinde la transaction en N sorties égales. - - - - sweep_single [<priority>] [<ring_size>] [outputs=<N>] <key_image> <address> [<payment_id>] - sweep_single [<priorité>] [<taille_cercle>] [outputs=<N>] <image_clé> <adresse> [<ID_paiement>] - - - - sign_transfer [export_raw] - sign_transfer [export_raw] - - - - Sign a transaction from a file. If the parameter "export_raw" is specified, transaction raw hex data suitable for the daemon RPC /sendrawtransaction is exported. - Signer une transaction à partir d'un fichier. Si le paramètre "export_raw" est spécifié, les données brutes hexadécimales adaptées au RPC /sendrawtransaction du démon sont exportées. - - - - 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. - Si aucun argument n'est spécifié ou si <index> est spécifié, le portefeuille affiche l'adresse par défaut ou l'adresse spécifiée. Si "all" est spécifié, le portefeuille affiche toutes les adresses existantes dans le comptes actuellement sélectionné. Si "new" est spécifié, le portefeuille crée une nouvelle adresse avec le texte d'étiquette fourni (qui peut être vide). Si "label" est spécifié, le portefeuille affecte le texte fourni à l'étiquette de l'adresse spécifiée par <index>. - - - + Available options: seed language Set the wallet's seed language. @@ -2872,7 +920,7 @@ Attention : Certaines clés d'entrées étant dépensées sont issues store-tx-info <1|0> Whether to store outgoing tx info (destination address, payment ID, tx secret key) for future reference. default-ring-size <n> - Set the default ring size (default and minimum is 5). + Set the default ring size (obsolete). auto-refresh <1|0> Whether to automatically synchronize new blocks from the daemon. refresh-type <full|optimize-coinbase|no-coinbase|default> @@ -2906,87 +954,2466 @@ subaddress-lookahead <major>:<minor> Set this if you are not sure whether you will spend on a key reusing Monero fork later. segregation-height <n> Set to the height of a key reusing fork you want to use, 0 to use default. - Options disponibles : - seed langue - Définir la langue de la phrase mnémonique. - always-confirm-transfers <1|0> - Confirmation des transactions non scindées. - print-ring-members <1|0> - Affichage d'informations détaillées sur les membres du cercle lors de la confirmation. - store-tx-info <1|0> - Sauvegarde des informations des transactions sortantes (adresse de destination, ID de paiement, clé secrète de transaction) pour référence ultérieure. - default-ring-size <n> - Définir la taille de cercle par défaut (la valeur par défaut est le minimum 5). - auto-refresh <1|0> - Synchronisation automatique des nouveaux blocs du démon. - refresh-type <full|optimize-coinbase|no-coinbase|default> - Définir le comportement du rafraîchissement du portefeuille. - priority [0|1|2|3|4] - Utiliser les frais pour la priorité par défaut/peu importante/normale/élevée/prioritaire. - confirm-missing-payment-id <1|0> - ask-password <0|1|2 (ou never|action|decrypt)> - unit <monero|millinero|micronero|nanonero|piconero> - Définir la (sous-)unité monero par défaut. - min-outputs-count [n] - Essayer de garder au moins ce nombre de sorties d'une valeur d'au moins min-outputs-value. - min-outputs-value [n] - Essayer de garder au moins min-outputs-count sorties d'au moins cette valeur. - merge-destinations <1|0> - Fusion des paiements multiples vers la même adresse de destination. - confirm-backlog <1|0> - Avertir s'il y a un arriéré de transactions. - confirm-backlog-threshold [n] - Définir un seuil pour confirm-backlog pour avertir seulement si l'arriéré de transactions est supérieur à n blocs. - refresh-from-block-height [n] - Définir la hauteur avant laquelle les blocs sont ignorés. - auto-low-priority <1|0> - Utilisation automatique du niveau de frais pour la priorité basse, lorsqu'il est sûr de le faire. - segregate-pre-fork-outputs <1|0> - Activez ceci si vous prévoyez de dépenser des sorties à la fois avec Monero ET un fork réutilisant les clés. - key-reuse-mitigation2 <1|0> - Activez ceci si vous n'êtes pas sûr de ne jamais utiliser un fork réutilisant les clés. - subaddress-lookahead <majeur>:<mineur> - Définir les nombres de sous-adresse à inclure par anticipation dans la table de hachage des sous-adresses. - segregation-height <n> - Définir la hauteur d'un fork réutilisant les clés que vous voulez utiliser, 0 par défaut. + - - set_tx_key <txid> <tx_key> - set_tx_key <ID_transaction> <clé_transaction> + + Show the incoming/outgoing transfers within an optional height range. + +Output format: +In or Coinbase: Block Number, "block"|"in", Time, Amount, Transaction Hash, Payment ID, Subaddress Index, "-", Note +Out: Block Number, "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Destinations, Input addresses**, "-", Note +Pool: "pool", "in", Time, Amount, Transaction Hash, Payment Id, Subaddress Index, "-", Note, Double Spend Note +Pending or Failed: "failed"|"pending", "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Input addresses**, "-", Note + +* Excluding change and fee. +** Set of address indices used as inputs in this transfer. + + + + + export_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] [output=<filepath>] + + + + + Export to CSV the incoming/outgoing transfers within an optional height range. + + + + + Export a signed set of key images to a <filename>. + + + + + Synchronizes key images with the hw wallet. + + + + + Performs extra multisig keys exchange rounds. Needed for arbitrary M/N multisig wallets + + + + + Interface with the MMS (Multisig Messaging System) +<subcommand> is one of: + init, info, signer, list, next, sync, transfer, delete, send, receive, export, note, show, set, help + send_signer_config, start_auto_config, stop_auto_config, auto_config +Get help about a subcommand with: help mms <subcommand>, or mms help <subcommand> + + + + + Initialize and configure the MMS for M/N = number of required signers/number of authorized signers multisig + + + + + Display current MMS configuration + + + + + Set or modify authorized signer info (single-word label, transport address, Monero address), or list all signers + + + + + List all messages + + + + + Evaluate the next possible multisig-related action(s) according to wallet state, and execute or offer for choice +By using 'sync' processing of waiting messages with multisig sync info can be forced regardless of wallet state + + + + + Force generation of multisig sync info regardless of wallet state, to recover from special situations like "stale data" errors + + + + + Initiate transfer with MMS support; arguments identical to normal 'transfer' command arguments, for info see there + + + + + Delete a single message by giving its id, or delete all messages by using 'all' + + + + + Send a single message by giving its id, or send all waiting messages + + + + + Check right away for new messages to receive + + + + + Write the content of a message to a file "mms_message_content" + + + + + Send a one-line message to an authorized signer, identified by its label, or show any waiting unread notes + + + + + Show detailed info about a single message + + + + + Available options: + auto-send <1|0> + Whether to automatically send newly generated messages right away. + + + + + + Send completed signer config to all other authorized signers + + + + + Start auto-config at the auto-config manager's wallet by issuing auto-config tokens and optionally set others' labels + + + + + Delete any auto-config tokens and abort a auto-config process + + + + + Start auto-config by using the token received from the auto-config manager + + + + + Mark output(s) as spent so they never get selected as fake outputs in a ring + + + + + Marks an output as unspent so it may get selected as a fake output in a ring + + + + + Checks whether an output is marked as spent + + + + + <device_name[:device_spec]> + + + + + wrong number range, use: %s + + + + + NOTE: the following %s can be used to recover access to your wallet. Write them down and store them somewhere safe and secure. Please do not store them in your email or on file storage services outside of your immediate control. + + + + + + string + + + + + 25 words + + + + + Device requires attention + + + + + Enter device PIN + + + + + Failed to read device PIN + + + + + Please enter the device passphrase on the device + + + + + Enter device passphrase + + + + + Failed to read device passphrase + + + + + The first refresh has finished for the HW-based wallet with received money. hw_key_images_sync is needed. + + + + + Do you want to do it now? (Y/Yes/N/No): + + + + + hw_key_images_sync skipped. Run command manually before a transfer. + + + + + Invalid keyword: + + + + + Heights: + + + + + + Locked blocks too high, max 1000000 (˜4 yrs) + + + + + + + + + + + + transaction cancelled. + transaction annulée. + + + + + Is this okay anyway? (Y/Yes/N/No): + Est-ce correct quand même ? (Y/Yes/Oui/N/No/Non) : + + + + There is currently a %u block backlog at that fee level. Is this okay? (Y/Yes/N/No): + Il y a actuellement un arriéré de %u blocs à ce niveau de frais. Est-ce correct quand même ? (Y/Yes/Oui/N/No/Non) : + + + + Failed to check for backlog: + Échec de la vérification du backlog : + + + + + +Transaction + +Transaction + + + + + Spending from address index %d + + Dépense depuis l'adresse d'index %d + + + + + + WARNING: Outputs of multiple addresses are being used together, which might potentially compromise your privacy. + + ATTENTION : Des sorties de multiples adresses sont utilisées ensemble, ce qui pourrait potentiellement compromettre votre confidentialité. + + + + + Sending %s. + Envoi de %s. + + + + Your transaction needs to be split into %llu transactions. This will result in a transaction fee being applied to each transaction, for a total fee of %s + Votre transaction doit être scindée en %llu transactions. Il en résulte que des frais de transaction doivent être appliqués à chaque transaction, pour un total de %s + + + + The transaction fee is %s + Les frais de transaction sont de %s + + + + , of which %s is dust from change + , dont %s est de la poussière de monnaie rendue + + + + . + . + + + + A total of %s from dust change will be sent to dust address + Un total de %s de poussière de monnaie rendue sera envoyé à une adresse de poussière + + + + . +This transaction will unlock on block %llu, in approximately %s days (assuming 2 minutes per block) + . +Cette transaction sera déverrouillée au bloc %llu, dans approximativement %s jours (en supposant 2 minutes par bloc) + + + + Unsigned transaction(s) successfully written to MMS + + + + + + + + + + + + Failed to write transaction(s) to file + Échec de l'écriture de(s) transaction(s) dans le fichier + + + + + + + + + + + Unsigned transaction(s) successfully written to file: + Transaction(s) non signée(s) écrite(s) dans le fichier avec succès : + + + + + Failed to cold sign transaction with HW wallet + + + + + No unmixable outputs found + Aucune sortie non mélangeable trouvée + + + + No address given + Aucune adresse fournie + + + + failed to parse Payment ID + échec de l'analyse de l'ID de paiement + + + + failed to parse key image + échec de l'analyse de l'image de clé + + + + No outputs found + Pas de sorties trouvées + + + + Multiple transactions are created, which is not supposed to happen + De multiples transactions sont crées, ce qui n'est pas supposé arriver + + + + The transaction uses multiple or no inputs, which is not supposed to happen + La transaction utilise aucune ou de multiples entrées, ce qui n'est pas supposé arriver + + + + missing threshold amount + montant seuil manquant + + + + invalid amount threshold + montant seuil invalide + + + + (Y/Yes/N/No): + + + + + Choose processing: + + + + + Sign tx + + + + + Send the tx for submission to + + + + + Send the tx for signing to + + + + + Submit tx + + + + + unknown + + + + + Choice: + + + + + Wrong choice + + + + + Id + + + + + I/O + + + + + Authorized Signer + + + + + Message Type + + + + + Height + + + + + R + + + + + Message State + + + + + Since + + + + + ago + + + + + # + + + + + Transport Address + + + + + Auto-Config Token + + + + + Monero Address + + + + + + + <not set> + + + + + Message + + + + + In/out: + + + + + State: + + + + + %s since %s, %s ago + + + + + Sent: Never + + + + + Sent: %s, %s ago + + + + + Authorized signer: + + + + + Content size: + + + + + bytes + + + + + Content: + + + + + (binary data) + + + + + Send these messages now? + + + + + Queued for sending. + + + + + Invalid message id + + + + + usage: mms init <required_signers>/<authorized_signers> <own_label> <own_transport_address> + + + + + The MMS is already initialized. Re-initialize by deleting all signer info and messages? + + + + + Error in the number of required signers and/or authorized signers + + + + + The MMS is not active. + + + + + Invalid signer number + + + + + mms signer [<number> <label> [<transport_address> [<monero_address>]]] + + + + + Invalid Monero address + + + + + Wallet state does not allow changing Monero addresses anymore + + + + + Usage: mms list + + + + + Usage: mms next [sync] + + + + + No next step: + + + + + prepare_multisig + + + + + make_multisig + + + + + exchange_multisig_keys + + + + + + export_multisig_info + + + + + import_multisig_info + + + + + sign_multisig + + + + + submit_multisig + + + + + Send tx + + + + + Process signer config + + + + + Replace current signer config with the one displayed above? + + + + + Process auto config data + + + + + Nothing ready to process + + + + + Usage: mms sync + + + + + Usage: mms delete (<message_id> | all) + + + + + Delete all messages? + + + + + Usage: mms send [<message_id>] + + + + + Usage: mms receive + + + + + Usage: mms export <message_id> + + + + + Message content saved to: + + + + + Failed to to save message content + + + + + Usage: mms note [<label> <text>] + + + + + No signer found with label + + + + + Usage: mms show <message_id> + + + + + Usage: mms set <option_name> [<option_value>] + + + + + Wrong option value + + + + + Auto-send is on + + + + + Auto-send is off + + + + + Unknown option + + + + + Usage: mms help [<subcommand>] + + + + + Usage: mms send_signer_config + + + + + Signer config not yet complete + + + + + Usage: mms start_auto_config [<label> <label> ...] + + + + + There are signers without a label set. Complete labels before auto-config or specify them as parameters here. + + + + + Auto-config is already running. Cancel and restart? + + + + + Usage: mms stop_auto_config + + + + + Delete any auto-config tokens and stop auto-config? + + + + + Usage: mms auto_config <auto_config_token> + + + + + Invalid auto-config token + + + + + Auto-config already running. Cancel and restart? + + + + + The MMS is not active. Activate using the "mms init" command + + + + + Invalid MMS subcommand + + + + + + Error in MMS command: + + + + + Claimed change does not go to a paid address + La monnaie réclamée ne va pas à une adresse payée + + + + Claimed change is larger than payment to the change address + La monnaie réclamée est supérieure au paiement à l'adresse de monnaie + + + + sending %s to %s + envoi de %s à %s + + + + dummy output(s) + sortie(s) factice(s) + + + + with no destinations + sans destination + + + + Loaded %lu transactions, for %s, fee %s, %s, %s, with min ring size %lu, %s. %sIs this okay? (Y/Yes/N/No): + %lu transactions chargées, pour %s, frais %s, %s, %s, taille de cercle minimum %lu, %s. %sEst-ce correct ? (Y/Yes/Oui/N/No/Non) : + + + + This is a multisig wallet, it can only sign with sign_multisig + Ceci est un portefeuille multisig, il ne peut signer qu'avec sign_multisig + + + + Failed to sign transaction + Échec de signature de transaction + + + + Failed to sign transaction: + Échec de signature de transaction : + + + + Transaction raw hex data exported to + Données brutes hex de la transaction exportées vers + + + + Failed to load transaction from file + Échec du chargement de la transaction du fichier + + + + + RPC error: + Erreur RPC : + + + + wallet is watch-only and has no spend key + c'est un portefeuille d'audit et il n'a pas de clé de dépense + + + + + + + Your original password was incorrect. + Votre mot de passe original est incorrect. + + + + Error with wallet rewrite: + Erreur avec la réécriture du portefeuille : + + + + invalid unit + unité invalide + + + + + invalid count: must be an unsigned integer + nombre invalide : un entier non signé est attendu + + + + invalid value + valeur invalide + + + + (Y/Yes/N/No): + (Y/Yes/Oui/N/No/Non) : + + + + + bad m_restore_height parameter: + mauvais paramètre m_restore_height : + + + + date format must be YYYY-MM-DD + le format de date doit être AAAA-MM-JJ + + + + Restore height is: + La hauteur de restauration est : + + + + + + Is this okay? (Y/Yes/N/No): + Est-ce correct ? (Y/Yes/Oui/N/No/Non) : + + + + Daemon is local, assuming trusted + Le démon est local, supposons qu'il est de confiance + + + + Password for new watch-only wallet + Mot de passe pour le nouveau portefeuille d'audit + + + + internal error: + erreur interne : + + + + + + unexpected error: + erreur inattendue : + + + + + + + + + + + + + + unknown error + erreur inconnue + + + + refresh failed: + échec du rafraîchissement : + + + + Blocks received: + Blocs reçus : + + + + unlocked balance: + solde débloqué : + + + + + + + amount + montant + + + + false + faux + + + + Unknown command: + Commande inconnue : + + + + Command usage: + Usage de la commande : + + + + Command description: + Description de la commande : + + + + wallet is multisig but not yet finalized + le portefeuille est multisig mais pas encore finalisé + + + + Failed to retrieve seed + Échec de la récupération de la phrase mnémonique + + + + wallet is multisig and has no seed + le portefeuille est multisig et n'a pas de phrase mnémonique + + + + Error: failed to estimate backlog array size: + Erreur : échec de l'estimation de la taille du tableau d'arriéré : + + + + Error: bad estimated backlog array size + Erreur : mauvaise estimation de la taille du tableau d'arriéré + + + + (current) + (actuel) + + + + %u block (%u minutes) backlog at priority %u%s + arriéré de %u bloc(s) (%u minutes) à la priorité %u%s + + + + %u to %u block (%u to %u minutes) backlog at priority %u + arriéré de %u à %u bloc(s) (%u à %u minutes) à la priorité %u + + + + No backlog at priority + Pas d'arriéré à la priorité + + + + + This wallet is already multisig + Le portefeuille est déjà multisig + + + + + wallet is watch-only and cannot be made multisig + c'est un portefeuille d'audit et il ne peut pas être tranformé en multisig + + + + + This wallet has been used before, please use a new wallet to create a multisig wallet + Ce portefeuille a été utilisé auparavant, veuillez utiliser un nouveau portefeuille pour créer un portefeuille multisig + + + + Send this multisig info to all other participants, then use make_multisig <threshold> <info1> [<info2>...] with others' multisig info + Envoyez ces infos multisig à tous les autres participants, ensuite utilisez make_multisig <seuil> <info1> [<info2>...] avec les infos multisig des autres + + + + This includes the PRIVATE view key, so needs to be disclosed only to that multisig wallet's participants + Ceci inclut la clé PRIVÉE d'audit, donc ne doit être divulgué qu'aux participants de ce portefeuille multisig + + + + Invalid threshold + Seuil invalide + + + + + Another step is needed + Une autre étape est nécessaire + + + + Error creating multisig: + Erreur de création multisig : + + + + Error creating multisig: new wallet is not multisig + Erreur de création multisig : le nouveau portefeuille n'est pas multisig + + + + multisig address: + adresse multisig : + + + + + + + This wallet is not multisig + Ce portefeuille n'est pas multisig + + + + + This wallet is already finalized + Ce portefeuille est déjà finalisé + + + + Failed to finalize multisig + Échec de finalisation multisig + + + + Failed to finalize multisig: + Échec de finalisation multisig : + + + + + + + + This multisig wallet is not yet finalized + Ce portefeuille multisig n'est pas encore finalisé + + + + Error exporting multisig info: + Erreur d'importation des infos multisig : + + + + Multisig info exported to + Infos multisig exportées vers + + + + Multisig info imported + Infos multisig importées + + + + Failed to import multisig info: + Échec de l'importation des infos multisig : + + + + Failed to update spent status after importing multisig info: + Échec de la mise à jour de l'état des dépenses après l'importation des infos multisig : + + + + Untrusted daemon, spent status may be incorrect. Use a trusted daemon and run "rescan_spent" + Pas un démon de confiance, l'état des dépenses peut être incorrect. Utilisez un démon de confiance et executez "rescan_spent" + + + + + + This is not a multisig wallet + Ceci n'est pas un portefeuille multisig + + + + + Failed to sign multisig transaction + Échec de la signature de la transaction multisig + + + + Multisig error: + Erreur multisig : + + + + Failed to sign multisig transaction: + Échec de la signature de la transaction multisig : + + + + It may be relayed to the network with submit_multisig + Elle peut être transmise au réseau avec submit_multisig + + + + + Failed to load multisig transaction from file + Échec du chargement de la transaction multisig du fichier + + + + + Multisig transaction signed by only %u signers, needs %u more signatures + Transaction multisig signée par %u signataire(s) seulement, nécessite %u signature(s) de plus + + + + + Transaction successfully submitted, transaction + Transaction transmise avec succès, transaction + + + + + You can check its status by using the `show_transfers` command. + Vous pouvez vérifier son statut en utilisant la commane 'show_transfers'. + + + + Failed to export multisig transaction to file + Échec de l'exportation de la transaction multisig vers le fichier + + + + Saved exported multisig transaction file(s): + Transaction multisig enregistrée dans le(s) fichier(s) : + + + + + + ring size must be an integer >= + la taille de cercle doit être un nombre entier >= + + + + could not change default ring size + échec du changement de la taille de cercle par défaut + + Invalid height + Hauteur invalide + + + + Start mining in the daemon (bg_mining and ignore_battery are optional booleans). + Démarrer la mine dans le démon (mine_arrière_plan et ignorer_batterie sont des booléens facultatifs). + + + + Stop mining in the daemon. + Arrêter la mine dans le démon. + + + + Set another daemon to connect to. + Spécifier un autre démon auquel se connecter. + + + + Save the current blockchain data. + Sauvegarder les données actuelles de la châine de blocs. + + + + Synchronize the transactions and balance. + Synchroniser les transactions et le solde. + + + + Show the wallet's balance of the currently selected account. + Afficher le solde du compte actuellement sélectionné. + + + + Show the payments for the given payment IDs. + Afficher les paiements pour les IDs de paiement donnés. + + + + Show the blockchain height. + Afficher la hauteur de la chaîne de blocs. + + + + Send all unmixable outputs to yourself with ring_size 1 + Envoyer toutes les sorties non mélangeables à vous-même avec une taille de cercle de 1 + + + + Send all unlocked outputs below the threshold to an address. + Envoyer toutes les sorties débloquées d'un montant inférieur au seuil à une adresse. + + + + Send a single output of the given key image to an address without change. + Envoyer une unique sortie ayant une image de clé donnée à une adresse sans rendu de monnaie. + + + + Donate <amount> to the development team (donate.getmonero.org). + Donner <montant> à l'équipe de développement (donate.getmonero.org). + + + + Submit a signed transaction from a file. + Transmettre une transaction signée d'un fichier. + + + + Change the current log detail (level must be <0-4>). + Changer le niveau de détail du journal (le niveau doit être <0-4>). + + + + If no arguments are specified, the wallet shows all the existing accounts along with their balances. +If the "new" argument is specified, the wallet creates a new account with its label initialized by the provided label text (which can be empty). +If the "switch" argument is specified, the wallet switches to the account specified by <index>. +If the "label" argument is specified, the wallet sets the label of the account specified by <index> to the provided label text. +If the "tag" argument is specified, a tag <tag_name> is assigned to the specified accounts <account_index_1>, <account_index_2>, .... +If the "untag" argument is specified, the tags assigned to the specified accounts <account_index_1>, <account_index_2> ..., are removed. +If the "tag_description" argument is specified, the tag <tag_name> is assigned an arbitrary text <description>. + Si aucun argument n'est spécifié, le portefeuille affiche tous les comptes existants ainsi que leurs soldes. +Si l'argument "new" est spécifié, le portefeuille crée un nouveau compte avec son étiquette initialisée par le texte fourni (qui peut être vide). +Si l'argument "switch" est spécifié, le portefeuille passe au compte spécifié par <index>. +Si l'argument "label" est spécifié, le portefeuille affecte le texte fourni à l'étiquette du compte spécifié par <index>. +Si l'argument "tag" est spécifié, un mot clé <mot_clé> est assigné aux comptes spécifiés <account_index_1>, <account_index_2>, .... +Si l'argument "untag" est spécifié, les mots clés assignés aux comptes spécifiés <account_index_1>, <account_index_2> ..., sont supprimés. +Si l'argument "tag_description" est spécifié, le texte arbitraire <description> est assigné au mot clé <mot_clé>. + + + + 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 + Encoder un ID de paiement dans une adresse intégrée pour l'adresse publique du portefeuille actuel (en l'absence d'argument un ID de paiement aléatoire est utilisé), ou décoder une adresse intégrée en une adresse standard et un ID de paiement + + + + Print all entries in the address book, optionally adding/deleting an entry to/from it. + Afficher toutes les entrées du carnet d'adresses, optionnellement en y ajoutant/supprimant une entrée. + + + + Save the wallet data. + Sauvegarder les données du portefeuille. + + + + Save a watch-only keys file. + Sauvegarder un fichier de clés d'audit. + + + + Display the private view key. + Afficher la clé privée d'audit. + + + + Display the private spend key. + Afficher la clé privée de dépense. + + + + Display the Electrum-style mnemonic seed + Afficher la phrase mnémonique de style Electrum + + + + Display the encrypted Electrum-style mnemonic seed. + Afficher la phrase mnémonique de style Electrum chiffrée. + + + + Rescan the blockchain for spent outputs. + Rescanner la chaîne de blocs pour trouver les sorties dépensées. + + + + Get the transaction key (r) for a given <txid>. + Obtenir la clé de transaction (r) pour un <ID_transaction> donné. + + + + Check the amount going to <address> in <txid>. + Vérifier le montant allant à <adresse> dans <ID_transaction>. + + + + Generate a signature proving funds sent to <address> in <txid>, optionally with a challenge string <message>, using either the transaction secret key (when <address> is not your wallet's address) or the view secret key (otherwise), which does not disclose the secret key. + Générer une signature prouvant l'envoi de fonds à <adresse> dans <ID_transaction>, optionnellement avec un <message> comme challenge, en utilisant soit la clé secrète de transaction (quand <adresse> n'est pas l'adresse de votre portefeuille) soit la clé secrète d'audit (dans le cas contraire), tout en ne divulgant pas la clé secrète. + + + + Check the proof for funds going to <address> in <txid> with the challenge string <message> if any. + Vérifier la validité de la preuve de fonds allant à <adresse> dans <ID_transaction> avec le <message> de challenge s'il y en a un. + + + + Generate a signature proving that you generated <txid> using the spend secret key, optionally with a challenge string <message>. + Générer une signature prouvant que vous avez créé <ID_transaction> en utilisant la clé secrète de dépense, optionnellement avec un <message> comme challenge. + + + + Check a signature proving that the signer generated <txid>, optionally with a challenge string <message>. + Vérifier la validité de la preuve que le signataire a créé <ID_transaction>, optionnellement avec un <message> comme challenge. + + + + Generate a signature proving that you own at least this much, optionally with a challenge string <message>. +If 'all' is specified, you prove the entire sum of all of your existing accounts' balances. +Otherwise, you prove the reserve of the smallest possible amount above <amount> available in your current account. + Générer une signature prouvant que vous possédez au moins ce montant, optionnellement avec un <message> comme challenge. +Si 'all' est spécifié, vous prouvez la somme totale des soldes de tous vos comptes existants. +Sinon, vous prouvez le plus petit solde supérieur à <montant> dans votre compte actuel. + + + + Check a signature proving that the owner of <address> holds at least this much, optionally with a challenge string <message>. + Vérifier la validité d'une signature prouvant que le propriétaire d'une <adresse> détient au moins un montant, optionnellement avec un <message> comme challenge. + + + + Show the unspent outputs of a specified address within an optional amount range. + Afficher les sorties non dépensées d'une adresse spécifique dans un interval de montants facultatif. + + + + Set an arbitrary string note for a <txid>. + Définir un texte arbitraire comme note pour <ID_transaction>. + + + + Get a string note for a txid. + Obtenir le texte de la note pour <ID_transaction>. + + + + Set an arbitrary description for the wallet. + Définir un texte arbitraire comme description du portefeuille. + + + + Get the description of the wallet. + Obtenir la description du portefeuille. + + + + Show the wallet's status. + Afficher l'état du portefeuille. + + + + Show the wallet's information. + Afficher les informations du portefeuille. + + + + Sign the contents of a file. + Signer le contenu d'un fichier. + + + + Verify a signature on the contents of a file. + Vérifier la signature du contenu d'un fichier. + + + + Import a signed key images list and verify their spent status. + Importer un ensemble signé d'images de clé et vérifier si elles correspondent à des dépenses. + + + + Export a set of outputs owned by this wallet. + Exporter un ensemble de sorties possédées par ce portefeuille. + + + + Import a set of outputs owned by this wallet. + Importer un ensemble de sorties possédées par ce portefeuille. + + + + Show information about a transfer to/from this address. + Afficher les information à propos d'un transfert vers/depuis cette adresse. + + + + Change the wallet's password. + Changer le mot de passe du portefeuille. + + + + Generate a new random full size payment id. These will be unencrypted on the blockchain, see integrated_address for encrypted short payment ids. + Générer un nouvel ID de paiement long aléatoire. Ceux-ci sont en clair dans la chaîne de blocs, voir integrated_address pour les IDs de paiement courts cryptés. + + + + Print the information about the current fee and transaction backlog. + Afficher les informations à propos des frais et arriéré de transactions actuels. + + + + Export data needed to create a multisig wallet + Exporter les données nécessaires pour créer un portefeuille multisig + + + + Turn this wallet into a multisig wallet + Transformer ce portefeuille en portefeuille multisig + + + + Turn this wallet into a multisig wallet, extra step for N-1/N wallets + Transformer ce portefeuille en portefeuille multisig, étape supplémentaire pour les portefeuilles N-1/N + + + + Export multisig info for other participants + Exporter les infos multisig pour les autres participants + + + + Import multisig info from other participants + Importer les infos multisig des autres participants + + + + Sign a multisig transaction from a file + Signer une transaction multisig d'un fichier + + + + Submit a signed multisig transaction from a file + Transmettre une transaction multisig signée d'un fichier + + + + Export a signed multisig transaction to a file + Exporter une transaction multisig signée vers un fichier + + + + Show the help section or the documentation about a <command>. + Afficher la section d'aide ou la documentation d'une <commande>. + + + + integer >= + entier >= + + + + block height + hauteur de bloc + + + + No wallet found with that name. Confirm creation of new wallet named: + Aucun portefeuille avec ce nom trouvé. Confirmer la création d'un nouveau portefeuille nommé : + + + + can't specify both --restore-deterministic-wallet or --restore-multisig-wallet and --non-deterministic + impossible de spécifier à la fois --restore-deterministic-wallet ou --restore-multisig-wallet et --non-deterministic + + + + --restore-multisig-wallet uses --generate-new-wallet, not --wallet-file + --restore-multisig-wallet utilise --generate-new-wallet, pas --wallet-file + + + + specify a recovery parameter with the --electrum-seed="multisig seed here" + spécifiez un paramètre de récupération avec --electrum-seed="phrase mnémonique multisig ici" + + + + Multisig seed failed verification + Échec de la vérification de la phrase mnémonique multisig + + + + + This address is a subaddress which cannot be used here. + Cette adresse est une sous-adresse qui ne peut pas être utilisée ici. + + + + Error: expected M/N, but got: + Erreur : M/N attendu, mais lu : + + + + Error: expected N > 1 and N <= M, but got: + Erreur : N > 1 et N <= M attendu, mais lu : + + + + Error: M/N is currently unsupported. + Erreur : M/N n'est actuellement pas supporté. + + + + Generating master wallet from %u of %u multisig wallet keys + Génération du portefeuille principal à partir de %u de %u clés de portefeuille multisig + + + + failed to parse secret view key + échec de l'analyse de la clé secrète d'audit + + + + failed to verify secret view key + échec de la vérification de la clé secrète d'audit + + + + Secret spend key (%u of %u): + Clé secrète de dépense (%u de %u) : + + + + Error: M/N is currently unsupported + Erreur : M/N n'est actuellement pas supporté + + + + Restore height + Hauteur de restauration + + + + Still apply restore height? (Y/Yes/N/No): + Appliquer la hauteur de restauration quand même ? (Y/Yes/Oui/N/No/Non) : + + + + Warning: using an untrusted daemon at %s, privacy will be lessened + Attention : en n'utilisant %s qui n'est pas un démon de confiance, la confidentialité sera réduite + + + + Daemon either is not started or wrong port was passed. Please make sure daemon is running or change the daemon address using the 'set_daemon' command. + Le démon n'est pas lancé ou un mauvais port a été fourni. Veuillez vous assurer que le démon fonctionne ou changez l'adresse de démon avec la commande 'set_daemon'. + + + + Your wallet has been generated! +To start synchronizing with the daemon, use the "refresh" command. +Use the "help" command to see the list of available commands. +Use "help <command>" to see a command's documentation. +Always use the "exit" command when closing monero-wallet-cli to save +your current session's state. Otherwise, you might need to synchronize +your wallet again (your wallet keys are NOT at risk in any case). + + Votre portefeuille a été généré ! +Pour commencer la synchronisation avec le démon, utilisez la commande "refresh". +Utilisez la commande "help" pour voir la liste des commandes disponibles. +Utilisez "help <commande>" pour voir la documentation d'une commande. +Utilisez toujours la commande "exit" pour fermer monero-wallet-cli pour sauvegarder +l'état de votre session. Sinon, vous pourriez avoir besoin de synchroniser +votre portefeuille à nouveau (mais les clés de votre portefeuille ne risquent rien). + + + + + failed to generate new mutlisig wallet + échec de la génération du nouveau portefeuille multisig + + + + Generated new %u/%u multisig wallet: + Nouveau portefeuille multisig %u/%u généré : + + + + Opened %u/%u multisig wallet%s + Portefeuille multisig %u/%u ouvert%s + + + + Use "help <command>" to see a command's documentation. + + Utilisez "help <commande>" pour voir la documentation d'une commande. + + + + + wallet is multisig and cannot save a watch-only version + c'est un portefeuille multisig et il ne peut pas sauvegarder une version d'audit + + + + Unexpected array length - Exited simple_wallet::set_daemon() + Taille de tableau inattendue - Sortie de simple_wallet::set_daemon() + + + + This does not seem to be a valid daemon URL. + Ceci semble ne pas être une URL de démon valide. + + + + + txid + ID transaction + + + + + idx + index + + + + (Some owned outputs have partial key images - import_multisig_info needed) + (Certaines sorties ont des images de clé partielles - import_multisig_info requis) + + + + Currently selected account: [ + Compte actuellement sélectionné : [ + + + + ] + ] + + + + Tag: + Mot clé : + + + + (No tag assigned) + (Pas de mot clé assigné) + + + + Balance per address: + Solde par adresse : + + + + Address + Adresse + + + + + Balance + Solde + + + + + Unlocked balance + Solde débloqué + + + + Outputs + Sorties + + + + + + Label + Étiquette + + + + %8u %6s %21s %21s %7u %21s + %8u %6s %21s %21s %7u %21s + + + + spent + dépensé + + + + global index + index global + + + + tx id + ID de transaction + + + + + addr index + index adresse + + + + No incoming transfers + Aucun transfert entrant + + + + No incoming available transfers + Aucun transfert entrant disponible + + + + No incoming unavailable transfers + Aucun transfert entrant non disponible + + + + payment + paiement + + + + transaction + transaction + + + + height + hauteur + + + + unlock time + durée de déverrouillage + + + + No payments with id + Aucun paiement avec l'ID + + + + + + + failed to get blockchain height: + échec de la récupération de la hauteur de la chaîne de blocs : + + + + +Transaction %llu/%llu: txid=%s + +Transaction %llu/%llu : ID=%s + + + + +Input %llu/%llu: amount=%s + +Entrée %llu/%llu : montant=%s + + + + failed to get output: + échec de la récupération de la sortie : + + + + output key's originating block height shouldn't be higher than the blockchain height + la hauteur du bloc d'origine de la clé de la sortie ne devrait pas être supérieure à celle de la chaîne de blocs + + + + +Originating block heights: + +Hauteurs des blocs d'origine : + + + + +| + +| + + + + + | + + | + + + + + +Warning: Some input keys being spent are from + +Attention : Certaines clés d'entrées étant dépensées sont issues de + + + + , which can break the anonymity of ring signature. Make sure this is intentional! + , ce qui peut casser l'anonymat du cercle de signature. Assurez-vous que c'est intentionnel ! + + + + + + Ring size must not be 0 + La taille de cercle ne doit pas être 0 + + + + + + ring size %u is too small, minimum is %u + la taille de cercle %u est trop petite, le minimum est %u + + + + wrong number of arguments + mauvais nombre d'arguments + + + + + + No payment id is included with this transaction. Is this okay? (Y/Yes/N/No): + Aucun ID de paiement n'est inclus dans cette transaction. Est-ce correct ? (Y/Yes/Oui/N/No/Non) : + + + + + No outputs found, or daemon is not ready + Aucune sortie trouvée, ou le démon n'est pas prêt + + + + Failed to parse donation address: + + + + + Donating %s %s to %s. + + + + + usage: export_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] [output=<path>] + + + + + direction + + + + + timestamp + + + + + running balance + + + + + hash + + + + + payment ID + + + + + fee + + + + + destination + + + + + index + + + + + note + + + + + CSV exported to + + + + + MMS received new message + + + + + + command only supported by HW wallet + commande supportée uniquement par un portefeuille matériel + + + + hw wallet does not support cold KI sync + + + + + Please confirm the key image sync on the device + + + + + Key images synchronized to height + + + + + Running untrusted daemon, cannot determine which transaction output is spent. Use a trusted daemon with --trusted-daemon and run rescan_spent + + + + + spent, + + + + + unspent + + + + + Failed to import key images + + + + + Failed to import key images: + Échec de l'importation des images de clé : + + + + Failed to reconnect device + Échec de la reconnexion à l'appareil + + + + Failed to reconnect device: + Échec de la reconnexion à l'appareil : + + + + Transaction successfully saved to + Transaction sauvegardée avec succès dans + + + + + , txid + , ID transaction + + + + Failed to save transaction to + Échec de la sauvegarde de la transaction dans + + + + + Sweeping %s in %llu transactions for a total fee of %s. Is this okay? (Y/Yes/N/No): + Balayage de %s dans %llu transactions pour des frais totaux de %s. Est-ce correct ? (Y/Yes/Oui/N/No/Non) : + + + + + + Sweeping %s for a total fee of %s. Is this okay? (Y/Yes/N/No): + Balayage de %s pour des frais totaux de %s. Est-ce correct ? (Y/Yes/Oui/N/No/Non) : + + + + This is a watch only wallet + Ceci est un portefeuille d'audit + + + + Double spend seen on the network: this transaction may or may not end up being mined + Double dépense détectée sur le réseau : cette transaction sera peut-être invalidée + + + + Transaction ID not found + ID de transaction non trouvé + + + + true + vrai + + + + failed to parse refresh type + échec de l'analyse du type de rafraîchissement + + + + + + + + + + + + + + + + + + + + + + + + + command not supported by HW wallet + commande non supportée par le portefeuille matériel + + + + + wallet is watch-only and has no seed + c'est un portefeuille d'audit et il n'a pas de phrase mnémonique + + + + + wallet is non-deterministic and has no seed + c'est un portefeuille non déterministe et il n'a pas de phrase mnémonique + + + + Enter optional seed offset passphrase, empty to see raw seed + Entrer une phrase de passe facultative pour le décalage de la phrase mnémonique, effacer pour voir la phrase mnémonique brute + + + + Incorrect password + Mot de passe invalide + + + + Current fee is %s %s per %s + Les frais sont actuellement de %s %s par %s + + + + + Invalid key image + Image de clé invalide + + + + Invalid txid + ID de transaction invalide + + + + Key image either not spent, or spent with mixin 0 + Image de clé soit non dépensée, soit dépensée avec 0 mélange + + + + Failed to get key image ring: + Échec de la récupération du cercle de l'image de clé : + + + + File doesn't exist + Le fichier d'existe pas + + + + Invalid ring specification: + Spécification de cercle invalide : + + + + Invalid key image: + Image de clé invalide : + + + + Invalid ring type, expected relative or abosolute: + Type de cercle invalide, "relative" ou "absolute" attendu : + + + + + Error reading line: + Erreur lors de la lecture de la ligne : + + + + Invalid ring: + Cercle invalide : + + + + Invalid relative ring: + Cercle relatif invalide : + + + + Invalid absolute ring: + Cercle absolu invalide : + + + + Failed to set ring for key image: + Échec de l'affectation du cercle pour l'image de clé : + + + + Continuing. + On continue. + + + + Missing absolute or relative keyword + Mot clé "absolute" ou "relative" manquant + + + + + invalid index: must be a strictly positive unsigned integer + index invalide : doit être un nombre entier strictement positif + + + + invalid index: indices wrap + index invalide : boucle des indices + + + + invalid index: indices should be in strictly ascending order + index invalide : les indices doivent être en ordre strictement croissant + + + + failed to set ring + échec de l'affectation du cercle + + + + First line is not an amount + La première ligne n'est pas un montant + + + + Invalid output: + Sortie invalide : + + + + Bad argument: + Mauvais argument : + + + + should be "add" + devrait être "add" + + + + Failed to open file + Échec de l'ouverture du fichier + + + + Invalid output key, and file doesn't exist + Clé de sortie invalide, et le fichier n'existe pas + + + + + Invalid output + Sortie invalide + + + + Failed to save known rings: + Échec de la sauvegarde des cercles connus : + + + + + wallet is watch-only and cannot transfer + c'est un portefeuille d'audit et il ne peut pas transférer + + + + + WARNING: this is a non default ring size, which may harm your privacy. Default is recommended. + ATTENTION : ceci c'est pas la taille de cercle par défaut, ce qui peut nuire à votre confidentialité. La valeur par défaut est recommandée. + + + + WARNING: from v8, ring size will be fixed and this setting will be ignored. + ATTENTION : ) partir de v8, la taille de cercle sera fixée et ce paramètre sera ignoré. + + + + + + priority must be either 0, 1, 2, 3, or 4, or one of: + la priorité doit être 0, 1, 2, 3, 4 ou l'une de : + + + + could not change default priority + échec du changement de la priorité par défaut + + + + invalid argument: must be either 0/never, 1/action, or 2/encrypt/decrypt + argument invalide : doit être soit 0/never, 1/action, ou 2/encrypt/decrypt + + + + Transfer <amount> to <address>. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) + Transférer <montant> à <adresse> Si le paramètre "index=<N1>[,<N2>,...]" est spécifié, le portefeuille utilise les sorties reçues par les adresses de ces indices. Si il est omis, le portefeuille choisit les indices d'adresse à utiliser aléatoirement. Dans tous les cas, il essaye de ne pas combiner des sorties de multiples adresses. <priorité> est la priorité de la transaction. Plus la priorité est haute, plus les frais de transaction sont élévés. Les valeurs valides par ordre de priorité (de la plus basse à la plus haute) sont : unimportant, normal, elevated, priority. Si elle est omise, la valeur par défaut (voir la commande "set priority") est utilisée. <taille_cercle> est le nombre d'entrées à inclure pour l'intraçabilité. De multiples paiements peuvent être réalisés d'un coup en ajoutant <URI_2> ou <adresse_2> <montant_2> et cetera (avant l'ID de paiement, si il est inclus) + + + + Transfer <amount> to <address> and lock it for <lockblocks> (max. 1000000). If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) + Transférer <montant> à <adresse> et le verrouiller pendant <blocs_verrou> (max 1000000). Si le paramètre "index=<N1>[,<N2>,...]" est spécifié, le portefeuille utilise les sorties reçues par les adresses de ces indices. Si il est omis, le portefeuille choisit les indices d'adresse à utiliser aléatoirement. Dans tous les cas, il essaye de ne pas combiner des sorties de multiples adresses. <priorité> est la priorité de la transaction. Plus la priorité est haute, plus les frais de transaction sont élévés. Les valeurs valides par ordre de priorité (de la plus basse à la plus haute) sont : unimportant, normal, elevated, priority. Si elle est omise, la valeur par défaut (voir la commande "set priority") est utilisée. <taille_cercle> est le nombre d'entrées à inclure pour l'intraçabilité. De multiples paiements peuvent être réalisés d'un coup en ajoutant <URI_2> ou <adresse_2> <montant_2> et cetera (avant l'ID de paiement, si il est inclus) + + + + Send all unlocked balance to an address and lock it for <lockblocks> (max. 1000000). If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. <priority> is the priority of the sweep. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. + Transférer tout le solde débloqué à une adresse et le verrouiller pendant <blocs_verrou> (max 1000000). Si le paramètre "index=<N1>[,<N2>,...]" est spécifié, le portefeuille utilise les sorties reçues par ces indices d'adresse. Si il est omis, le portefeuille choisit un index d'adresse à utiliser aléatoirement. <priorité> est la priorité du balayage. Plus la priorité est haute, plus les frais de transaction sont élévés. Les valeurs valides par ordre de priorité (de la plus basse à la plus haute) sont : unimportant, normal, elevated, priority. Si elle est omise, la valeur par défaut (voir la commande "set priority") est utilisée. <taille_cercle> est le nombre d'entrées à inclure pour l'intraçabilité. + + + + Send all unlocked balance to an address. If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. If the parameter "outputs=<N>" is specified and N > 0, wallet splits the transaction into N even outputs. + Envoyer tout le solde débloqué à une adresse. Si le paramètre "index<N1>[,<N2>,...]" est spécifié, le portefeuille balaye les sorties reçues par ces indices d'adresse. Si il est omis, le portefeuille choisit un index d'adresse à utiliser aléatoirement. Si le paramètre "outputs=<N>" est spécifié et N > 0, le portefeuille scinde la transaction en N sorties égales. + + + + Sign a transaction from a file. If the parameter "export_raw" is specified, transaction raw hex data suitable for the daemon RPC /sendrawtransaction is exported. + Signer une transaction à partir d'un fichier. Si le paramètre "export_raw" est spécifié, les données brutes hexadécimales adaptées au RPC /sendrawtransaction du démon sont exportées. + + + + 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. + Si aucun argument n'est spécifié ou si <index> est spécifié, le portefeuille affiche l'adresse par défaut ou l'adresse spécifiée. Si "all" est spécifié, le portefeuille affiche toutes les adresses existantes dans le comptes actuellement sélectionné. Si "new" est spécifié, le portefeuille crée une nouvelle adresse avec le texte d'étiquette fourni (qui peut être vide). Si "label" est spécifié, le portefeuille affecte le texte fourni à l'étiquette de l'adresse spécifiée par <index>. + + + Set the transaction key (r) for a given <txid> in case the tx was made by some other device or 3rd party wallet. Définir la clé de transaction (r) pour un <ID_transaction> donné au cas où cette clé ait été créée par un appareil ou portefeuille tiers. - - show_transfers [in|out|pending|failed|pool|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] - show_transfers [in|out|pending|failed|pool|coinbase] [index=<N1>[,<N2>,...]] [<hauteur_min> [<hauteur_max>]] - - - + Rescan the blockchain from scratch, losing any information which can not be recovered from the blockchain itself. Rescanner la chaîne de blocs à partir du début, en perdant toute information qui ne peut pas être retrouvée à partir de la chaîne elle même. - - hw_reconnect - hw_reconnect - - - + Attempts to reconnect HW wallet. Essayer de se reconnecter à un portefeuille matériel. - - print_ring <key_image> | <txid> - print_ring <image_clé> | <ID_transaction> - - - + Print the ring(s) used to spend a given key image or transaction (if the ring size is > 1) Output format: @@ -2994,1297 +3421,1076 @@ Key Image, "absolute", list of rings Afficher le(s) cercle(s) utilisé(s) pour dépenser une image de clé ou une transaction (si la taille de cercle est > 1) - - set_ring <filename> | ( <key_image> absolute|relative <index> [<index>...] ) - set_ring <nom_fichier> | ( <image_clé> absolute|relative <index> [<index>...] ) - - - + Set the ring used for a given key image, so it can be reused in a fork Définir le cercle utilisé pour une image de clé donnée, afin de pouvoir le réutiliser dans un fork - - save_known_rings - save_known_rings - - - + Save known rings to the shared rings database Sauvegarder les cercles connus dans la base de données des cercles partagés - - blackball <amount>/<offset> | <filename> [add] - blackball <montant>/<offset> | <nom_fichier> [add] - - - - Blackball output(s) so they never get selected as fake outputs in a ring - Blackbouler des sorties pour qu'elles ne soient jamais sélectionnées comme leurres dans un cercle - - - - unblackball <amount>/<offset> - unblackball <montant>/<offset> - - - - Unblackballs an output so it may get selected as a fake output in a ring - Déblackbouler une sortie pour qu'elle puisse être sélectionnée comme leurre dans un cercle - - - - blackballed <amount>/<offset> - blackballed <montant>/<offset> - - - - Checks whether an output is blackballed - Vérifier si une sortie est blackboulée - - - - version - version - - - + Returns version information Retourne les informations de version - + 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) full (le plus lent, aucune supposition); optimize-coinbase (rapide, suppose que la récompense de bloc est payée à une unique adresse); no-coinbase (le plus rapide, suppose que l'on ne reçoit aucune récompense de bloc), default (comme optimize-coinbase) - + 0, 1, 2, 3, or 4, or one of 0, 1, 2, 3, 4 ou l'une de - + 0|1|2 (or never|action|decrypt) 0|1|2 (ou never|action|decrypt) - + monero, millinero, micronero, nanonero, piconero monero, millinero, micronero, nanonero, piconero - + <major>:<minor> <majeur>:<mineur> - - wrong number range, use: set_log <log_level_number_0-4> | <categories> - nombre hors interval, utilisez : set_log <niveau_de_journalisation_0-4> | <catégories> - - - + Wallet name not valid. Please try again or use Ctrl-C to quit. Nom de portefeuille non valide. Veuillez réessayer ou utilisez Ctrl-C pour quitter. - + Wallet and key files found, loading... Fichier portefeuille et fichier de clés trouvés, chargement... - + Key file found but not wallet file. Regenerating... Fichier de clés trouvé mais pas le fichier portefeuille. Régénération... - + Key file not found. Failed to open wallet: - Fichier de clés non trouvé. Échec de l'ouverture du portefeuille : + Fichier de clés non trouvé. Échec de l'ouverture du portefeuille : - + Generating new wallet... Génération du nouveau portefeuille... - + Can't specify more than one of --testnet and --stagenet Impossible de spécifier plus d'une option parmis --testnet et --stagenet - + can't specify more than one of --generate-new-wallet="wallet_name", --wallet-file="wallet_name", --generate-from-view-key="wallet_name", --generate-from-spend-key="wallet_name", --generate-from-keys="wallet_name", --generate-from-multisig-keys="wallet_name", --generate-from-json="jsonfilename" and --generate-from-device="wallet_name" impossible de spécifier plus d'une option parmis --generate-new-wallet="nom_portefeuille", --wallet-file="nom_portefeuille", --generate-from-view-key="nom_portefeuille", --generate-from-spend-key="nom_portefeuille", --generate-from-keys="nom_portefeuille", --generate-from-multisig-keys="nom_portefeuille", --generate-from-json="nom_fichier_json" et --generate-from-device="nom_portefeuille" - + Electrum-style word list failed verification Échec de la vérification de la liste de mots de style Electrum - + Enter seed offset passphrase, empty if none Entrer une phrase de passe pour le décalage de la phrase mnémonique, vide si aucun - - - - - - - - - - + + + + + + + + + + No data supplied, cancelled Pas de données fournies, annulation - - - - - - - - - - - - + + + + + + + + + + + + failed to parse address échec de l'analyse de l'adresse - - + + failed to parse view key secret key échec de l'analyse de la clé secrète d'audit - - + + failed to verify view key secret key échec de la vérification de la clé secrète d'audit - - - + + + view key does not match standard address la clé d'audit ne correspond pas à l'adresse standard - - - - - - + + + + + + account creation failed échec de la création du compte - - - + + + failed to parse spend key secret key échec de l'analyse de la clé secrète de dépense - - + + failed to verify spend key secret key échec de la vérification de la clé secrète de dépense - - + + spend key does not match standard address la clé de dépense ne correspond pas à l'adresse standard - + No restore height is specified. Aucune hauteur de restauration n'est spécifiée. - + Assumed you are creating a new account, restore will be done from current estimated blockchain height. Nous supposons que vous créez un nouveau compte, la restauration sera faite à partir d'une hauteur de la chaîne de blocs estimée. - + Use --restore-height if you want to restore an already setup account from a specific height Utilisez --restore-height si vous voulez restaurer un compte existant à partir d'une hauteur spécifique - + account creation aborted création du compte annulée - + can't specify --subaddress-lookahead and --wallet-file at the same time Impossible de spécifier --subaddress-lookahead et --wallet-file en même temps - + failed to open account échec de l'ouverture du compte - - - - - + + + + + wallet is null portefeuille est nul - + Failed to initialize ring database: privacy enhancing features will be inactive Impossible d'initialiser la base de données des cercles : les fonctions d'amélioration de la confidentialité seront inactives - + If your display freezes, exit blind with ^C, then run again with --use-english-language-names Si votre affichage se bloque, quittez en aveugle avec ^C, puis lancer à nouveau en utilisant --use-english-language-names - - + + invalid language choice entered. Please try again. choix de langue passé invalide. Veuillez réessayer. - + View key: - Clé d'audit : + Clé d'audit : - + Generated new wallet on hw device: Nouveau portefeuille généré sur l'appareil : - + Key file not found. Failed to open wallet Fichier des clés non trouvé. Échec d'ouverture du portefeuille - + You may want to remove the file "%s" and try again Vous pourriez vouloir supprimer le fichier "%s" et réessayer - + failed to deinitialize wallet échec de la désinitialisation du portefeuille - + Watch only wallet saved as: Portefeuille d'audit sauvegardé vers : - + Failed to save watch only wallet: - Échec de la sauvegarde du portefeuille d'audit : + Échec de la sauvegarde du portefeuille d'audit : - - - + + + this command requires a trusted daemon. Enable with --trusted-daemon cette commande requiert un démon de confiance. Activer avec --trusted-daemon - - invalid arguments. Please use start_mining [<number_of_threads>] [do_bg_mining] [ignore_battery] - arguments invalides. Veuillez utiliser start_mining [<nombre_de_threads>] [do_bg_mining] [ignore_battery] - - - + Expected trusted or untrusted, got "trusted" ou "untrusted" attendu, mais lu - + trusted de confiance - + untrusted non fiable - + blockchain can't be saved: - la chaîne de blocs ne peut pas être sauvegardée : + la chaîne de blocs ne peut pas être sauvegardée : - + NOTE: this transaction uses an encrypted payment ID: consider using subaddresses instead NOTE: cette transaction utilise un ID de paiement chiffré: veuillez considérer l'utilisation de sous-adresses à la place - + WARNING: this transaction uses an unencrypted payment ID: consider using subaddresses instead ATTENTION: cette transaction utilise un ID de paiement non chiffré: veuillez considérer l'utilisation de sous-adresses à la place - + Password needed (%s) - use the refresh command Mot de passe requis (%s) - utilisez la commande refresh - + Enter password Entrez le mot de passe - - + + daemon is busy. Please try again later. le démon est occupé. Veuillez réessayer plus tard. - - + + no connection to daemon. Please make sure daemon is running. pas de connexion au démon. Veuillez vous assurer que le démon fonctionne. - + refresh error: - erreur du rafraîchissement : + erreur du rafraîchissement : - + (Some owned outputs have missing key images - import_key_images needed) (Il manque les images de clé de certaines sorties - import_key_images requis) - + Balance: - Solde : + Solde : - + pubkey clé publique - + key image image de clé - - + + + unlocked déverrouillé - + ringct ringct - + T V - + F F - + locked vérrouillé - + RingCT RingCT - + - - - + payment ID has invalid format, expected 16 or 64 character hex string: - format d'identifiant de paiement invalide, 16 ou 64 caractères hexadécimaux attendus : + format d'identifiant de paiement invalide, 16 ou 64 caractères hexadécimaux attendus : - + failed to get spent status échec de la récupération du statut de dépense - + failed to find construction data for tx input échec de la recherche des données pour contruire l'entrée de la transaction - + the same transaction la même transaction - + blocks that are temporally very close blocs très proches dans le temps - - - + + + ring size %u is too large, maximum is %u la taille de cercle %u est trop grande, le maximum est %u - - + + Unencrypted payment IDs are bad for privacy: ask the recipient to use subaddresses instead Les ID de paiment non chiffrés sont mauvais pour la confidentialité : demandez au bénéficiaire d'utiliser les sous-adresses à la place - + payment id failed to encode échec de l'encodage de l'ID de paiement - - - Locked blocks too high, max 1000000 (˜4 yrs) - Nombre de blocs verrou trop élévé, 1000000 max (˜4 ans) - - - + failed to parse short payment ID from URI échec de l'analyse de l'ID de paiement court à partir de l'URI - - + + Invalid last argument: Dernier argument invalide : - + a single transaction cannot use more than one payment id une unique transaction ne peut pas utiliser plus d'un ID de paiement - + failed to parse payment id, though it was detected échec de l'analyse de l'ID de paiement, bien qu'il ait été détecté - + Not enough money in unlocked balance Pas assez de fonds dans le solde débloqué - + Discarding %s of unmixable outputs that cannot be spent, which can be undone by "rescan_spent". Is this okay? (Y/Yes/N/No): On se débarrasse de %s de sorties non mélangeables qui ne peuvent pas être dépensées, ce qui peut être défait avec "rescan_spent". Est-ce d'accord ? (Y/Yes/N/No) : - - usage: %s [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] [outputs=<N>] <address> [<payment_id>] - usage: %s [index=<N1>[,<N2>,...]] [<priorité>] [<taille_cercle>] [outputs=<N>] <adresse> [<ID_paiement>] - - - + missing lockedblocks parameter paramètre blocs_verrou manquant - + bad locked_blocks parameter mauvais paramètre blocs_verrou - - + + Failed to parse number of outputs Échec de l'analyse du nombre de sorties - - + + Amount of outputs should be greater than 0 Le nombre de sorties doit être supérieur à 0 - - usage: sweep_single [<priority>] [<ring_size>] [outputs=<N>] <key_image> <address> [<payment_id>] - usage : sweep_single [<priorité>] [<taille_cercle>] [outputs=<N>] <image_clé> <adresse> [<ID_paiement>] - - - - donations are not enabled on the testnet or on the stagenet - les dons ne sont pas activés sur les réseaux testnet et stagenet - - - + Donating %s %s to The Monero Project (donate.getmonero.org or %s). Don de %s %s à The Monero Project (donate.getmonero.org ou %s). - - usage: sign_transfer [export_raw] - usage : sign_transfer [export_raw] - - - - usage: set_tx_key <txid> <tx_key> - usage : set_tx_key <ID_transaction> <clé_transaction> - - - - - + + + failed to parse tx_key échec de l'analyse de la clé de transaction - + Tx key successfully stored. Clé de transaction sauvegardée avec succès. - + Failed to store tx key: Échec de la sauvegarde de la clé de transaction : - - + + Good signature Bonne signature - - - + + + Bad signature Mauvaise signature - + usage: show_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] - usage : show_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<hauteur_min> [<hauteur_max>]] + usage : show_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<hauteur_min> [<hauteur_max>]] - + + block bloc - + Warning: this will lose any information which can not be recovered from the blockchain. Attention : ceci pedra toute information qui ne peut pas être retrouvée à partir de la chaîne de blocs. - + This includes destination addresses, tx secret keys, tx notes, etc Ceci inclut les adresses de destination, les clé secrètes de transaction, les notes de transaction, etc - + Rescan anyway ? (Y/Yes/N/No): Rescanner quand même ? (Y/Yes/N/No) : - - usage: integrated_address [payment ID] - usage : integrated_address [ID paiement] - - - + Standard address: - Adresse standard : + Adresse standard : - + failed to parse payment ID or address échec de l'analyse de l'ID de paiement ou de l'adresse - - usage: address_book [(add (<address> [pid <long or short payment id>])|<integrated address> [<description possibly with whitespaces>])|(delete <index>)] - usage : address_book [(add (<adresse> [pid <ID de paiement long ou court>])|<adresse integrée> [<description avec des espaces possible>])|(delete <index>)] - - - + failed to parse payment ID échec de l'analyse de l'ID de paiement - + failed to parse index échec de l'analyse de l'index - + Address book is empty. Le carnet d'adresses est vide. - + Index: - Index : + Index : - - + + Address: - Adresse : + Adresse : - + Payment ID: - ID de paiement : + ID de paiement : - - + + Description: - Description : + Description : - - usage: set_tx_note [txid] free text note - usage : set_tx_note [ID transaction] note de texte libre - - - - usage: get_tx_note [txid] - usage : get_tx_note [ID transaction] - - - + Network type: Type de réseau : - + Testnet Testnet - + Stagenet Stagenet - + Mainnet Mainnet - - usage: sign <filename> - usage : sign <fichier> - - - + wallet is watch-only and cannot sign c'est un portefeuille d'audit et il ne peut pas signer - - - - + + + + failed to read file échec de la lecture du fichier - - usage: check_tx_proof <txid> <address> <signature_file> [<message>] - usage : check_tx_proof <ID_transaction> <adresse> <fichier_signature> [<message>] - - - - - + + + failed to load signature file échec du chargement du fichier signature - - usage: get_spend_proof <txid> [<message>] - usage : get_spend_proof <ID_transaction> [<message>] - - - + wallet is watch-only and cannot generate the proof c'est un portefeuille d'audit et il ne peut générer de preuve - - usage: check_spend_proof <txid> <signature_file> [<message>] - usage : check_spend_proof <ID_transaction> <fichier_signature> [<message>] - - - - usage: get_reserve_proof (all|<amount>) [<message>] - usage : get_reserve_proof (all|<montant>) [<message>] - - - + The reserve proof can be generated only by a full wallet La preuve de réserve ne peut être généré que par un portefeuille complet - - usage: check_reserve_proof <address> <signature_file> [<message>] - usage : check_reserve_proof <adresse> <fichier_signature> [<message>] - - - + Address must not be a subaddress L'adresse ne doit pas être une sous-adresse - + Good signature -- total: %s, spent: %s, unspent: %s - Bonne signature -- total : %s, dépensé : %s, non dépensé : %s + Bonne signature -- total : %s, dépensé : %s, non dépensé : %s - + [Double spend seen on the network: this transaction may or may not end up being mined] - [Double dépense détectée sur le réseau : cette transaction sera peut-être invalidée] + [Double dépense détectée sur le réseau : cette transaction sera peut-être invalidée] - - usage: unspent_outputs [index=<N1>[,<N2>,...]] [<min_amount> [<max_amount>]] - usage : unspent_outputs [index=<N1>[,<N2>,...]] [<montant_min> [<montant_max>]] - - - + There is no unspent output in the specified address Il n'y a pas de sortie non dépensée pour l'adresse spécifiée - + (no daemon) (pas de démon) - + (out of sync) (désynchronisé) - + (Untitled account) (compte sans nom) - - - - - - + + + + + + failed to parse index: - échec de l'analyse de l'index : + échec de l'analyse de l'index : - - + + specify an index between 0 and specifiez un index entre 0 et - - usage: - account - account new <label text with white spaces allowed> - account switch <index> - account label <index> <label text with white spaces allowed> - account tag <tag_name> <account_index_1> [<account_index_2> ...] - account untag <account_index_1> [<account_index_2> ...] - account tag_description <tag_name> <description> - usage : - account - account new <texte étiquette avec espaces autorisés> - account switch <index> - account label <index> <texte étiquette avec espaces autorisés> - account tag <mot_clé> <index_compte_1> [<index_compte_2> ...] - account untag <index_compte_1> [<index_compte_2> ...] - account tag_description <mot_clé> <description> - - - + Grand total: Balance: -Somme finale : - Solde : +Somme finale : + Solde : - + , unlocked balance: - , solde débloqué : + , solde débloqué : - + Untagged accounts: - Comptes sans mot clé : + Comptes sans mot clé : - + Tag %s is unregistered. Le mot clé %s n'est pas enregistré. - + Accounts with tag: - Comptes avec mot clé : + Comptes avec mot clé : - + Tag's description: - Description du mot clé : + Description du mot clé : - + Account Compte - + %c%8u %6s %21s %21s %21s %c%8u %6s %21s %21s %21s - + ---------------------------------------------------------------------------------- ---------------------------------------------------------------------------------- - + %15s %21s %21s %15s %21s %21s - + Primary address Adresse primaire - + (used) (utilisé) - + (Untitled address) (adresse sans nom) - + <index_min> is already out of bound <index_min> est déjà hors limite - + <index_max> exceeds the bound <index_max> excède la limite - - usage: address [ new <label text with white spaces allowed> | all | <index_min> [<index_max>] | label <index> <label text with white spaces allowed> ] - usage : address [ new <texte étiquette avec espaces autorisés> | all | <index_min> [<index_max>] | label <index> <texte étiquette avec espaces autorisés>] - - - - + + Integrated addresses can only be created for account 0 Les adresses intégrées ne peuvent être créées que pour le compte 0 - + Integrated address: %s, payment ID: %s - Adresse intégrée : %s, ID de paiement : %s + Adresse intégrée : %s, ID de paiement : %s - + Subaddress: - Sous-adresse : + Sous-adresse : - - usage: get_description - usage : get_description - - - + no description found pas de description trouvée - + description found: - description trouvée : + description trouvée : - + Filename: - Fichier : + Fichier : - + Watch only Audit - + %u/%u multisig%s Multisig %u/%u%s - + Normal Normal - + + Type: - Type : + Type : - + This wallet is multisig and cannot sign C'est un portefeuille multisig et il ne peut pas signer - - usage: verify <filename> <address> <signature> - usage : verify <fichier> <adresse> <signature> - - - + Bad signature from Mauvaise signature de - + Good signature from Bonne signature de - - usage: export_key_images <filename> - usage : export_key_images <fichier> - - - + wallet is watch-only and cannot export key images c'est un portefeuille d'audit et il ne peut pas exporter les images de clé - - - + + + failed to save file échec de l'enregistrement du fichier - + Signed key images exported to Images de clé signées exportées vers - - usage: import_key_images <filename> - usage : import_key_images <fichier> - - - - usage: export_outputs <filename> - usage : export_outputs <fichier> - - - + Outputs exported to Sorties exportées vers - - usage: import_outputs <filename> - usage : import_outputs <fichier> - - - - - - + + + + + amount is wrong: - montant erroné : + montant erroné : - + + expected number from 0 to attend un nombre de 0 à - + Sweeping Balayage de - + Money successfully sent, transaction: - Fonds envoyés avec succès, transaction : + Fonds envoyés avec succès, transaction : - + Change goes to more than one address La monnaie rendue va à plus d'une adresse - + %s change to %s %s de monnaie rendue à %s - + no change sans monnaie rendue - - - + + + Transaction successfully signed to file Transaction signée avec succès dans le fichier - - usage: get_tx_key <txid> - usage : get_tx_key <ID transaction> - - - - - - - - - - - - + + + + + + + + + + failed to parse txid échec de l'analyse de l'ID de transaction - + Tx key: - Clé de transaction : + Clé de transaction : - + no tx keys found for this txid aucune clé de transaction trouvée pour cet ID de transaction - - usage: get_tx_proof <txid> <address> [<message>] - usage : get_tx_proof <ID_transaction> <adresse> [<message>] - - - - - + + + signature file saved to: - fichier signature sauvegardé dans : + fichier signature sauvegardé dans : - - - + + + failed to save signature file échec de la sauvegarde du fichier signature - - usage: check_tx_key <txid> <txkey> <address> - usage : check_tx_key <ID transaction> <clé transaction> <adresse> - - - - + + failed to parse tx key échec de l'analyse de la clé de transaction - - - + + + error: - erreur : + erreur : - - + + received a reçu - - + + in txid dans la transaction - - + + received nothing in txid n'a rien reçu dans la transaction - - + + WARNING: this transaction is not yet included in the blockchain! - ATTENTION : cette transaction n'est pas encore inclue dans la chaîne de blocs ! + ATTENTION : cette transaction n'est pas encore inclue dans la chaîne de blocs ! - - + + This transaction has %u confirmations Cette transaction a %u confirmations - - + + WARNING: failed to determine number of confirmations! - ATTENTION : échec de la détermination du nombre de confirmations ! + ATTENTION : échec de la détermination du nombre de confirmations ! - + bad min_height parameter: - mauvais paramètre hauteur_minimum : + mauvais paramètre hauteur_minimum : - + bad max_height parameter: - mauvais paramètre hauteur_maximum : + mauvais paramètre hauteur_maximum : - + in reçu - - - out - payé - - - - failed - échoué - - - - pending - en attente - - - + <min_amount> should be smaller than <max_amount> <montant_minimum> doit être inférieur à <montant_maximum> - + Amount: -Montant : +Montant : - + , number of keys: - , nombre de clés : + , nombre de clés : - + - + Min block height: -Hauteur de bloc minimum : +Hauteur de bloc minimum : - + Max block height: -Hauteur de bloc maximum : +Hauteur de bloc maximum : - + Min amount found: -Montant minimum trouvé : +Montant minimum trouvé : - + Max amount found: -Montant maximum trouvé : +Montant maximum trouvé : - + Total count: -Compte total : +Compte total : - + Bin size: -Taille de classe : +Taille de classe : - + Outputs per *: -Sorties par * : +Sorties par * : - + count ^ @@ -4293,54 +4499,54 @@ Sorties par * : - + | | - + + + - + +--> block height +--> hauteur de bloc - + ^ ^ - + ^ ^ - + - + wallet portefeuille - - + + Random payment ID: - ID de paiement aléatoire : + ID de paiement aléatoire : - + Matching integrated address: - Adresse intégrée correspondante : + Adresse intégrée correspondante : @@ -4396,297 +4602,437 @@ Sorties par * : Erreur de vérification des infos multisig supplémentaires - - Error finalizing multisig - Erreur de finalisation multisig - - - + Generated multisig wallets for address Portefeuilles multisig générés pour l'adresse - + Error creating multisig wallets: - Erreur de création des portefeuilles multisig : + Erreur de création des portefeuilles multisig : - + This program generates a set of multisig wallets - use this simpler scheme only if all the participants trust each other Ce programme génère un ensemble de portefeuilles multisig - n'utilisez cette méthode plus simple que si tous les participants se font confiance - + Error: Can't specify more than one of --testnet and --stagenet Erreur: Impossible de spécifier plus d'une option parmis --testnet et --stagenet - + Error: expected N/M, but got: - Erreur : N/M attendu, mais lu : + Erreur : N/M attendu, mais lu : - - + + Error: either --scheme or both of --threshold and --participants may be given - Erreur : soit --scheme soit --threshold et --participants doivent être indiqués + Erreur : soit --scheme soit --threshold et --participants doivent être indiqués - + Error: expected N > 1 and N <= M, but got N==%u and M==%d - Erreur : N > 1 et N <= M attendu, mais lu N==%u et M==%d + Erreur : N > 1 et N <= M attendu, mais lu N==%u et M==%d - + Error: --filename-base is required - Erreur : --filename-base est requis + Erreur : --filename-base est requis + + + + mms::message_store + + + Use PyBitmessage instance at URL <arg> + - - Error: unsupported scheme: only N/N and N-1/N are supported - Erreur : schéma non supporté : seuls N/N et N-1/N sont supportés + + Specify <arg> as username:password for PyBitmessage API + + + + + Auto-config cannot proceed because auto config data from other signers is not complete + + + + + The signer config is not complete. + + + + + Wallet can't go multisig because key sets from other signers are missing or not complete. + + + + + Wallet can't start another key exchange round because key sets from other signers are missing or not complete. + + + + + Syncing not done because multisig sync data from other signers are missing or not complete. + + + + + There are waiting messages, but nothing is ready to process under normal circumstances + + + + + +Use "mms next sync" if you want to force processing of the waiting sync data + + + + + +Use "mms note" to display the waiting notes + + + + + There are no messages waiting to be processed. + + + + + key set + + + + + additional key set + + + + + multisig sync data + + + + + partially signed tx + + + + + fully signed tx + + + + + note + + + + + signer config + + + + + auto-config data + + + + + unknown message type + + + + + in + reçu + + + + out + payé + + + + unknown message direction + + + + + ready to send + + + + + sent + + + + + waiting + + + + + processed + + + + + cancelled + + + + + unknown message state + sw - + Generate new wallet and save it to <arg> Générer un nouveau portefeuille et le sauvegarder dans <arg> - + Generate new wallet from device and save it to <arg> Générer un nouveau portefeuille à partir de l'appareil et le sauvegarder dans <arg> - + Generate incoming-only wallet from view key Générer un portefeuille d'audit à partir d'une clé d'audit - + Generate deterministic wallet from spend key Générer un portefeuille déterministe à partir d'une clé de dépense - + Generate wallet from private keys Générer un portefeuille à partir de clés privées - + Generate a master wallet from multisig wallet keys Générer un portefeuille principal à partir de clés de portefeuille multisig - + Language for mnemonic Langue de la phrase mnémonique - + Specify Electrum seed for wallet recovery/creation Spécifier la phrase mnémonique Electrum pour la récupération/création d'un portefeuille - + Recover wallet using Electrum-style mnemonic seed Récupérer un portefeuille en utilisant une phrase mnémonique de style Electrum - + Recover multisig wallet using Electrum-style mnemonic seed Récupérer un portefeuille multisig en utilisant une phrase mnémonique de style Electrum - + Generate non-deterministic view and spend keys Générer des clés d'audit et de dépense non déterministes - + invalid argument: must be either 0/1, true/false, y/n, yes/no argument invalide : doit être soit 0/1, true/false, y/n, yes/no - + DNSSEC validation passed Validation DNSSEC réussie - + WARNING: DNSSEC validation was unsuccessful, this address may not be correct! ATTENTION: la validation DNSSEC a échoué, cette adresse n'est peut être pas correcte ! - + For URL: Pour l'URL : - + Monero Address = Adresse Monero = - + Is this OK? (Y/n) Est-ce correct ? (Y/n) - + you have cancelled the transfer request vous avez annulé la demande de transfert - + failed to parse index: - échec de l'analyse de l'index : + échec de l'analyse de l'index : - + invalid format for subaddress lookahead; must be <major>:<minor> format invalide pour l'anticipation des sous-addresses; doit être <majeur>:<mineur> - + no connection to daemon. Please make sure daemon is running. pas de connexion au démon. Veuillez vous assurer que le démon fonctionne. - + RPC error: - Erreur RPC : + Erreur RPC : - + failed to get random outputs to mix: - échec de la récupération de sorties aléatoires à mélanger : + échec de la récupération de sorties aléatoires à mélanger : - - + + Not enough money in unlocked balance Pas assez de fonds dans le solde débloqué - + Failed to find a way to create transactions. This is usually due to dust which is so small it cannot pay for itself in fees, or trying to send more money than the unlocked balance, or not leaving enough for fees Impossible de trouver une façon de créer les transactions. Ceci est souvent dû à de la poussière si petite qu'elle ne peut pas payer ses propres frais, ou à une tentative d'envoi d'un montant supérieur au solde débloqué, ou à un montant restant insuffisant pour payer les frais - + not enough outputs for specified ring size pas assez de sorties pour la taille de cercle spécifiée - + output amount montant de la sortie - + found outputs to use sorties à utiliser trouvées - + Please use sweep_unmixable. Veuillez utiliser sweep_unmixable. - + transaction was not constructed la transaction n'a pas été construite - + transaction %s was rejected by daemon with status: - la transaction %s a été rejetée par le démon avec le statut : + la transaction %s a été rejetée par le démon avec le statut : - + Reason: Raison : - + one of destinations is zero une des destinations est zéro - + failed to find a suitable way to split transactions échec de la recherche d'une façon adéquate de scinder les transactions - + unknown transfer error: - erreur de transfert inconnue : + erreur de transfert inconnue : - + Multisig error: - Erreur multisig : + Erreur multisig : - + internal error: - erreur interne : + erreur interne : - + unexpected error: - erreur inattendue : + erreur inattendue : - + There was an error, which could mean the node may be trying to get you to retry creating a transaction, and zero in on which outputs you own. Or it could be a bona fide error. It may be prudent to disconnect from this node, and not try to send a transaction immediately. Alternatively, connect to another node so the original node cannot correlate information. Il y a eu une erreur, ce qui pourrait signifier que le noeud essaye de vous faire réessayer de créer une transaction, pour tenter d'identifier quelles sorties sont les votres. Ou il pourrait s'agir d'une erreur de bonne foi. Il pourrait être prudent de se déconnecter de ce noeud, et de ne pas essayer d'envoyer une transaction immédiatement. Ou sinon, se connecter à un autre noeud pour que le noeud original ne puisse pas corréler les informations. - + File %s likely stores wallet private keys! Use a different file name. Le fichier %s contient probablement des clés privées de portefeuille ! Utilisez un nom de fichier différent. - + File %s already exists. Are you sure to overwrite it? (Y/Yes/N/No): Le fichier %s existe déjà. Êtes vous sûr de vouloir l'écraser ? (Y/Yes/N/No) : - + seconds secondes - + minutes minutes - + hours heures - + days jours - + months mois - + a long time longtemps - + This is the command line monero wallet. It needs to connect to a monero daemon to work correctly. WARNING: Do not reuse your Monero keys on another fork, UNLESS this fork has key reuse mitigations built in. Doing so will harm your privacy. @@ -4695,68 +5041,68 @@ Il a besoin de se connecter à un démon monero pour fonctionner correctement. ATTENTION : Ne réutilisez pas vos clés Monero avec un autre fork, À MOINS QUE ce fork inclue des mitigations contre la réutilisation des clés. Faire ceci nuira à votre confidentialité. - + Unknown command: - Commande inconnue : + Commande inconnue : - + Allow communicating with a daemon that uses a different RPC version Autoriser la communication avec un démon utilisant une version de RPC différente - + Restore from specific blockchain height Restaurer à partir d'une hauteur de bloc spécifique - + The newly created transaction will not be relayed to the monero network La transaction nouvellement créée ne sera pas transmise au réseau monero - + Create an address file for new wallets Créer un fichier d'adresse pour les nouveaux portefeuilles - + Display English language names Afficher les noms de langue en anglais - + failed to read wallet password échec de la lecture du mot de passe du portefeuille - + Enter a new password for the wallet Entrer un nouveau mot de passe pour le portefeuille - + Wallet password Mot de passe du portefeuille - - + + daemon is busy. Please try again later. le démon est occupé. Veuillez réessayer plus tard. - + possibly lost connection to daemon connexion avec le démon peut-être perdue - + Error: - Erreur : + Erreur : - + Failed to initialize wallet Échec de l'initialisation du portefeuille @@ -4764,228 +5110,233 @@ ATTENTION : Ne réutilisez pas vos clés Monero avec un autre fork, À MOINS QUE tools::wallet2 - + Use daemon instance at <host>:<port> Utiliser l'instance de démon située à <hôte>:<port> - + Use daemon instance at host <arg> instead of localhost Utiliser l'instance de démon située à l'hôte <arg> au lieu de localhost - + Wallet password file Fichier mot de passe du portefeuille - + Use daemon instance at port <arg> instead of 18081 Utiliser l'instance de démon située au port <arg> au lieu de 18081 - + For testnet. Daemon must also be launched with --testnet flag Pour testnet, le démon doit aussi être lancé avec l'option --testnet - + can't specify daemon host or port more than once impossible de spécifier l'hôte ou le port du démon plus d'une fois - + can't specify more than one of --password and --password-file impossible de spécifier plus d'une option parmis --password et --password-file - + the password file specified could not be read le fichier mot de passe spécifié n'a pas pu être lu - + Failed to load file Échec du chargement du fichier - + Wallet password (escape/quote as needed) Mot de passe du portefeuille (échapper/citer si nécessaire) - + Enable commands which rely on a trusted daemon Activer les commandes qui dépendent d'un démon de confiance - + Disable commands which rely on a trusted daemon Désactiver les commandes qui dépendent d'un démon de confiance - + Specify username[:password] for daemon RPC client Spécifier le nom_utilisateur:[mot_de_passe] pour le client RPC du démon - + For stagenet. Daemon must also be launched with --stagenet flag Pour stagenet, le démon doit aussi être lancé avec l'option --stagenet - + Set shared ring database path Définir le chemin de la base de donnée de cercles partagés - + Number of rounds for the key derivation function Nombre de rondes de la fonction de dérivation de clé - + HW device to use Portefeuille matériel à utiliser - + + HW device wallet derivation path (e.g., SLIP-10) + + + + --trusted-daemon and --untrusted-daemon are both seen, assuming untrusted --trusted-daemon et --untrusted-daemon présents simultanément, --untrusted-daemon choisi - + Daemon is local, assuming trusted Le démon est local, supposons qu'il est de confiance - + no password specified; use --prompt-for-password to prompt for a password pas de mot de passe spécifié; utilisez --prompt-for-password pour demander un mot de passe - + Enter a new password for the wallet Entrer un nouveau mot de passe pour le portefeuille - + Wallet password Mot de passe du portefeuille - + Failed to parse JSON Échec de l'analyse JSON - + Version %u too new, we can only grok up to %u Version %u trop récente, on comprend au mieux %u - + failed to parse view key secret key échec de l'analyse de la clé secrète d'audit - - - + + + failed to verify view key secret key échec de la vérification de la clé secrète d'audit - + failed to parse spend key secret key échec de l'analyse de la clé secrète de dépense - - - + + + failed to verify spend key secret key échec de la vérification de la clé secrète de dépense - + Electrum-style word list failed verification Échec de la vérification de la liste de mots de style Electrum - + At least one of either an Electrum-style word list, private view key, or private spend key must be specified Il faut spécifier au moins une des options parmis la liste de mots de style Electrum, la clé privée d'audit et la clé privée de dépense - + Both Electrum-style word list and private key(s) specified Liste de mots de style Electrum et clé privée spécifiées en même temps - + invalid address adresse invalide - + view key does not match standard address la clé d'audit ne correspond pas à l'adresse standard - + spend key does not match standard address la clé de dépense ne correspond pas à l'adresse standard - + Cannot generate deprecated wallets from JSON Impossible de générer un portefeuille obsolète à partir de JSON - + failed to parse address: - échec de l'analyse de l'adresse : + échec de l'analyse de l'adresse : - + Address must be specified in order to create watch-only wallet L'adresse doit être spécifiée afin de créer un portefeuille d'audit - + failed to generate new wallet: - échec de la génération du nouveau portefeuille : + échec de la génération du nouveau portefeuille : - + Password is needed to compute key image for incoming monero Le mot de passe est requis pour calculer l'image de clé pour les moneros entrants - + Invalid password: password is needed to compute key image for incoming monero Mot de passe invalide : le mot de passe est requis pour calculer l'image de clé pour les moneros entrants - - - + + + Primary account Compte primaire - + No funds received in this tx. Aucun fonds n'a été reçu dans cette transaction. - + failed to read file échec de la lecture du fichier - + Set subaddress lookahead sizes to <major>:<minor> Définir les tailles d'anticipation des sous-addresses à <majeur>:<mineur> @@ -5000,7 +5351,7 @@ ATTENTION : Ne réutilisez pas vos clés Monero avec un autre fork, À MOINS QUE Failed to create directory %s: %s - Échec de la création du répertoire %s : %s + Échec de la création du répertoire %s : %s @@ -5038,91 +5389,91 @@ ATTENTION : Ne réutilisez pas vos clés Monero avec un autre fork, À MOINS QUE Le mot clé %s n'est pas enregistré. - + Transaction not possible. Available only %s, transaction amount %s = %s + %s (fee) - Transaction impossible. Solde disponible : %s, montant de la transaction %s = %s + %s (frais) + Transaction impossible. Solde disponible : %s, montant de la transaction %s = %s + %s (frais) - + This is the RPC monero wallet. It needs to connect to a monero daemon to work correctly. Ceci est le portefeuille monero par RPC. Il a besoin de se connecter à un démon monero pour fonctionner correctement. - + Can't specify more than one of --wallet-file and --generate-from-json Impossible de spécifier plus d'une option parmis --wallet-file et --generate-from-json - + Can't specify more than one of --testnet and --stagenet Impossible de spécifier plus d'une option parmis --testnet et --stagenet - + Must specify --wallet-file or --generate-from-json or --wallet-dir --wallet-file, --generate-from-json ou --wallet-dir doit être spécifié - + Loading wallet... Chargement du portefeuille... - - + + Saving wallet... Sauvegarde du portefeuille... - - + + Successfully saved Sauvegardé avec succès - + Successfully loaded Chargé avec succès - + Wallet initialization failed: - Échec de l'initialisation du portefeuille : + Échec de l'initialisation du portefeuille : - + Failed to initialize wallet RPC server Échec de l'initialisation du serveur RPC du portefeuille - + Starting wallet RPC server Démarrage du serveur RPC du portefeuille - + Failed to run wallet: - Échec du lancement du portefeuille : + Échec du lancement du portefeuille : - + Stopped wallet RPC server Arrêt du serveur RPC du portefeuille - + Failed to save wallet: - Échec de la sauvegarde du portefeuille : + Échec de la sauvegarde du portefeuille : wallet_args - - - + + + Wallet options Options du portefeuille @@ -5171,17 +5522,27 @@ connecter à un démon monero pour fonctionner correctement. Logging to: - Journalisation dans : + Journalisation dans : Logging to %s Journalisation dans %s + + + WARNING: You may not have a high enough lockable memory limit + + + + + see ulimit -l + + Usage: - Usage : + Usage : diff --git a/translations/monero_it.ts b/translations/monero_it.ts index 09872fea8..18b43e6d7 100644 --- a/translations/monero_it.ts +++ b/translations/monero_it.ts @@ -1,6 +1,6 @@ - + Monero::AddressBookImpl @@ -11,7 +11,7 @@ Invalid payment ID. Short payment ID should only be used in an integrated address - ID pagamento non valido. L'ID pagamento corto dovrebbe essere usato solo in un indirizzo integrato + ID pagamento non valido. L'ID pagamento corto dovrebbe essere usato solo in un indirizzo integrato @@ -21,51 +21,61 @@ Integrated address and long payment ID can't be used at the same time - L'indirizzo integrato e l'ID pagamento lungo non possono essere utilizzati contemporaneamente + L'indirizzo integrato e l'ID pagamento lungo non possono essere utilizzati contemporaneamente Monero::PendingTransactionImpl - + Attempting to save transaction to file, but specified file(s) exist. Exiting to not risk overwriting. File: Sto tentando di salvare la transazione nel file, ma il file specificato è già esistente. Sto uscendo per non rischiare di sovrascriverlo. File: - + Failed to write transaction(s) to file Impossibile scrivere transazione/i su file - + daemon is busy. Please try again later. il daemon è impegnato. Prova più tardi. - + no connection to daemon. Please make sure daemon is running. nessuna connessione con il daemon. Controlla che sia operativo. - + transaction %s was rejected by daemon with status: la transazione %s è stata respinta dal daemon con status: - + . Reason: . Motivo: - + Unknown exception: Eccezione sconosciuta: - + Unhandled exception Eccezione non gestita + + + Couldn't multisig sign data: + + + + + Couldn't sign multisig transaction: + + Monero::UnsignedTransactionImpl @@ -124,281 +134,407 @@ Monero::WalletImpl - + payment id has invalid format, expected 16 or 64 character hex string: L'id pagamento è in un formato invalido, dovrebbe essere una stringa esadecimale di 16 o 64 caratteri: - + Failed to add short payment id: Impossibile aggiungere id pagamento corto - - + + daemon is busy. Please try again later. il daemon è impegnato. Riprova più tardi. - - + + no connection to daemon. Please make sure daemon is running. nessuna connessione con il daemon. Accertati che sia operativo. - - + + RPC error: errore RPC: - - + + not enough outputs for specified ring size insufficiente numero di output per il ring size specificato - - + + found outputs to use trovati output che possono essere usati - + Please sweep unmixable outputs. Pulisci gli output non mixabili. - - failed to get random outputs to mix - impossibile recuperare output casuali da mixare - - - - + + not enough money to transfer, available only %s, sent amount %s non hai abbastanza fondi da trasferire, sono disponibili solo %s, ammontare inviato %s - + failed to parse address parsing indirizzo fallito - + failed to parse secret spend key impossibile effettuare il parsing della chiave segreta di spesa - - No view key supplied, cancelled - Non è stata fornita nessuna chiave di visualizzazione - - - + failed to parse secret view key impossibile effettuare il parsing della chiave segreta di visualizzazione - + failed to verify secret spend key impossibile verificare la chiave segreta di spesa - + spend key does not match address la chiave di spesa non corrisponde all'indirizzo - + failed to verify secret view key verifica chiave segreta di visualizzazione fallita - + view key does not match address la chiave di visualizzazione non corrisponde all'indirizzo - + + failed to generate new wallet: impossibile generare il nuovo portafoglio: - + Failed to send import wallet request Impossibile inviare la richiesta di importazione portafoglio - + Failed to load unsigned transactions Impossibile caricare transazioni non firmate - + Failed to load transaction from file Impossibile caricare la transazione da file - + Wallet is view only Il portafoglio è di tipo solo visualizzazione - + failed to save file impossibile salvare il file - + Key images can only be imported with a trusted daemon Le key image possono essere importate solo con un daemon fidato - + Failed to import key images: Impossibile importare le key images: - + Failed to get subaddress label: - Impossibile recuperare l'etichetta del sottoindirizzo: + Impossibile recuperare l'etichetta del sottoindirizzo: - + Failed to set subaddress label: - Impossibile assegnare l'etichetta del sottoindirizzo: + Impossibile assegnare l'etichetta del sottoindirizzo: - - failed to get random outputs to mix: %s - impossibile recuperare output casuali da mixare: %s + + Neither view key nor spend key supplied, cancelled + - - + + Electrum seed is empty + + + + + Electrum-style word list failed verification + + + + + Failed to get multisig info: + + + + + + Failed to make multisig: + + + + + Failed to finalize multisig wallet creation + + + + + Failed to finalize multisig wallet creation: + + + + + Failed to export multisig images: + + + + + Failed to parse imported multisig images + + + + + Failed to import multisig images: + + + + + Failed to check for partial multisig key images: + + + + + Failed to restore multisig transaction: + + + + + Invalid destination address + Indirizzo destinatario non valido + + + + failed to get outputs to mix: %s + + + + + not enough money to transfer, overall balance only %s, sent amount %s fondi non sufficienti per il trasferimento, saldo totale %s, importo inviato %s - - + + not enough money to transfer, available only %s, transaction amount %s = %s + %s (fee) fondi non sufficienti per il trasferimento, disponibili solo %s, ammontare transazione %s = %s + %s (commissione) - - + + output amount ammontare output - - + + transaction was not constructed transazione non costruita - - + + transaction %s was rejected by daemon with status: la transazione %s è stata rifiutata dal daemon con status: - - + + one of destinations is zero una delle destinazioni è zero - - + + failed to find a suitable way to split transactions impossibile trovare un modo per dividere le transazioni - - + + unknown transfer error: errore trasferimento sconosciuto: - - + + internal error: errore interno: - - + + unexpected error: errore inaspettato: - - + + unknown error errore sconosciuto - - - - - - + + failed to get outputs to mix + + + + + + + + + + Failed to parse txid Impossibile effettuare parsing del txid - + no tx keys found for this txid nessuna chiave tx trovata per questo txid - - + + Failed to parse tx key Impossibile effettuare parsing della chiave tx - - - - + + + + Failed to parse address - Impossibile effettuare parsing dell'indirizzo + Impossibile effettuare parsing dell'indirizzo - + Address must not be a subaddress - L'indirizzo non può essere un sottoindirizzo + L'indirizzo non può essere un sottoindirizzo - + + The wallet must be in multisig ready state + + + + + Given string is not a key + + + + Rescan spent can only be used with a trusted daemon "Riscannerizza spesi" può essere utilizzato solo da un daemon fidato + + + Invalid output: + + + + + Failed to mark outputs as spent + + + + + + Failed to parse output amount + + + + + + Failed to parse output offset + + + + + Failed to mark output as spent + + + + + Failed to mark output as unspent + + + + + + Failed to parse key image + + + + + Failed to get ring + + + + + Failed to get rings + + + + + Failed to set ring + + Wallet - + Failed to parse address - Impossibile effettuare parsing dell'indirizzo + Impossibile effettuare parsing dell'indirizzo - + Failed to parse key Impossibile effettuare parsing della chiave - + failed to verify key impossibile effettuare la verifica della chiave - + key does not match address la chiave non corrisponde all'indirizzo @@ -406,12 +542,12 @@ command_line - + yes - + no no @@ -449,18 +585,18 @@ permette connessioni esterne non criptate in entrata. Considera in alternativa un tunnel SSH o un proxy SSL. Sovrascrivi con -- - + Username specified with -- Nome utente specificato con -- - - + + cannot be empty non può essere vuoto - + requires RPC server password -- @@ -468,1036 +604,925 @@ cryptonote::simple_wallet - + Commands: Comandi: - + failed to read wallet password impossibile leggere la password del portafoglio - + invalid password password non valida - + set seed: needs an argument. available options: language imposta seed: richiede un argomento. opzioni disponibili: lingua - + set: unrecognized argument(s) imposta: argomento/i non riconosciuto/i - + wallet file path not valid: percorso file portafoglio non valido: - + Attempting to generate or restore wallet, but specified file(s) exist. Exiting to not risk overwriting. Sto tentando di generare o ripristinare il portafoglio, ma i(l) file specificato/i esiste/esistono già. Sto uscendo per non rischiare di sovrascrivere. - - usage: payment_id - uso: payment_id - - - + needs an argument ha bisogno di un argomento - - - - - - - - - - + + + + + + + + + + + + + 0 or 1 0 o 1 - - 0, 1, 2, 3, or 4 - 0, 1, 2, 3, o 4 - - - - + + + unsigned integer intero senza segno - - NOTE: the following 25 words can be used to recover access to your wallet. Write them down and store them somewhere safe and secure. Please do not store them in your email or on file storage services outside of your immediate control. - - ATTENZIONE: le seguenti 25 parole possono essere usate per ripristinare il tuo portafoglio. Prendine nota e conservale in un posto sicuro. Non conservarle nella tua casella di posta elettronica o utilizzando servizi di cloud storage. - - - + specify a recovery parameter with the --electrum-seed="words list here" specificare un parametro di ripristino con --electrum-seed="lista parole qui" - + wallet failed to connect to daemon: impossibile connettere il portafoglio al daemon: - + Daemon uses a different RPC major version (%u) than the wallet (%u): %s. Either update one of them, or use --allow-mismatched-daemon-version. Il daemon usa una versione principale RPC (%u) diversa da quella del portafoglio (%u): %s. Aggiorna una delle due, o usa --allow-mismatched-daemon-version. - + List of available languages for your wallet's seed: Lista delle lingue disponibili per il seed del tuo portafoglio: - + Enter the number corresponding to the language of your choice: Inserisci il numero corrispondente al linguaggio da te scelto: - + You had been using a deprecated version of the wallet. Please use the new seed that we provide. Hai usato una versione obsoleta del portafoglio. Per favore usa il nuovo seed che ti abbiamo fornito. - - + + Generated new wallet: Nuovo portafoglio generato: - - - + + + + failed to generate new wallet: impossibile generare nuovo portafoglio: - + Opened watch-only wallet Portafoglio solo-vista aperto - + Opened wallet Portafoglio aperto - + You had been using a deprecated version of the wallet. Please proceed to upgrade your wallet. Stai utilizzando una versione disapprovata del portafoglio. Per favore procedi nell'upgrade del portafoglio. - + You had been using a deprecated version of the wallet. Your wallet file format is being upgraded now. Stai utilizzando una versione disapprovata del portafoglio. Il formato del tuo portafoglio sta venendo aggiornato adesso. - + failed to load wallet: impossibile caricare portafoglio: - + Use the "help" command to see the list of available commands. Usa il comando "help" per visualizzare la lista dei comandi disponibili. - + Wallet data saved Dati del portafoglio salvati - + Mining started in daemon Mining avviato nel daemon - + mining has NOT been started: il mining NON è stato avviato: - + Mining stopped in daemon Mining nel daemon interrotto - + mining has NOT been stopped: il mining NON è stato interrotto: - + Blockchain saved Blockchain salvata - - - + + Height Blocco - - transaction - transazione - - - + spent speso/i - - unsupported transaction format - formato transazione non supportato - - - + Starting refresh... Sto iniziando il refresh... - + Refresh done, blocks received: Refresh finito, blocchi ricevuti: - - + payment id has invalid format, expected 16 or 64 character hex string: l'id pagamento ha un formato invalido, dovrebbe essere una stringa hex di 16 o 64 caratteri: - + bad locked_blocks parameter: parametro locked_blocks non corretto: - - - + + a single transaction cannot use more than one payment id: una singola transazione non può usare più di un id pagamento: - - - - + + + + failed to set up payment id, though it was decoded correctly impossibile impostare id pagamento, anche se è stato decodificado correttamente - - - - - - - - + + + + ring size %u is too large, maximum is %u + + + + + + Unencrypted payment IDs are bad for privacy: ask the recipient to use subaddresses instead + + + + + payment id failed to encode + + + + + + Locked blocks too high, max 1000000 (˜4 yrs) + + + + + failed to parse short payment ID from URI + + + + + + Invalid last argument: + + + + + a single transaction cannot use more than one payment id + + + + + failed to parse payment id, though it was detected + + + + + + + + + + + transaction cancelled. transazione cancellata. - + Sending %s. Sto inviando %s. - + Your transaction needs to be split into %llu transactions. This will result in a transaction fee being applied to each transaction, for a total fee of %s La tua transazione deve essere divisa in %llu transazioni. Una commissione verrà applicata per ogni transazione, per un totale di %s commissioni - + The transaction fee is %s La commissione per la transazione è %s - + , of which %s is dust from change , della quale %s è polvere dovuta allo scambio - + . . - + A total of %s from dust change will be sent to dust address Un totale di %s in polvere verrà inviato all'indirizzo della polvere - + . This transaction will unlock on block %llu, in approximately %s days (assuming 2 minutes per block) . Questa transazione verrà sbloccata al blocco %llu, in approssimativamente %s giorni (supponendo 2 minuti per blocco) - - - - - - - - + + Unsigned transaction(s) successfully written to MMS + + + + + + + + + + + Failed to write transaction(s) to file Impossibile scrivere transazione/i su file - - - - - - - - + + + + + + + + Unsigned transaction(s) successfully written to file: Transazioni/e non firmata/e scritte/a con successo su file: - + + + Failed to cold sign transaction with HW wallet + + + + No unmixable outputs found Nessun output non-mixabile trovato - + + Not enough money in unlocked balance + + + + + Discarding %s of unmixable outputs that cannot be spent, which can be undone by "rescan_spent". Is this okay? (Y/Yes/N/No): + + + + No address given Non è stato fornito nessun indirizzo - + + missing lockedblocks parameter + + + + + bad locked_blocks parameter + + + + + + Failed to parse number of outputs + + + + + + Amount of outputs should be greater than 0 + + + + + Failed to parse donation address: + + + + + Donating %s %s to The Monero Project (donate.getmonero.org or %s). + + + + + Donating %s %s to %s. + + + + Claimed change does not go to a paid address Il cambiamento richiesto non porta a un indirizzo pagato - + Claimed change is larger than payment to the change address Il cambiamento richiesto è più largo del pagamento all'indirizzo di cambio - + sending %s to %s sto mandando %s a %s - + dummy output(s) output dummy - + with no destinations senza destinazioni - + Loaded %lu transactions, for %s, fee %s, %s, %s, with min ring size %lu, %s. %sIs this okay? (Y/Yes/N/No): Caricate %lu transazioni, per %s, commissione %s, %s, %s, con ring size minimo %lu, %s. %sOK?(Y/Yes/N/No): - + This is a multisig wallet, it can only sign with sign_multisig Questo è un portafoglio multisig, può firmare solo con sign_multisig - - usage: sign_transfer [export] - uso: sign_transfer [export] - - - + Failed to sign transaction Impossibile firmare la transazione - + Failed to sign transaction: Impossibile firmare la transazione: - + Transaction raw hex data exported to Dati esadecimali grezzi della transazione esportati su - + Failed to load transaction from file Impossibile caricare la transazione da file - - + + RPC error: errore RPC: - + wallet is watch-only and has no spend key il portafoglio è solo-vista e non ha una chiave di spesa - - - + + + + Your original password was incorrect. La tua password originale era scorretta - + Error with wallet rewrite: Errore riscrittura wallet: - - priority must be 0, 1, 2, 3, or 4 - la priorità deve essere 0, 1, 2, 3, or 4 - - - - - priority must be 0, 1, 2, 3, or 4 - la priorità deve essere 0, 1, 2, 3, or 4 - - - + invalid unit unità invalida - - + + invalid count: must be an unsigned integer conteggio invalido: deve essere un intero senza segno - + invalid value valore invalido - - usage: set_log <log_level_number_0-4> | <categories> - uso: set_log <log_level_number_0-4> | <categories> - - - + (Y/Yes/N/No): (S/Sì/N/No): - - + + bad m_restore_height parameter: parametro m_restore_height non corretto: - + date format must be YYYY-MM-DD il formato della data deve essere YYYY-MM-DD - + Restore height is: Ripristina altezza è: - - + + + Is this okay? (Y/Yes/N/No): Va bene? (S/Sì/N/No): - + Daemon is local, assuming trusted Il daemon è locale, viene considerato fidato - + Password for new watch-only wallet Password per il nuovo portafoglio solo-vista - - invalid arguments. Please use start_mining [<number_of_threads>] [do_bg_mining] [ignore_battery], <number_of_threads> should be from 1 to - argomenti invalidi. Usa start_mining [<number_of_threads>] [do_bg_mining] [ignore_battery], <number_of_threads> dovrebbe risultare da 1 a - - - + internal error: errore interno: - - - + + + unexpected error: errore inaspettato: - - - - - - - - - + + + + + + + + + + + unknown error errore sconosciuto - + refresh failed: refresh fallito: - + Blocks received: Blocchi ricevuti: - + unlocked balance: bilancio sbloccato: - - - + + + + amount ammontare - + false falso - + Unknown command: Comando sconosciuto: - + Command usage: Uso del comando: - + Command description: Descrizione del comando: - + wallet is multisig but not yet finalized il portafoglio è multisig ma ancora non finalizzato - - Enter optional seed encryption passphrase, empty to see raw seed - Immetti passphrase opzionale per la cifratura del seed, lascia vuoto per vedere il seed grezzo - - - + Failed to retrieve seed Impossibile recuperare il seed - + wallet is multisig and has no seed il portafoglio è multisig e non ha seed - - Cannot connect to daemon - Impossibile connettersi al daemon - - - - Current fee is %s monero per kB - La commissione attuale è %s Monero(j) per kB - - - + Error: failed to estimate backlog array size: - Errore: impossibile stimare la dimensione dell'array di backlog: + Errore: impossibile stimare la dimensione dell'array di backlog: - + Error: bad estimated backlog array size - Errore: errata stima della dimensione dell'array di backlog + Errore: errata stima della dimensione dell'array di backlog - + (current) (attuale) - + %u block (%u minutes) backlog at priority %u%s Backlog blocco %u (%u minuti) a priorità %u%s - + %u to %u block (%u to %u minutes) backlog at priority %u Backlog blocco %u a %u (%u a %u minuti) a priorità %u - + No backlog at priority Nessun backlog a priorità - - + + This wallet is already multisig Questo portafoglio è già multisig - - + + wallet is watch-only and cannot be made multisig il portafoglio è sola-visualizzazione e non può essere reso multisig - - + + This wallet has been used before, please use a new wallet to create a multisig wallet Questo portafoglio è stato usato precedentmente, per cortesia utilizza un nuovo portafoglio per creare un portafoglio multisig - - Your password is incorrect. - La tua password è errata. - - - + Send this multisig info to all other participants, then use make_multisig <threshold> <info1> [<info2>...] with others' multisig info Invia queste informazioni multisig a tutti gli altri partecipanti, poi utilizza make_multisig <threshold> <info1> [<info2>...] con le informazioni multisig degli altri - + This includes the PRIVATE view key, so needs to be disclosed only to that multisig wallet's participants Questo include la chiave PRIVATA di visualizzazione, pertanto deve essere comunicata solo ai partecipanti di quel portafoglio multisig - - usage: make_multisig <threshold> <multisiginfo1> [<multisiginfo2>...] - utilizzo: make_multisig <threshold> <multisiginfo1> [<multisiginfo2>...] - - - + Invalid threshold Soglia invalida - + + Another step is needed Ancora un ultimo passo - - Send this multisig info to all other participants, then use finalize_multisig <info1> [<info2>...] with others' multisig info - Invia queste informazioni multisig a tutti gli altri partecipanti, poi utilizza finalize_multisig <info1> [<info2>...] con le informazioni multisig degli altri - - - + Error creating multisig: Impossibile creare multisig: - + Error creating multisig: new wallet is not multisig Impossibile creare multisig: il nuovo portafoglio non è multisig - + multisig address: indirizzo multisig: - - - + + + + This wallet is not multisig Questo portafoglio non è multisig - + + This wallet is already finalized Questo portafoglio è già finalizzato - - usage: finalize_multisig <multisiginfo1> [<multisiginfo2>...] - utilizzo: finalize_multisig <multisiginfo1> [<multisiginfo2>...] - - - + Failed to finalize multisig Impossibile finalizzare multisig - + Failed to finalize multisig: Impossibile finalizzare multisig: - - - - - + + + + + This multisig wallet is not yet finalized Questo portafoglio multisig non è ancora finalizzato - - usage: export_multisig_info <filename> - utilizzo: export_multisig_info <filename> - - - + Error exporting multisig info: Impossibile esportare informazioni sul multisig: - + Multisig info exported to Informazioni sul multisig esportate su - - usage: import_multisig_info <filename1> [<filename2>...] - one for each other participant - utilizzo: import_multisig_info <filename1> [<filename2>...] - uno per ogni altro partecipante - - - + Multisig info imported Informazioni su multisig importate - + Failed to import multisig info: Impossibile importare informazioni sul multisig: - + Failed to update spent status after importing multisig info: Impossibile aggiornare lo stato di spesa dopo aver importato le informazioni sul multisig: - + Untrusted daemon, spent status may be incorrect. Use a trusted daemon and run "rescan_spent" Daemon non fidato, lo stato di spesa potrebbe non essere corretto. Usare un daemon fidato ed eseguire "rescan_spent" - - - + + + This is not a multisig wallet Questo non è un portafoglio multisig - - usage: sign_multisig <filename> - uso: sign_multisig <filename> - - - + + Failed to sign multisig transaction Impossibile firmare la transazione multisig - + Multisig error: Errore multisig: - + Failed to sign multisig transaction: Impossibile firmare la transazione multisig: - + It may be relayed to the network with submit_multisig Potrebbe essere trasmesso alla rete con submit_multisig - - usage: submit_multisig <filename> - uso: submit_multisig <filename> - - - - + + Failed to load multisig transaction from file Impossibile caricare la transazione multisig da file - - + + Multisig transaction signed by only %u signers, needs %u more signatures Transazione multisig firmata da solo %u firmatari, necessita di altre %u firme - - + + Transaction successfully submitted, transaction Transazione inviata con successo, transazione - - + + You can check its status by using the `show_transfers` command. - E' possibile controllare il suo stato mediante il comando `show_transfers`. + E' possibile controllare il suo stato mediante il comando `show_transfers`. - - usage: export_raw_multisig <filename> - utilizzo: export_raw_multisig <filename> - - - + Failed to export multisig transaction to file Impossibile esportare la transazione multisig su file - + Saved exported multisig transaction file(s): Transazioni esportate salvate su(i) file: - - - + + + ring size must be an integer >= il ring size deve essere un intero >= - + could not change default ring size impossibile modificare il ring size di default - + + Invalid height Altezza invalida - - start_mining [<number_of_threads>] [bg_mining] [ignore_battery] - - - - + Start mining in the daemon (bg_mining and ignore_battery are optional booleans). Avvia il mining sul daemon (bg_mining e ignore_battery sono booleani opzionali). - + Stop mining in the daemon. Arresta il mining sul daemon. - - set_daemon <host>[:<port>] - - - - + Set another daemon to connect to. Seleziona un altro daemon cui connettersi. - + Save the current blockchain data. Salva i dati blockchain correnti. - + Synchronize the transactions and balance. Sincronizza le transazioni ed il saldo. - - balance [detail] - saldo [dettaglio] - - - + Show the wallet's balance of the currently selected account. Mostra il saldo del portafoglio del conto attualmente selezionato. - - incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] - - - - - Show the incoming transfers, all or filtered by availability and address index. - -Output format: -Amount, Spent("T"|"F"), "locked"|"unlocked", RingCT, Global Index, Transaction Hash, Address Index, [Public Key, Key Image] - Mostra i trasferimenti in entrata, tutti o filtrati per disponibilità ed indice di indirizzo. - - - - payments <PID_1> [<PID_2> ... <PID_N>] - pagamenti <PID_1> [<PID_2> ... <PID_N>] - - - + Show the payments for the given payment IDs. Mostra i pagamenti per gli id pagamento specificati. - + Show the blockchain height. - Mostra l'altezza della blockchain. + Mostra l'altezza della blockchain. - - transfer_original [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> <amount> [<payment_id>] - - - - - Transfer <amount> to <address> using an older transaction building algorithm. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding <address_2> <amount_2> etcetera (before the payment ID, if it's included) - Trasferisce <amount> a <address> usando un algoritmo più vecchio per la costruzione della transazione. Se viene specificato il parametro "index=<N1>[,<N2>,...]", il portafoglio usa output ricevuti dagli indirizzi di questi indici. Se il parametro viene omesso, il portafoglio sceglie casualmente gli indici di indirizzo da utilizzare. In ogni caso, fa del suo meglio per non combinare output su indirizzi multipli. <priority> è la priorità della transazione. Più alta è la priorità, più alta è la commissione riconosciuta per la transazione. I valori ammissibili in ordine di priorità (dal più basso al più alto) sono: non importante, normale, elevato, prioritaria. Se la priorità è omessa, viene utilizzato il valore di default (vedi il comando "set priority"). <ring_size> è il numero di input da includere per la non tracciabilità. Possono essere effettuati pagamenti multipli in una sola volta aggiungendo <address_2> <amount_2> etc. (prima dell'ID di pagamento, se incluso) - - - - transfer [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> <amount> [<payment_id>] - - - - - Transfer <amount> to <address>. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding <address_2> <amount_2> etcetera (before the payment ID, if it's included) - Trasferisce <amount> a <address>. Se viene specificato il parametro "index=<N1>[,<N2>,...]", il portafoglio usa output ricevuti dagli indirizzi di questi indici. Se il parametro viene omesso, il portafoglio sceglie casualmente gli indici di indirizzo da utilizzare. In ogni caso, fa del suo meglio per non combinare output su indirizzi multipli. <priority> è la priorità della transazione. Più alta è la priorità, più alta è la commissione riconosciuta per la transazione. I valori ammissibili in ordine di priorità (dal più basso al più alto) sono: non importante, normale, elevato, prioritaria. Se la priorità è omessa, viene utilizzato il valore di default (vedi il comando "set priority"). <ring_size> è il numero di input da includere per la non tracciabilità. Possono essere effettuati pagamenti multipli in una sola volta aggiungendo <address_2> <amount_2> etc. (prima dell'ID di pagamento, se incluso) - - - - locked_transfer [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <addr> <amount> <lockblocks> [<payment_id>] - - - - - Transfer <amount> to <address> and lock it for <lockblocks> (max. 1000000). If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding <address_2> <amount_2> etcetera (before the payment ID, if it's included) - Trasferisce <amount> to <address> e lo blocca per <lockblocks> (max. 1000000). Se viene specificato il parametro "index=<N1>[,<N2>,...]", il portafoglio usa output ricevuti dagli indirizzi di questi indici. Se il parametro viene omesso, il portafoglio sceglie casualmente gli indici di indirizzo da utilizzare. In ogni caso, fa del suo meglio per non combinare output su indirizzi multipli. <priority> è la priorità della transazione. Più alta è la priorità, più alta è la commissione riconosciuta per la transazione. I valori ammissibili in ordine di priorità (dal più basso al più alto) sono: non importante, normale, elevato, prioritaria. Se la priorità è omessa, viene utilizzato il valore di default (vedi il comando "set priority"). <ring_size> è il numero di input da includere per la non tracciabilità. Possono essere effettuati pagamenti multipli in una sola volta aggiungendo <address_2> <amount_2> etc. (prima dell'ID di pagamento, se incluso) - - - + Send all unmixable outputs to yourself with ring_size 1 Invia tutti gli output non mixabili a te stesso usando ring_size 1 - - sweep_all [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> [<payment_id>] - - - - - Send all unlocked balance to an address. If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. - Invia tutto il saldo sbloccato ad un indirizzo. Se viene specificato il parametro "index<N1>[,<N2>,...]", il portafoglio spazza gli output ricevuti da questi indici di indirizzo. Se il parametro viene omesso, il portafoglio sceglie casualmente un indice di indirizzo da utilizzare. - - - - sweep_below <amount_threshold> [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> [<payment_id>] - - - - + Send all unlocked outputs below the threshold to an address. Invia tutti gli output sbloccati sotto la soglia ad un indirizzo. - - sweep_single [<priority>] [<ring_size>] <key_image> <address> [<payment_id>] - - - - + Send a single output of the given key image to an address without change. Invia un singolo output della key image specificata ad un indirizzo senza modifica. - - donate [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <amount> [<payment_id>] - - - - + Donate <amount> to the development team (donate.getmonero.org). Dona <amount> al team di sviluppo (donate.getmonero.org). - - sign_transfer <file> - - - - - Sign a transaction from a <file>. - Firma una transazione da <file>. - - - + Submit a signed transaction from a file. Invia una transazione firmata da file. - - set_log <level>|{+,-,}<categories> - - - - + Change the current log detail (level must be <0-4>). Modifica il dettaglio di log (il livello deve essere <0-4>). - - account - account new <label text with white spaces allowed> - account switch <index> - account label <index> <label text with white spaces allowed> - account tag <tag_name> <account_index_1> [<account_index_2> ...] - account untag <account_index_1> [<account_index_2> ...] - account tag_description <tag_name> <description> - - - - + If no arguments are specified, the wallet shows all the existing accounts along with their balances. If the "new" argument is specified, the wallet creates a new account with its label initialized by the provided label text (which can be empty). If the "switch" argument is specified, the wallet switches to the account specified by <index>. @@ -1508,67 +1533,1165 @@ If the "tag_description" argument is specified, the tag <tag_name&g - - address [ new <label text with white spaces allowed> | all | <index_min> [<index_max>] | label <index> <label text with white spaces allowed>] - - - - - If no arguments are specified or <index> is specified, the wallet shows the default or specified address. If "all" is specified, the walllet 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. - - - - - integrated_address [<payment_id> | <address>] - - - - + 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 - - address_book [(add ((<address> [pid <id>])|<integrated address>) [<description possibly with whitespaces>])|(delete <index>)] - - - - + Print all entries in the address book, optionally adding/deleting an entry to/from it. - + Save the wallet data. - + Save a watch-only keys file. - + Display the private view key. - + Display the private spend key. - + Display the Electrum-style mnemonic seed - - set <option> [<value>] + + Display the encrypted Electrum-style mnemonic seed. - + + Rescan the blockchain for spent outputs. + + + + + Get the transaction key (r) for a given <txid>. + + + + + Check the amount going to <address> in <txid>. + + + + + Generate a signature proving funds sent to <address> in <txid>, optionally with a challenge string <message>, using either the transaction secret key (when <address> is not your wallet's address) or the view secret key (otherwise), which does not disclose the secret key. + + + + + Check the proof for funds going to <address> in <txid> with the challenge string <message> if any. + + + + + Generate a signature proving that you generated <txid> using the spend secret key, optionally with a challenge string <message>. + + + + + Check a signature proving that the signer generated <txid>, optionally with a challenge string <message>. + + + + + Generate a signature proving that you own at least this much, optionally with a challenge string <message>. +If 'all' is specified, you prove the entire sum of all of your existing accounts' balances. +Otherwise, you prove the reserve of the smallest possible amount above <amount> available in your current account. + + + + + Check a signature proving that the owner of <address> holds at least this much, optionally with a challenge string <message>. + + + + + Show the unspent outputs of a specified address within an optional amount range. + + + + + Set an arbitrary string note for a <txid>. + + + + + Get a string note for a txid. + + + + + Set an arbitrary description for the wallet. + + + + + Get the description of the wallet. + + + + + Show the wallet's status. + + + + + Show the wallet's information. + + + + + Sign the contents of a file. + + + + + Verify a signature on the contents of a file. + + + + + Import a signed key images list and verify their spent status. + + + + + Export a set of outputs owned by this wallet. + + + + + Import a set of outputs owned by this wallet. + + + + + Show information about a transfer to/from this address. + + + + + Change the wallet's password. + + + + + Generate a new random full size payment id. These will be unencrypted on the blockchain, see integrated_address for encrypted short payment ids. + + + + + Print the information about the current fee and transaction backlog. + + + + + Export data needed to create a multisig wallet + + + + + Turn this wallet into a multisig wallet + + + + + Turn this wallet into a multisig wallet, extra step for N-1/N wallets + + + + + Export multisig info for other participants + + + + + Import multisig info from other participants + + + + + Sign a multisig transaction from a file + + + + + Submit a signed multisig transaction from a file + + + + + Export a signed multisig transaction to a file + + + + + Show the help section or the documentation about a <command>. + + + + + integer >= + + + + + block height + + + + + No wallet found with that name. Confirm creation of new wallet named: + + + + + can't specify both --restore-deterministic-wallet or --restore-multisig-wallet and --non-deterministic + + + + + --restore-multisig-wallet uses --generate-new-wallet, not --wallet-file + + + + + specify a recovery parameter with the --electrum-seed="multisig seed here" + + + + + Multisig seed failed verification + + + + + + This address is a subaddress which cannot be used here. + + + + + Error: expected M/N, but got: + + + + + Error: expected N > 1 and N <= M, but got: + + + + + Error: M/N is currently unsupported. + + + + + Generating master wallet from %u of %u multisig wallet keys + + + + + failed to parse secret view key + impossibile fare il parsing della chiave segreta di visualizzazione + + + + failed to verify secret view key + verifica chiave segreta di visualizzazione fallita + + + + Secret spend key (%u of %u): + + + + + Error: M/N is currently unsupported + + + + + Restore height + + + + + Still apply restore height? (Y/Yes/N/No): + + + + + Warning: using an untrusted daemon at %s, privacy will be lessened + + + + + Daemon either is not started or wrong port was passed. Please make sure daemon is running or change the daemon address using the 'set_daemon' command. + + + + + Your wallet has been generated! +To start synchronizing with the daemon, use the "refresh" command. +Use the "help" command to see the list of available commands. +Use "help <command>" to see a command's documentation. +Always use the "exit" command when closing monero-wallet-cli to save +your current session's state. Otherwise, you might need to synchronize +your wallet again (your wallet keys are NOT at risk in any case). + + + + + + failed to generate new mutlisig wallet + + + + + Generated new %u/%u multisig wallet: + + + + + Opened %u/%u multisig wallet%s + + + + + Use "help <command>" to see a command's documentation. + + + + + + wallet is multisig and cannot save a watch-only version + + + + + Unexpected array length - Exited simple_wallet::set_daemon() + + + + + This does not seem to be a valid daemon URL. + + + + + + txid + + + + + + idx + + + + + (Some owned outputs have partial key images - import_multisig_info needed) + + + + + Currently selected account: [ + + + + + ] + + + + + Tag: + + + + + (No tag assigned) + + + + + Balance per address: + + + + + Address + + + + + + Balance + + + + + + Unlocked balance + + + + + Outputs + + + + + + + Label + + + + + %8u %6s %21s %21s %7u %21s + + + + + spent + spesi + + + + global index + indice globale + + + + tx id + tx id + + + + + addr index + + + + + No incoming transfers + Nessun trasferimento in entrata + + + + No incoming available transfers + Nessun trasferimento in entrata disponibile + + + + No incoming unavailable transfers + Nessun trasferimento indisponibile in entrata + + + + payment + pagamento + + + + transaction + transazione + + + + height + altezza + + + + unlock time + tempo sbloccato + + + + No payments with id + Nessun pagamento con id + + + + + + + failed to get blockchain height: + impossibile recuperare altezza blockchain: + + + + +Transaction %llu/%llu: txid=%s + +Transazione %llu/%llu: txid=%s + + + + +Input %llu/%llu: amount=%s + + + + + failed to get output: + impossibile recuperare output: + + + + output key's originating block height shouldn't be higher than the blockchain height + l'altezza del blocco di origine della chiave di output non dovrebbe essere più alta dell'altezza della blockchain + + + + +Originating block heights: + +Originando blocchi: + + + + +| + +| + + + + + | + + | + + + + + +Warning: Some input keys being spent are from + +Avviso: alcune chiavi di input spese vengono da + + + + , which can break the anonymity of ring signature. Make sure this is intentional! + , che potrebbe compromettere l'anonimità della ring signature. Assicurati di farlo intenzionalmente! + + + + + + Ring size must not be 0 + Il ring size non può essere 0 + + + + + + ring size %u is too small, minimum is %u + il ring size %u è troppo piccolo, il minimo è %u + + + + wrong number of arguments + numero di argomenti errato + + + + + + No payment id is included with this transaction. Is this okay? (Y/Yes/N/No): + Nessun id pagamento è incluso in questa transazione. Questo è corretto? (S/Sì/N/No): + + + + + No outputs found, or daemon is not ready + Nessun output trovato, o il daemon non è pronto + + + + + + failed to parse tx_key + + + + + Tx key successfully stored. + + + + + Failed to store tx key: + + + + + + block + + + + + usage: show_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] + + + + + usage: export_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] [output=<path>] + + + + + direction + + + + + timestamp + + + + + running balance + + + + + hash + + + + + payment ID + + + + + fee + + + + + destination + + + + + index + + + + + note + + + + + CSV exported to + + + + + Warning: this will lose any information which can not be recovered from the blockchain. + + + + + This includes destination addresses, tx secret keys, tx notes, etc + + + + + Rescan anyway ? (Y/Yes/N/No): + + + + + MMS received new message + + + + + Network type: + + + + + Testnet + + + + + Stagenet + + + + + Mainnet + + + + + + command only supported by HW wallet + + + + + hw wallet does not support cold KI sync + + + + + Please confirm the key image sync on the device + + + + + Key images synchronized to height + + + + + Running untrusted daemon, cannot determine which transaction output is spent. Use a trusted daemon with --trusted-daemon and run rescan_spent + + + + + spent, + + + + + unspent + + + + + Failed to import key images + + + + + Failed to import key images: + Impossibile importare le key images: + + + + Failed to reconnect device + + + + + Failed to reconnect device: + + + + + Transaction successfully saved to + + + + + + , txid + + + + + Failed to save transaction to + + + + + + Sweeping %s in %llu transactions for a total fee of %s. Is this okay? (Y/Yes/N/No): + Sto eseguendo lo sweep di %s nelle transazioni %llu per un totale commissioni di %s. Va bene? (S/Sì/N/No): + + + + + + Sweeping %s for a total fee of %s. Is this okay? (Y/Yes/N/No): + Sto eseguendo lo sweep di %s per un totale commissioni di %s. Va bene? (S/Sì/N/No): + + + + This is a watch only wallet + Questo è un portafoglio solo-vista + + + + Double spend seen on the network: this transaction may or may not end up being mined + + + + + Transaction ID not found + ID transazione non trovato + + + + true + vero + + + + failed to parse refresh type + impossibile fare il parsing del tipo di refresh + + + + + + + + + + + + + + + + + + + + + + + + + command not supported by HW wallet + + + + + + wallet is watch-only and has no seed + il portafoglio è solo-vista e non possiede un seed + + + + + wallet is non-deterministic and has no seed + il portafoglio è non-deterministico e non possiede un seed + + + + Enter optional seed offset passphrase, empty to see raw seed + + + + + Incorrect password + + + + + Current fee is %s %s per %s + + + + + + Send this multisig info to all other participants, then use exchange_multisig_keys <info1> [<info2>...] with others' multisig info + + + + + Multisig wallet has been successfully created. Current wallet type: + + + + + Failed to perform multisig keys exchange: + + + + + Failed to load multisig transaction from MMS + + + + + + Invalid key image + + + + + Invalid txid + + + + + Key image either not spent, or spent with mixin 0 + + + + + Failed to get key image ring: + + + + + File doesn't exist + + + + + Invalid ring specification: + + + + + Invalid key image: + + + + + Invalid ring type, expected relative or abosolute: + + + + + + Error reading line: + + + + + Invalid ring: + + + + + Invalid relative ring: + + + + + Invalid absolute ring: + + + + + Failed to set ring for key image: + + + + + Continuing. + + + + + Missing absolute or relative keyword + + + + + + invalid index: must be a strictly positive unsigned integer + + + + + invalid index: indices wrap + + + + + invalid index: indices should be in strictly ascending order + + + + + failed to set ring + + + + + First line is not an amount + + + + + Invalid output: + + + + + Bad argument: + + + + + should be "add" + + + + + Failed to open file + + + + + Invalid output key, and file doesn't exist + + + + + Failed to mark output spent: + + + + + + Invalid output + + + + + Failed to mark output unspent: + + + + + Spent: + + + + + Not spent: + + + + + Failed to check whether output is spent: + + + + + Failed to save known rings: + + + + + Please confirm the transaction on the device + + + + + + wallet is watch-only and cannot transfer + il portafoglio è solo-vista e non può eseguire trasferimenti + + + + + WARNING: this is a non default ring size, which may harm your privacy. Default is recommended. + + + + + WARNING: from v8, ring size will be fixed and this setting will be ignored. + + + + + + + priority must be either 0, 1, 2, 3, or 4, or one of: + + + + + could not change default priority + impossibile cambiare priorità standard + + + + invalid argument: must be either 0/never, 1/action, or 2/encrypt/decrypt + + + + + Device name not specified + + + + + Device reconnect failed + + + + + Device reconnect failed: + + + + + Show the incoming transfers, all or filtered by availability and address index. + +Output format: +Amount, Spent("T"|"F"), "locked"|"unlocked", RingCT, Global Index, Transaction Hash, Address Index, [Public Key, Key Image] + + + + + Transfer <amount> to <address>. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) + + + + + Transfer <amount> to <address> and lock it for <lockblocks> (max. 1000000). If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) + + + + + Send all unlocked balance to an address and lock it for <lockblocks> (max. 1000000). If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. <priority> is the priority of the sweep. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. + + + + + Send all unlocked balance to an address. If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. If the parameter "outputs=<N>" is specified and N > 0, wallet splits the transaction into N even outputs. + + + + + Sign a transaction from a file. If the parameter "export_raw" is specified, transaction raw hex data suitable for the daemon RPC /sendrawtransaction is exported. + + + + + 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. + + + + Available options: seed language Set the wallet's seed language. @@ -1579,7 +2702,7 @@ If the "tag_description" argument is specified, the tag <tag_name&g store-tx-info <1|0> Whether to store outgoing tx info (destination address, payment ID, tx secret key) for future reference. default-ring-size <n> - Set the default ring size (default and minimum is 5). + Set the default ring size (obsolete). auto-refresh <1|0> Whether to automatically synchronize new blocks from the daemon. refresh-type <full|optimize-coinbase|no-coinbase|default> @@ -1587,7 +2710,7 @@ If the "tag_description" argument is specified, the tag <tag_name&g priority [0|1|2|3|4] Set the fee to default/unimportant/normal/elevated/priority. confirm-missing-payment-id <1|0> - ask-password <1|0> + ask-password <0|1|2 (or never|action|decrypt)> unit <monero|millinero|micronero|nanonero|piconero> Set the default monero (sub-)unit. min-outputs-count [n] @@ -1603,114 +2726,31 @@ If the "tag_description" argument is specified, the tag <tag_name&g refresh-from-block-height [n] Set the height before which to ignore blocks. auto-low-priority <1|0> - Whether to automatically use the low priority fee level when it's safe to do so. + Whether to automatically use the low priority fee level when it's safe to do so. + segregate-pre-fork-outputs <1|0> + Set this if you intend to spend outputs on both Monero AND a key reusing fork. + key-reuse-mitigation2 <1|0> + Set this if you are not sure whether you will spend on a key reusing Monero fork later. +subaddress-lookahead <major>:<minor> + Set the lookahead sizes for the subaddress hash table. + Set this if you are not sure whether you will spend on a key reusing Monero fork later. + segregation-height <n> + Set to the height of a key reusing fork you want to use, 0 to use default. - - Display the encrypted Electrum-style mnemonic seed. + + Set the transaction key (r) for a given <txid> in case the tx was made by some other device or 3rd party wallet. - - Rescan the blockchain for spent outputs. - - - - - get_tx_key <txid> - - - - - Get the transaction key (r) for a given <txid>. - - - - - check_tx_key <txid> <txkey> <address> - - - - - Check the amount going to <address> in <txid>. - - - - - get_tx_proof <txid> <address> [<message>] - - - - - Generate a signature proving funds sent to <address> in <txid>, optionally with a challenge string <message>, using either the transaction secret key (when <address> is not your wallet's address) or the view secret key (otherwise), which does not disclose the secret key. - - - - - check_tx_proof <txid> <address> <signature_file> [<message>] - - - - - Check the proof for funds going to <address> in <txid> with the challenge string <message> if any. - - - - - get_spend_proof <txid> [<message>] - - - - - Generate a signature proving that you generated <txid> using the spend secret key, optionally with a challenge string <message>. - - - - - check_spend_proof <txid> <signature_file> [<message>] - - - - - Check a signature proving that the signer generated <txid>, optionally with a challenge string <message>. - - - - - get_reserve_proof (all|<amount>) [<message>] - - - - - Generate a signature proving that you own at least this much, optionally with a challenge string <message>. -If 'all' is specified, you prove the entire sum of all of your existing accounts' balances. -Otherwise, you prove the reserve of the smallest possible amount above <amount> available in your current account. - - - - - check_reserve_proof <address> <signature_file> [<message>] - - - - - Check a signature proving that the owner of <address> holds at least this much, optionally with a challenge string <message>. - - - - - show_transfers [in|out|pending|failed|pool] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] - - - - + Show the incoming/outgoing transfers within an optional height range. Output format: -In or Coinbase: Block Number, "block"|"in", Time, Amount, Transaction Hash, Payment ID, Subaddress Index, "-", Note\ +In or Coinbase: Block Number, "block"|"in", Time, Amount, Transaction Hash, Payment ID, Subaddress Index, "-", Note Out: Block Number, "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Destinations, Input addresses**, "-", Note -Pool: "pool", "in", Time, Amount, Transaction Hash, Payment Id, Subaddress Index, "-", Note, Double Spend Note\ +Pool: "pool", "in", Time, Amount, Transaction Hash, Payment Id, Subaddress Index, "-", Note, Double Spend Note Pending or Failed: "failed"|"pending", "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Input addresses**, "-", Note * Excluding change and fee. @@ -1718,1824 +2758,1762 @@ Pending or Failed: "failed"|"pending", "o - - unspent_outputs [index=<N1>[,<N2>,...]] [<min_amount> [<max_amount>]] + + export_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] [output=<filepath>] - - Show the unspent outputs of a specified address within an optional amount range. + + Export to CSV the incoming/outgoing transfers within an optional height range. - - Rescan the blockchain from scratch. + + Rescan the blockchain from scratch, losing any information which can not be recovered from the blockchain itself. - - set_tx_note <txid> [free text note] + + Export a signed set of key images to a <filename>. - - Set an arbitrary string note for a <txid>. + + Synchronizes key images with the hw wallet. - - get_tx_note <txid> + + Attempts to reconnect HW wallet. - - Get a string note for a txid. - - - - - set_description [free text note] - - - - - Set an arbitrary description for the wallet. - - - - - Get the description of the wallet. - - - - - Show the wallet's status. - - - - - Show the wallet's information. - - - - - sign <file> - - - - - Sign the contents of a file. - - - - - verify <filename> <address> <signature> - - - - - Verify a signature on the contents of a file. - - - - - export_key_images <file> - - - - - Export a signed set of key images to a <file>. - - - - - import_key_images <file> - - - - - Import a signed key images list and verify their spent status. - - - - - export_outputs <file> - - - - - Export a set of outputs owned by this wallet. - - - - - import_outputs <file> - - - - - Import a set of outputs owned by this wallet. - - - - - show_transfer <txid> - - - - - Show information about a transfer to/from this address. - - - - - Change the wallet's password. - - - - - Generate a new random full size payment id. These will be unencrypted on the blockchain, see integrated_address for encrypted short payment ids. - - - - - Print the information about the current fee and transaction backlog. - - - - - Export data needed to create a multisig wallet - - - - - make_multisig <threshold> <string1> [<string>...] - - - - - Turn this wallet into a multisig wallet - - - - - finalize_multisig <string> [<string>...] - - - - - Turn this wallet into a multisig wallet, extra step for N-1/N wallets - - - - - export_multisig_info <filename> - - - - - Export multisig info for other participants - - - - - import_multisig_info <filename> [<filename>...] - - - - - Import multisig info from other participants - - - - - sign_multisig <filename> - - - - - Sign a multisig transaction from a file - - - - - submit_multisig <filename> - - - - - Submit a signed multisig transaction from a file - - - - - export_raw_multisig_tx <filename> - - - - - Export a signed multisig transaction to a file - - - - - help [<command>] - - - - - Show the help section or the documentation about a <command>. - - - - - integer >= - - - - - block height - - - - - No wallet found with that name. Confirm creation of new wallet named: - - - - - can't specify more than one of --generate-new-wallet="wallet_name", --wallet-file="wallet_name", --generate-from-view-key="wallet_name", --generate-from-spend-key="wallet_name", --generate-from-keys="wallet_name", --generate-from-multisig-keys="wallet_name" and --generate-from-json="jsonfilename" - - - - - can't specify both --restore-deterministic-wallet or --restore-multisig-wallet and --non-deterministic - - - - - --restore-multisig-wallet uses --generate-new-wallet, not --wallet-file - - - - - specify a recovery parameter with the --electrum-seed="multisig seed here" - - - - - Multisig seed failed verification - - - - - Enter seed encryption passphrase, empty if none - - - - - - This address is a subaddress which cannot be used here. - - - - - Error: expected M/N, but got: - - - - - Error: expected N > 1 and N <= M, but got: - - - - - Error: M/N is currently unsupported. - - - - - Generating master wallet from %u of %u multisig wallet keys - - - - - failed to parse secret view key - impossibile fare il parsing della chiave segreta di visualizzazione - - - - failed to verify secret view key - verifica chiave segreta di visualizzazione fallita - - - - Secret spend key (%u of %u): - - - - - Error: M/N is currently unsupported - - - - - Restore height - - - - - Still apply restore height? (Y/Yes/N/No): - - - - - Warning: using an untrusted daemon at %s, privacy will be lessened - - - - - Daemon either is not started or wrong port was passed. Please make sure daemon is running or change the daemon address using the 'set_daemon' command. - - - - - Your wallet has been generated! -To start synchronizing with the daemon, use the "refresh" command. -Use the "help" command to see the list of available commands. -Use "help <command>" to see a command's documentation. -Always use the "exit" command when closing monero-wallet-cli to save -your current session's state. Otherwise, you might need to synchronize -your wallet again (your wallet keys are NOT at risk in any case). - - - - - - failed to generate new mutlisig wallet - - - - - Generated new %u/%u multisig wallet: + + Performs extra multisig keys exchange rounds. Needed for arbitrary M/N multisig wallets - Opened %u/%u multisig wallet%s + Interface with the MMS (Multisig Messaging System) +<subcommand> is one of: + init, info, signer, list, next, sync, transfer, delete, send, receive, export, note, show, set, help + send_signer_config, start_auto_config, stop_auto_config, auto_config +Get help about a subcommand with: help mms <subcommand>, or mms help <subcommand> + + + + + Initialize and configure the MMS for M/N = number of required signers/number of authorized signers multisig + + + + + Display current MMS configuration + + + + + Set or modify authorized signer info (single-word label, transport address, Monero address), or list all signers + + + + + List all messages + + + + + Evaluate the next possible multisig-related action(s) according to wallet state, and execute or offer for choice +By using 'sync' processing of waiting messages with multisig sync info can be forced regardless of wallet state + + + + + Force generation of multisig sync info regardless of wallet state, to recover from special situations like "stale data" errors + + + + + Initiate transfer with MMS support; arguments identical to normal 'transfer' command arguments, for info see there + + + + + Delete a single message by giving its id, or delete all messages by using 'all' + + + + + Send a single message by giving its id, or send all waiting messages + + + + + Check right away for new messages to receive + + + + + Write the content of a message to a file "mms_message_content" - Use "help <command>" to see a command's documentation. - + Send a one-line message to an authorized signer, identified by its label, or show any waiting unread notes - - wallet is multisig and cannot save a watch-only version + + Show detailed info about a single message - - missing daemon URL argument + + Available options: + auto-send <1|0> + Whether to automatically send newly generated messages right away. + - - Unexpected array length - Exited simple_wallet::set_daemon() + + Send completed signer config to all other authorized signers - - This does not seem to be a valid daemon URL. + + Start auto-config at the auto-config manager's wallet by issuing auto-config tokens and optionally set others' labels - - - txid + + Delete any auto-config tokens and abort a auto-config process - - - idx + + Start auto-config by using the token received from the auto-config manager - - (Some owned outputs have partial key images - import_multisig_info needed) + + Print the ring(s) used to spend a given key image or transaction (if the ring size is > 1) + +Output format: +Key Image, "absolute", list of rings - - Currently selected account: [ + + Set the ring used for a given key image, so it can be reused in a fork - - ] + + Save known rings to the shared rings database - - Tag: + + Mark output(s) as spent so they never get selected as fake outputs in a ring - - (No tag assigned) + + Marks an output as unspent so it may get selected as a fake output in a ring - - Balance per address: + + Checks whether an output is marked as spent - - Address + + Returns version information - - - Balance - - - - - - Unlocked balance - - - - - Outputs - - - - - - Label - - - - - %8u %6s %21s %21s %7u %21s - - - - - usage: balance [detail] - - - - - - usage: incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] - - - - - spent - spesi - - - - global index - indice globale - - - - tx id - tx id - - - - - addr index - - - - - No incoming transfers - Nessun trasferimento in entrata - - - - No incoming available transfers - Nessun trasferimento in entrata disponibile - - - - No incoming unavailable transfers - Nessun trasferimento indisponibile in entrata - - - - expected at least one payment ID - deve esserci almeno un payment ID - - - - payment - pagamento - - - - transaction - transazione - - - - height - altezza - - - - unlock time - tempo sbloccato - - - - No payments with id - Nessun pagamento con id - - - - - - failed to get blockchain height: - impossibile recuperare altezza blockchain: - - - - - - - - failed to connect to the daemon - impossibile connettersi al daemon - - - - -Transaction %llu/%llu: txid=%s - -Transazione %llu/%llu: txid=%s - - - - -Input %llu/%llu: amount=%s - - - - - failed to get output: - impossibile recuperare output: - - - - output key's originating block height shouldn't be higher than the blockchain height - l'altezza del blocco di origine della chiave di output non dovrebbe essere più alta dell'altezza della blockchain - - - - -Originating block heights: - -Originando blocchi: - - - - -| - -| - - - - - | - - | - - - - - -Warning: Some input keys being spent are from - -Avviso: alcune chiavi di input spese vengono da - - - - , which can break the anonymity of ring signature. Make sure this is intentional! - , che potrebbe compromettere l'anonimità della ring signature. Assicurati di farlo intenzionalmente! - - - - - Ring size must not be 0 - Il ring size non può essere 0 - - - - - ring size %u is too small, minimum is %u - il ring size %u è troppo piccolo, il minimo è %u - - - - wrong number of arguments - numero di argomenti errato - - - - - - No payment id is included with this transaction. Is this okay? (Y/Yes/N/No): - Nessun id pagamento è incluso in questa transazione. Questo è corretto? (S/Sì/N/No): - - - - - No outputs found, or daemon is not ready - Nessun output trovato, o il daemon non è pronto - - - - Transaction successfully saved to - - - - - - , txid - - - - - Failed to save transaction to - - - - - - Sweeping %s in %llu transactions for a total fee of %s. Is this okay? (Y/Yes/N/No): - Sto eseguendo lo sweep di %s nelle transazioni %llu per un totale commissioni di %s. Va bene? (S/Sì/N/No): - - - - - - Sweeping %s for a total fee of %s. Is this okay? (Y/Yes/N/No): - Sto eseguendo lo sweep di %s per un totale commissioni di %s. Va bene? (S/Sì/N/No): - - - - Donating - Donando - - - - This is a watch only wallet - Questo è un portafoglio solo-vista - - - - usage: show_transfer <txid> - utilizzo: show_transfer <txid> - - - - Double spend seen on the network: this transaction may or may not end up being mined - - - - - Transaction ID not found - ID transazione non trovato - - - - true - vero - - - - failed to parse refresh type - impossibile fare il parsing del tipo di refresh - - - - - wallet is watch-only and has no seed - il portafoglio è solo-vista e non possiede un seed - - - - - wallet is non-deterministic and has no seed - il portafoglio è non-deterministico e non possiede un seed - - - - - wallet is watch-only and cannot transfer - il portafoglio è solo-vista e non può eseguire trasferimenti - - - - could not change default priority - impossibile cambiare priorità standard - - - + 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) completo (più lento, nessuna ipotesi); optimize-coinbase (veloce, ipotizza che l'intero coinbase viene pagato ad un indirizzo singolo); no-coinbase (il più veloce, ipotizza di non ricevere una transazione coinbase), default (come optimize-coinbase) - + + 0, 1, 2, 3, or 4, or one of + + + + + 0|1|2 (or never|action|decrypt) + + + + monero, millinero, micronero, nanonero, piconero monero, millinero, micronero, nanonero, piconero - + + <major>:<minor> + + + + + <device_name[:device_spec]> + + + + + wrong number range, use: %s + + + + Wallet name not valid. Please try again or use Ctrl-C to quit. Nome del portafoglio non valido. Prova di nuovo o usa Ctrl-C per uscire - + Wallet and key files found, loading... Portafoglio e chiavi trovate, sto caricando... - + Key file found but not wallet file. Regenerating... Ho trovato la chiave ma non il portafoglio. Sto rigenerando... - + Key file not found. Failed to open wallet: Chiave non trovata. Impossibile aprire portafoglio: - + Generating new wallet... Sto generando un nuovo portafoglio... - + + NOTE: the following %s can be used to recover access to your wallet. Write them down and store them somewhere safe and secure. Please do not store them in your email or on file storage services outside of your immediate control. + + + + + + string + + + + + 25 words + + + + + Can't specify more than one of --testnet and --stagenet + + + + + can't specify more than one of --generate-new-wallet="wallet_name", --wallet-file="wallet_name", --generate-from-view-key="wallet_name", --generate-from-spend-key="wallet_name", --generate-from-keys="wallet_name", --generate-from-multisig-keys="wallet_name", --generate-from-json="jsonfilename" and --generate-from-device="wallet_name" + + + + --restore-deterministic-wallet uses --generate-new-wallet, not --wallet-file --restore-deterministic-wallet usa --generate-new-wallet, non --wallet-file - + Electrum-style word list failed verification La lista di parole stile Electrum ha fallito la verifica - - - - - - - - - - + + Enter seed offset passphrase, empty if none + + + + + + + + + + + + + No data supplied, cancelled Nessun dato fornito, cancellato - - - - - - - - - - - - + + + + + + + + + + + + failed to parse address impossibile fare il parsing dell'indirizzo - - + + failed to parse view key secret key impossibile fare il parsing chiave di visualizzazione chiave segreta - - + + failed to verify view key secret key impossibile verificare chiave di visualizzazione chiave segreta - - - + + + view key does not match standard address la chiave di visualizzazione non corrisponde all'indirizzo standard - - - - - + + + + + + account creation failed creazione dell'account fallita - - - + + + failed to parse spend key secret key impossibile fare il parsing chiave di spesa chiave segreta - - + + failed to verify spend key secret key impossibile verificare chiave di spesa chiave segreta - - + + spend key does not match standard address la chiave di spesa non corrisponde all'indirizzo standard - + + No restore height is specified. + + + + + Assumed you are creating a new account, restore will be done from current estimated blockchain height. + + + + + Use --restore-height if you want to restore an already setup account from a specific height + + + + + account creation aborted + + + + specify a wallet path with --generate-new-wallet (not --wallet-file) specifica un percorso per il portafoglio con --generate-new-wallet (non --wallet-file) - + + can't specify --subaddress-lookahead and --wallet-file at the same time + + + + failed to open account impossibile aprire account - - - - - + + + + + wallet is null il portafoglio è nullo - - + + Failed to initialize ring database: privacy enhancing features will be inactive + + + + + If your display freezes, exit blind with ^C, then run again with --use-english-language-names + + + + + invalid language choice entered. Please try again. linguaggio selezionato scorretto. Prova di nuovo. - + View key: Chiave di visualizzazione: - + + Generated new wallet on hw device: + + + + + Key file not found. Failed to open wallet + + + + You may want to remove the file "%s" and try again Potresti voler rimuovere il file "%s" e provare di nuovo - + failed to deinitialize wallet deinizializzazione portafoglio fallita - - - + + Watch only wallet saved as: + + + + + Failed to save watch only wallet: + + + + + + this command requires a trusted daemon. Enable with --trusted-daemon questo comando richiede un daemon fidato. Abilita questa opzione con --trusted-daemon - + + Expected trusted or untrusted, got + + + + + trusted + + + + + untrusted + + + + blockchain can't be saved: impossibile salvare la blockchain: - - + + NOTE: this transaction uses an encrypted payment ID: consider using subaddresses instead + + + + + WARNING: this transaction uses an unencrypted payment ID: consider using subaddresses instead + + + + + Password needed (%s) - use the refresh command + + + + + Enter password + + + + + Device requires attention + + + + + Enter device PIN + + + + + Failed to read device PIN + + + + + Please enter the device passphrase on the device + + + + + Enter device passphrase + + + + + Failed to read device passphrase + + + + + The first refresh has finished for the HW-based wallet with received money. hw_key_images_sync is needed. + + + + + Do you want to do it now? (Y/Yes/N/No): + + + + + hw_key_images_sync skipped. Run command manually before a transfer. + + + + + daemon is busy. Please try again later. il daemon è impegnato. Prova più tardi - - + + no connection to daemon. Please make sure daemon is running. nessuna connessione con il daemon. Assicurati che sia in funzione - + refresh error: errore refresh: - + + (Some owned outputs have missing key images - import_key_images needed) + + + + Balance: Bilancio: - + + Invalid keyword: + + + + pubkey pubkey - + key image immagine chiave - - + + + unlocked sbloccato - + ringct ringct - + + Heights: + + + + T T - + F F - + locked bloccato - + RingCT RingCT - + - - - + payment ID has invalid format, expected 16 or 64 character hex string: l'id pagamento è in un formato invalido, dovrebbe essere una stringa hex di 16 o 64 caratteri - + failed to get spent status impossibile recuperare status spesi - + + failed to find construction data for tx input + + + + the same transaction la stessa transazione - + blocks that are temporally very close i blocchi che sono temporalmente molto vicini - - Locked blocks too high, max 1000000 (˜4 yrs) - I blocchi bloccati sono troppo alti, max 1000000 (˜4 anni) + + (Y/Yes/N/No): + - - + + Choose processing: + + + + + Sign tx + + + + + Send the tx for submission to + + + + + Send the tx for signing to + + + + + Submit tx + + + + + unknown + + + + + Choice: + + + + + Wrong choice + + + + + Id + + + + + I/O + + + + + Authorized Signer + + + + + Message Type + + + + + Height + + + + + R + + + + + Message State + + + + + Since + + + + + ago + + + + + # + + + + + Transport Address + + + + + Auto-Config Token + + + + + Monero Address + + + + + + + <not set> + + + + + Message + + + + + In/out: + + + + + State: + + + + + %s since %s, %s ago + + + + + Sent: Never + + + + + Sent: %s, %s ago + + + + + Authorized signer: + + + + + Content size: + + + + + bytes + + + + + Content: + + + + + (binary data) + + + + + Send these messages now? + + + + + Queued for sending. + + + + + Invalid message id + + + + + usage: mms init <required_signers>/<authorized_signers> <own_label> <own_transport_address> + + + + + The MMS is already initialized. Re-initialize by deleting all signer info and messages? + + + + + Error in the number of required signers and/or authorized signers + + + + + The MMS is not active. + + + + + Invalid signer number + + + + + mms signer [<number> <label> [<transport_address> [<monero_address>]]] + + + + + Invalid Monero address + + + + + Wallet state does not allow changing Monero addresses anymore + + + + + Usage: mms list + + + + + Usage: mms next [sync] + + + + + No next step: + + + + + prepare_multisig + + + + + make_multisig + + + + + exchange_multisig_keys + + + + + + export_multisig_info + + + + + import_multisig_info + + + + + sign_multisig + + + + + submit_multisig + + + + + Send tx + + + + + Process signer config + + + + + Replace current signer config with the one displayed above? + + + + + Process auto config data + + + + + Nothing ready to process + + + + + Usage: mms sync + + + + + Usage: mms delete (<message_id> | all) + + + + + Delete all messages? + + + + + Usage: mms send [<message_id>] + + + + + Usage: mms receive + + + + + Usage: mms export <message_id> + + + + + Message content saved to: + + + + + Failed to to save message content + + + + + Usage: mms note [<label> <text>] + + + + + No signer found with label + + + + + Usage: mms show <message_id> + + + + + Usage: mms set <option_name> [<option_value>] + + + + + Wrong option value + + + + + Auto-send is on + + + + + Auto-send is off + + + + + Unknown option + + + + + Usage: mms help [<subcommand>] + + + + + Usage: mms send_signer_config + + + + + Signer config not yet complete + + + + + Usage: mms start_auto_config [<label> <label> ...] + + + + + There are signers without a label set. Complete labels before auto-config or specify them as parameters here. + + + + + Auto-config is already running. Cancel and restart? + + + + + Usage: mms stop_auto_config + + + + + Delete any auto-config tokens and stop auto-config? + + + + + Usage: mms auto_config <auto_config_token> + + + + + Invalid auto-config token + + + + + Auto-config already running. Cancel and restart? + + + + + The MMS is not active. Activate using the "mms init" command + + + + + Invalid MMS subcommand + + + + + + Error in MMS command: + + + + + Is this okay anyway? (Y/Yes/N/No): - + There is currently a %u block backlog at that fee level. Is this okay? (Y/Yes/N/No): - + Failed to check for backlog: - - + + Transaction - - + + Spending from address index %d - - + + WARNING: Outputs of multiple addresses are being used together, which might potentially compromise your privacy. - + failed to parse Payment ID - - usage: sweep_single [<priority>] [<ring_size>] <key_image> <address> [<payment_id>] - - - - + failed to parse key image - + No outputs found - + Multiple transactions are created, which is not supposed to happen - + The transaction uses multiple or no inputs, which is not supposed to happen - + missing threshold amount manca la soglia massima dell'ammontare - + invalid amount threshold ammontare soglia invalido - - donations are not enabled on the testnet - - - - - usage: donate [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <amount> [<payment_id>] - - - - + Change goes to more than one address Il cambiamento va a più di un indirizzo - - + + Good signature Firma valida - - - + + + Bad signature Firma invalida - - usage: integrated_address [payment ID] - utilizzo: integrated_address [ID pagamento] - - - + Standard address: Indirizzo standard: - + failed to parse payment ID or address impossibile fare il parsing di ID pagamento o indirizzo - - usage: address_book [(add (<address> [pid <long or short payment id>])|<integrated address> [<description possibly with whitespaces>])|(delete <index>)] - utilizzo: address_book [(add (<address> [pid <long or short payment id>])|<integrated address> [<description possibly with whitespaces>])|(delete <index>)] - - - + failed to parse payment ID impossibile fare il parsing di ID pagamento - + failed to parse index impossibile fare il parsing dell'indice - + Address book is empty. La rubrica è vuota. - + Index: Indice: - - + + Address: Indirizzo: - + Payment ID: ID Pagamento: - - + + Description: Descrizione: - - usage: set_tx_note [txid] free text note - utilizzo: set_tx_note [txid] nota di testo libera - - - - usage: get_tx_note [txid] - utilizzo: get_tx_note [txid] - - - - usage: sign <filename> - utilizzo: sign <filename> - - - + wallet is watch-only and cannot sign il portafoglio è di tipo solo-visualizzazione e non può firmare - - - - + + + + failed to read file impossibile leggere il file - - usage: check_tx_proof <txid> <address> <signature_file> [<message>] - - - - - - + + + failed to load signature file - - usage: get_spend_proof <txid> [<message>] - - - - + wallet is watch-only and cannot generate the proof - - usage: check_spend_proof <txid> <signature_file> [<message>] - - - - - usage: get_reserve_proof (all|<amount>) [<message>] - - - - + The reserve proof can be generated only by a full wallet - - usage: check_reserve_proof <address> <signature_file> [<message>] - - - - + Address must not be a subaddress - + L'indirizzo non può essere un sottoindirizzo - + Good signature -- total: %s, spent: %s, unspent: %s - - usage: show_transfers [in|out|all|pending|failed] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] - - - - + [Double spend seen on the network: this transaction may or may not end up being mined] - - usage: unspent_outputs [index=<N1>[,<N2>,...]] [<min_amount> [<max_amount>]] - - - - + There is no unspent output in the specified address - + (no daemon) - + (out of sync) - + (Untitled account) - - - - - - + + + + + + failed to parse index: - - + + specify an index between 0 and - - usage: - account - account new <label text with white spaces allowed> - account switch <index> - account label <index> <label text with white spaces allowed> - account tag <tag_name> <account_index_1> [<account_index_2> ...] - account untag <account_index_1> [<account_index_2> ...] - account tag_description <tag_name> <description> - - - - + Grand total: Balance: - + , unlocked balance: - + Untagged accounts: - + Tag %s is unregistered. - + Accounts with tag: - + Tag's description: - + Account - + %c%8u %6s %21s %21s %21s - + ---------------------------------------------------------------------------------- - + %15s %21s %21s - + Primary address - + (used) - + (Untitled address) - + <index_min> is already out of bound - + <index_max> exceeds the bound - - usage: address [ new <label text with white spaces allowed> | all | <index_min> [<index_max>] | label <index> <label text with white spaces allowed> ] - - - - - + + Integrated addresses can only be created for account 0 - + Integrated address: %s, payment ID: %s - + Subaddress: - - usage: get_description - - - - + no description found - + description found: - + Filename: - + Watch only - + %u/%u multisig%s - + Normal - + + Type: - - Testnet: - - - - - Yes - - - - - No - - - - + This wallet is multisig and cannot sign - - usage: verify <filename> <address> <signature> - utilizzo: verify <filename> <address> <signature> - - - + Bad signature from Firma non valida da - + Good signature from Firma valida da - - usage: export_key_images <filename> - utilizzo: export_key_images <filename> - - - + wallet is watch-only and cannot export key images il portafoglio è solo-vista e non può esportare immagini chiave - - - + + + failed to save file impossibile salvare file - + Signed key images exported to Chiave immagine firmata esportata in - - usage: import_key_images <filename> - utilizzo: import_key_images <filename> - - - - usage: export_outputs <filename> - utilizzo: export_outputs <filename> - - - + Outputs exported to Outputs esportati in - - usage: import_outputs <filename> - utilizzo: import_outputs <filename> - - - - - - + + + + + amount is wrong: l'ammontare non è corretto: - + + expected number from 0 to deve essere un numero da 0 a - + Sweeping Eseguendo lo sweeping - + Money successfully sent, transaction: Fondi inviati con successo, transazione: - + %s change to %s %s cambia in %s - + no change nessun cambiamento - - - + + + Transaction successfully signed to file Transazione firmata con successo nel file - - usage: get_tx_key <txid> - utilizzo: get_tx_key <txid> - - - - - - - - - - - + + + + + + + + + + failed to parse txid parsing txid fallito - + Tx key: Chiave Tx: - + no tx keys found for this txid nessuna chiave tx trovata per questo txid - - usage: get_tx_proof <txid> <address> [<message>] - - - - - - + + + signature file saved to: - - - + + + failed to save signature file - - usage: check_tx_key <txid> <txkey> <address> - utilizzo: check_tx_key <txid> <txkey> <address> - - - - + + failed to parse tx key impossibile fare il parsing della chiave tx - - - + + + error: errore: - - + + received ricevuto/i - - + + in txid in txid - - + + received nothing in txid nulla ricevuto in txid - - + + WARNING: this transaction is not yet included in the blockchain! AVVISO: questa transazione non è ancora inclusa nella blockchain! - - + + This transaction has %u confirmations Questa transazione ha %u conferme - - + + WARNING: failed to determine number of confirmations! AVVISO: impossibile determinare il numero di conferme! - + bad min_height parameter: parametro min_height non corretto: - + bad max_height parameter: parametro max_height non corretto: - + in in - - - out - out - - - - failed - fallito - - - - pending - in attesa - - - + <min_amount> should be smaller than <max_amount> <min_amount> dovrebbe essere più piccolo di <max_amount> - + Amount: Ammontare: - + , number of keys: , numero di chiavi: - + - + Min block height: Altezza minima blocco: - + Max block height: Altezza massima blocco: - + Min amount found: Ammontare minimo trovato: - + Max amount found: Ammontare massimo trovato: - + Total count: Conto totale: - + Bin size: Dimensione Bin: - + Outputs per *: - + count ^ - + | | - + + + - + +--> block height - + ^ ^ - + ^ ^ - + - + wallet portafoglio - - + + Random payment ID: ID pagamento casuale: - + Matching integrated address: Indirizzo integrato corrispondente: @@ -3552,11 +4530,6 @@ Outputs per *: Give threshold and participants at once as M/N - - - How many participants wil share parts of the multisig wallet - - How many signers are required to sign a valid transaction @@ -3568,18 +4541,33 @@ Outputs per *: - + Generating %u %u/%u multisig wallets - + Error verifying multisig extra info - - Error finalizing multisig + + How many participants will share parts of the multisig wallet + + + + + Create stagenet multisig wallets + + + + + Create an address file for new wallets + + + + + Failed to verify multisig info @@ -3593,132 +4581,495 @@ Outputs per *: - + This program generates a set of multisig wallets - use this simpler scheme only if all the participants trust each other - + + Error: Can't specify more than one of --testnet and --stagenet + + + + Error: expected N/M, but got: - - + + Error: either --scheme or both of --threshold and --participants may be given - + Error: expected N > 1 and N <= M, but got N==%u and M==%d - + Error: --filename-base is required + + + mms::message_store - - Error: unsupported scheme: only N/N and N-1/N are supported + + Use PyBitmessage instance at URL <arg> + + + + + Specify <arg> as username:password for PyBitmessage API + + + + + Auto-config cannot proceed because auto config data from other signers is not complete + + + + + The signer config is not complete. + + + + + Wallet can't go multisig because key sets from other signers are missing or not complete. + + + + + Wallet can't start another key exchange round because key sets from other signers are missing or not complete. + + + + + Syncing not done because multisig sync data from other signers are missing or not complete. + + + + + There are waiting messages, but nothing is ready to process under normal circumstances + + + + + +Use "mms next sync" if you want to force processing of the waiting sync data + + + + + +Use "mms note" to display the waiting notes + + + + + There are no messages waiting to be processed. + + + + + key set + + + + + additional key set + + + + + multisig sync data + + + + + partially signed tx + + + + + fully signed tx + + + + + note + + + + + signer config + + + + + auto-config data + + + + + unknown message type + + + + + in + in + + + + out + out + + + + unknown message direction + + + + + ready to send + + + + + sent + + + + + waiting + + + + + processed + + + + + cancelled + + + + + unknown message state sw - + Generate new wallet and save it to <arg> Genera un nuovo portafoglio e salvalo in <arg> - + + Generate new wallet from device and save it to <arg> + + + + Generate incoming-only wallet from view key Genera un portafoglio solo-ricezione da chiave di visualizzazione - + Generate deterministic wallet from spend key - + Generate wallet from private keys Genera portafoglio da chiavi private - + Generate a master wallet from multisig wallet keys - + Language for mnemonic - + Specify Electrum seed for wallet recovery/creation Specifica il seed stile Electrum per recuperare/creare il portafoglio - + Recover wallet using Electrum-style mnemonic seed Recupera portafoglio usando il seed mnemonico stile-Electrum - + Recover multisig wallet using Electrum-style mnemonic seed - + Generate non-deterministic view and spend keys Crea chiavi di visualizzione e chiavi di spesa non-deterministiche - - Enable commands which rely on a trusted daemon - Abilita comandi dipendenti da un daemon fidato + + invalid argument: must be either 0/1, true/false, y/n, yes/no + - + + DNSSEC validation passed + + + + + WARNING: DNSSEC validation was unsuccessful, this address may not be correct! + + + + + For URL: + + + + + Monero Address = + + + + + Is this OK? (Y/n) + + + + + you have cancelled the transfer request + + + + + failed to parse index: + + + + + invalid format for subaddress lookahead; must be <major>:<minor> + + + + + no connection to daemon. Please make sure daemon is running. + + + + + RPC error: + errore RPC: + + + + failed to get random outputs to mix: + + + + + + Not enough money in unlocked balance + + + + + Failed to find a way to create transactions. This is usually due to dust which is so small it cannot pay for itself in fees, or trying to send more money than the unlocked balance, or not leaving enough for fees + + + + + not enough outputs for specified ring size + insufficiente numero di output per il ring size specificato + + + + output amount + ammontare output + + + + found outputs to use + trovati output che possono essere usati + + + + Please use sweep_unmixable. + + + + + transaction was not constructed + transazione non costruita + + + + transaction %s was rejected by daemon with status: + + + + + Reason: + + + + + one of destinations is zero + una delle destinazioni è zero + + + + failed to find a suitable way to split transactions + impossibile trovare un modo per dividere le transazioni + + + + unknown transfer error: + errore trasferimento sconosciuto: + + + + Multisig error: + Errore multisig: + + + + internal error: + errore interno: + + + + unexpected error: + errore inaspettato: + + + + There was an error, which could mean the node may be trying to get you to retry creating a transaction, and zero in on which outputs you own. Or it could be a bona fide error. It may be prudent to disconnect from this node, and not try to send a transaction immediately. Alternatively, connect to another node so the original node cannot correlate information. + + + + + File %s likely stores wallet private keys! Use a different file name. + + + + + File %s already exists. Are you sure to overwrite it? (Y/Yes/N/No): + + + + + seconds + + + + + minutes + + + + + hours + + + + + days + + + + + months + + + + + a long time + + + + + This is the command line monero wallet. It needs to connect to a monero +daemon to work correctly. +WARNING: Do not reuse your Monero keys on another fork, UNLESS this fork has key reuse mitigations built in. Doing so will harm your privacy. + + + + + Unknown command: + Comando sconosciuto: + + + Allow communicating with a daemon that uses a different RPC version Permetti comunicazioni con un daemon che usa una versione RPC differente - + Restore from specific blockchain height Ripristina da specifico blocco - + The newly created transaction will not be relayed to the monero network - + + Create an address file for new wallets + + + + + Display English language names + + + + + failed to read wallet password + impossibile leggere la password del portafoglio + + + + Enter a new password for the wallet + + + + + Wallet password + + + + + daemon is busy. Please try again later. il daemon è occupato. Prova più tardi. - + possibly lost connection to daemon possibile perdita di connessione con il daemon - + Error: Errore: - - This is the command line monero wallet. It needs to connect to a monero -daemon to work correctly. - - - - + Failed to initialize wallet Inizializzazione wallet fallita @@ -3726,299 +5077,359 @@ daemon to work correctly. tools::wallet2 - + Use daemon instance at <host>:<port> Usa instanza daemon in <host>:<port> - + Use daemon instance at host <arg> instead of localhost Usa istanza daemon all'host <arg> invece che localhost - + Wallet password file File password portafoglio - + Use daemon instance at port <arg> instead of 18081 Usa istanza daemon alla porta <arg> invece che alla 18081 - + For testnet. Daemon must also be launched with --testnet flag Per testnet. Il daemon può anche essere lanciato con la flag --testnet - - Restricts to view-only commands - Restringi a comandi di tipo solo-vista - - - + can't specify daemon host or port more than once non puoi specificare la porta o l'host del daemon più di una volta - + can't specify more than one of --password and --password-file non puoi specificare più di un --password e --password-file - + the password file specified could not be read il file password specificato non può essere letto - + Failed to load file Impossibile caricare file - + Wallet password (escape/quote as needed) Wallet password (escape/quote se necessario) - + + Enable commands which rely on a trusted daemon + Abilita comandi dipendenti da un daemon fidato + + + + Disable commands which rely on a trusted daemon + + + + Specify username[:password] for daemon RPC client Specificare username[:password] per client del daemon RPC - - no password specified; use --prompt-for-password to prompt for a password + + For stagenet. Daemon must also be launched with --stagenet flag - - Failed to parse JSON - Impossibile fare il parsing di JSON + + Set shared ring database path + - - Version %u too new, we can only grok up to %u - La versione %u è troppo recente, possiamo comprendere solo fino alla versione %u + + Number of rounds for the key derivation function + - - failed to parse view key secret key - impossibile fare il parsing di chiave di visualizzazione chiave segreta + + HW device to use + - - - - failed to verify view key secret key - impossibile verificare chiave di visualizzazione chiave segreta + + HW device wallet derivation path (e.g., SLIP-10) + - - failed to parse spend key secret key - impossibile fare il parsing chiave di spesa chiave segreta - - - - - - failed to verify spend key secret key - impossibile verificare chiave di spesa chiave segreta - - - - Electrum-style word list failed verification - Verifica lista di parole stile-Electrum fallita - - - - At least one of Electrum-style word list and private view key and private spend key must be specified + + --trusted-daemon and --untrusted-daemon are both seen, assuming untrusted + Daemon is local, assuming trusted + Il daemon è locale, viene considerato fidato + + + + no password specified; use --prompt-for-password to prompt for a password + + + + + Enter a new password for the wallet + + + + + Wallet password + + + + + Failed to parse JSON + Impossibile fare il parsing di JSON + + + + Version %u too new, we can only grok up to %u + La versione %u è troppo recente, possiamo comprendere solo fino alla versione %u + + + + failed to parse view key secret key + impossibile fare il parsing di chiave di visualizzazione chiave segreta + + + + + + failed to verify view key secret key + impossibile verificare chiave di visualizzazione chiave segreta + + + + failed to parse spend key secret key + impossibile fare il parsing chiave di spesa chiave segreta + + + + + + failed to verify spend key secret key + impossibile verificare chiave di spesa chiave segreta + + + + Electrum-style word list failed verification + Verifica lista di parole stile-Electrum fallita + + + + At least one of either an Electrum-style word list, private view key, or private spend key must be specified + + + + Both Electrum-style word list and private key(s) specified Specificate entrambe lista parole stile-Electrum e chiave/i privata/e - + invalid address indirizzo invalido - + view key does not match standard address la chiave di visualizzazione non corrisponde all'indirizzo standard - + spend key does not match standard address la chiave di spesa non corrisponde all'indirizzo standard - + Cannot generate deprecated wallets from JSON Impossibile creare portafogli disapprovati da JSON - + failed to parse address: - + Address must be specified in order to create watch-only wallet - + failed to generate new wallet: impossibile generare nuovo portafoglio: - - - - - - - - + + Password is needed to compute key image for incoming monero + + + + + Invalid password: password is needed to compute key image for incoming monero + + + + + + Primary account - + No funds received in this tx. - + failed to read file lettura file fallita + + + Set subaddress lookahead sizes to <major>:<minor> + + tools::wallet_rpc_server - - Daemon is local, assuming trusted - Il daemon è locale, viene considerato fidato - - - + Failed to create directory - + Failed to create directory %s: %s - + Cannot specify -- Impossibile specificare -- - + and -- e -- - + Failed to create file Impossibile creare file - + . Check permissions or remove file . Controlla permessi o rimuovi il file - + Error writing to file Errore durante scrittura su file - + RPC username/password is stored in file Username/password RPC conservato nel file - + Tag %s is unregistered. - + Transaction not possible. Available only %s, transaction amount %s = %s + %s (fee) - + This is the RPC monero wallet. It needs to connect to a monero daemon to work correctly. - + Can't specify more than one of --wallet-file and --generate-from-json Non puoi specificare più di un --wallet-file e --generate-from-json - + + Can't specify more than one of --testnet and --stagenet + + + + Must specify --wallet-file or --generate-from-json or --wallet-dir Devi specificare --wallet-file o --generate-from-json o --wallet-dir - + Loading wallet... Sto caricando il portafoglio... - - + + Saving wallet... Sto salvando il portafoglio... - - + + Successfully saved - + Successfully loaded - + Wallet initialization failed: Inizializzazione portafoglio fallita: - + Failed to initialize wallet RPC server Inizializzazione server RPC portafoglio fallita - + Starting wallet RPC server Server RPC portafoglio in avvio - + Failed to run wallet: - + Stopped wallet RPC server Server RPC portafoglio arrestato - + Failed to save wallet: Impossibile salvare portafoglio: @@ -4026,9 +5437,9 @@ daemon to work correctly. wallet_args - - - + + + Wallet options Opzioni portafoglio @@ -4043,48 +5454,58 @@ daemon to work correctly. Usa portafoglio <arg> - + Max number of threads to use for a parallel job Numero massimo di threads da utilizzare per un lavoro parallelo - + Specify log file Specificare file di log - + Config file File configurazione - + General options Opzioni generali - + This is the command line monero wallet. It needs to connect to a monero daemon to work correctly. - + Can't find config file Impossibile trovare file configurazione - + Logging to: Sto salvando il Log in: - + Logging to %s Sto salvando il Log in %s - + + WARNING: You may not have a high enough lockable memory limit + + + + + see ulimit -l + + + + Usage: Uso: diff --git a/translations/monero_ja.ts b/translations/monero_ja.ts index 7305b42f8..617186da3 100644 --- a/translations/monero_ja.ts +++ b/translations/monero_ja.ts @@ -1,6 +1,6 @@ - + Monero::AddressBookImpl @@ -27,45 +27,55 @@ Monero::PendingTransactionImpl - + Attempting to save transaction to file, but specified file(s) exist. Exiting to not risk overwriting. File: ファイルは既に存在するのでファイルに取引を書き出せなかった。上書きしないにエグジットしてます。ファイル: - + Failed to write transaction(s) to file 取引をファイルに書き込めませんでした - + daemon is busy. Please try again later. デーモンは忙しいです。後でもう一度試してください。 - + no connection to daemon. Please make sure daemon is running. デーモンの接続が確立ありません。デーモンが実行中になっていることを確認してください。 - + transaction %s was rejected by daemon with status: 取引 %s がデーモンによって拒否しました。ステータス: - + . Reason: 。 理由: - + Unknown exception: 未知の例外: - + Unhandled exception 未処理の例外 + + + Couldn't multisig sign data: + + + + + Couldn't sign multisig transaction: + + Monero::UnsignedTransactionImpl @@ -124,281 +134,407 @@ Monero::WalletImpl - + payment id has invalid format, expected 16 or 64 character hex string: ペイメントIDのフォーマットは不正です。16文字または64文字の16進数の文字列が必要で: - + Failed to add short payment id: 短いペイメントIDの追加に失敗しました: - - + + daemon is busy. Please try again later. デーモンは忙しいです。後でもう一度試してください。 - - + + no connection to daemon. Please make sure daemon is running. デーモンの接続が確立ありません。デーモンが実行中になっていることを確認してください。 - - + + RPC error: RPCエラー: - - + + not enough outputs for specified ring size 指定したリングサイズのアウトプットが不十分です - - + + found outputs to use 使うためにアウトプットを見つかれました - + Please sweep unmixable outputs. ミックス不能なアウトプットをスイープしてください。 - - failed to get random outputs to mix - ランダムなアウトプットをミックスすることに失敗しました - - - - + + not enough money to transfer, available only %s, sent amount %s 振替でMoneroを受け取ることできません。利用可能な金額: %s, 取引の金額: %s - + failed to parse address アドレスの解析に失敗しました - + failed to parse secret spend key 秘密なスペンドキーの解析に失敗しました - - No view key supplied, cancelled - ビューキーをもらいませんでしたのでキャンセルしました - - - + failed to parse secret view key 秘密なビューキーの解析に失敗しました - + failed to verify secret spend key 秘密なスペンドキーの検証に失敗しました - + spend key does not match address スペンドキーがアドレスと一致しませんでした - + failed to verify secret view key 秘密なビューキーの検証に失敗しました - + view key does not match address ビューキーがアドレスと一致しませんでした - + + failed to generate new wallet: 新しいウォレットの生成に失敗しました: - + Failed to send import wallet request インポートウォレットリクエストの送信に失敗しました - + Failed to load unsigned transactions 未署名の取引を読み込めませんでした - + Failed to load transaction from file ファイルからの取引のロードに失敗しました - + Wallet is view only 閲覧専用ウォレットです - + failed to save file ファイルを保存できませんでした - + Key images can only be imported with a trusted daemon 信頼できるデーモンしかでキーイメージをインポートしません - + Failed to import key images: キーイメージをインポートできませんでした: - + Failed to get subaddress label: サブアドレスラベルを取得できませんでした: - + Failed to set subaddress label: サブアドレスラベルをセットできませんでした: - - failed to get random outputs to mix: %s - ランダムなアウトプットをミックスすることに失敗しました: %s + + Neither view key nor spend key supplied, cancelled + - - + + Electrum seed is empty + + + + + Electrum-style word list failed verification + Electrumな単語表の検証に失敗しました + + + + Failed to get multisig info: + + + + + + Failed to make multisig: + + + + + Failed to finalize multisig wallet creation + + + + + Failed to finalize multisig wallet creation: + + + + + Failed to export multisig images: + + + + + Failed to parse imported multisig images + + + + + Failed to import multisig images: + + + + + Failed to check for partial multisig key images: + + + + + Failed to restore multisig transaction: + + + + + Invalid destination address + 不正な宛先アドレス + + + + failed to get outputs to mix: %s + + + + + not enough money to transfer, overall balance only %s, sent amount %s 振替でMoneroを受け取ることできません。利用可能な金額: %s, 取引の金額: %s - - + + not enough money to transfer, available only %s, transaction amount %s = %s + %s (fee) 取引は無理です。利用可能な金額 %s、 取引の金額 %s = %s + %s (手数料) - - + + output amount アウトプットの金額 - - + + transaction was not constructed 取引を作りませんでした - - + + transaction %s was rejected by daemon with status: 取引 %s がデーモンによって拒否しました。ステータス: - - + + one of destinations is zero 宛先の1つはゼロです - - + + failed to find a suitable way to split transactions 取引を分割する適切な方法を見つけることができませんでした - - + + unknown transfer error: 不明な転送エラー: - - + + internal error: 内部エラー: - - + + unexpected error: 予期せぬエラー: - - + + unknown error 不明なエラー - - - - - - + + failed to get outputs to mix + + + + + + + + + + Failed to parse txid txidの解析に失敗しました - + no tx keys found for this txid このtxidのためにtxキーを見つかれませんでした - - + + Failed to parse tx key txキーの解析に失敗しました - - - - + + + + Failed to parse address アドレスの解析に失敗しました - + Address must not be a subaddress アドレスはサブアドレスであってはならないです - + + The wallet must be in multisig ready state + + + + + Given string is not a key + + + + Rescan spent can only be used with a trusted daemon 信頼できるデーモンしかで再スキャンしません + + + Invalid output: + + + + + Failed to mark outputs as spent + + + + + + Failed to parse output amount + + + + + + Failed to parse output offset + + + + + Failed to mark output as spent + + + + + Failed to mark output as unspent + + + + + + Failed to parse key image + + + + + Failed to get ring + + + + + Failed to get rings + + + + + Failed to set ring + + Wallet - + Failed to parse address アドレスの解析に失敗しました - + Failed to parse key キーの解析に失敗しました - + failed to verify key キーの検証に失敗しました - + key does not match address キーがアドレスと一致しませんでした @@ -406,12 +542,12 @@ command_line - + yes はい - + no いいえ @@ -449,18 +585,18 @@ は暗号化されていない外部接続をできますがSSHトンネルやSSLプロキシの方がいいです。これでオーバーライド -- - + Username specified with -- このRPCサーバのユーザー名につて -- - - + + cannot be empty 入力する必要があります - + requires RPC server password -- のRPCサーバのパスワードありません -- @@ -468,1133 +604,992 @@ cryptonote::simple_wallet - + Commands: - + failed to read wallet password - + invalid password 不正なパスワード - + set seed: needs an argument. available options: language - + set: unrecognized argument(s) - + wallet file path not valid: - + Attempting to generate or restore wallet, but specified file(s) exist. Exiting to not risk overwriting. - - usage: payment_id - - - - + needs an argument - - - - - - - - - - + + + + + + + + + + + + + 0 or 1 0や1 - - 0, 1, 2, 3, or 4 - 0、1、2、3、や 4 - - - - + + + unsigned integer 符号無しの整数 - - NOTE: the following 25 words can be used to recover access to your wallet. Write them down and store them somewhere safe and secure. Please do not store them in your email or on file storage services outside of your immediate control. - - - - - + --restore-deterministic-wallet uses --generate-new-wallet, not --wallet-file - + specify a recovery parameter with the --electrum-seed="words list here" - + specify a wallet path with --generate-new-wallet (not --wallet-file) - + wallet failed to connect to daemon: - + Daemon uses a different RPC major version (%u) than the wallet (%u): %s. Either update one of them, or use --allow-mismatched-daemon-version. - + List of available languages for your wallet's seed: - + Enter the number corresponding to the language of your choice: - + You had been using a deprecated version of the wallet. Please use the new seed that we provide. - - + + Generated new wallet: - - - + + + + failed to generate new wallet: 新しいウォレットの生成に失敗しました: - + Opened watch-only wallet - + Opened wallet - + You had been using a deprecated version of the wallet. Please proceed to upgrade your wallet. - + You had been using a deprecated version of the wallet. Your wallet file format is being upgraded now. - + failed to load wallet: ウォレットをロードできませんでした: - + Use the "help" command to see the list of available commands. - + Wallet data saved - + Mining started in daemon - + mining has NOT been started: - + Mining stopped in daemon - + mining has NOT been stopped: - + Blockchain saved - - - + + Height - - transaction - 取引 - - - + spent - - unsupported transaction format - - - - + Starting refresh... - + Refresh done, blocks received: - - + payment id has invalid format, expected 16 or 64 character hex string: - + ペイメントIDのフォーマットは不正です。16文字または64文字の16進数の文字列が必要で: - + bad locked_blocks parameter: - - - + + a single transaction cannot use more than one payment id: - - - - + + + + failed to set up payment id, though it was decoded correctly - - - - - - - - + + + + ring size %u is too large, maximum is %u + + + + + + Unencrypted payment IDs are bad for privacy: ask the recipient to use subaddresses instead + + + + + payment id failed to encode + + + + + + Locked blocks too high, max 1000000 (˜4 yrs) + + + + + failed to parse short payment ID from URI + + + + + + Invalid last argument: + + + + + a single transaction cannot use more than one payment id + + + + + failed to parse payment id, though it was detected + + + + + + + + + + + transaction cancelled. - - + + Is this okay anyway? (Y/Yes/N/No): - + There is currently a %u block backlog at that fee level. Is this okay? (Y/Yes/N/No): - + Failed to check for backlog: - - + + Transaction 取引 - - + + Spending from address index %d - - + + WARNING: Outputs of multiple addresses are being used together, which might potentially compromise your privacy. - + Sending %s. - + Your transaction needs to be split into %llu transactions. This will result in a transaction fee being applied to each transaction, for a total fee of %s - + The transaction fee is %s - + , of which %s is dust from change - + . - + A total of %s from dust change will be sent to dust address - + . This transaction will unlock on block %llu, in approximately %s days (assuming 2 minutes per block) - - - - - - - - - Failed to write transaction(s) to file + + Unsigned transaction(s) successfully written to MMS - - - - - - - - + + + + + + + + + Failed to write transaction(s) to file + 取引をファイルに書き込めませんでした + + + + + + + + + + Unsigned transaction(s) successfully written to file: - + + + Failed to cold sign transaction with HW wallet + + + + No unmixable outputs found - + + Not enough money in unlocked balance + + + + + Discarding %s of unmixable outputs that cannot be spent, which can be undone by "rescan_spent". Is this okay? (Y/Yes/N/No): + + + + No address given - + + missing lockedblocks parameter + + + + + bad locked_blocks parameter + + + + + + Failed to parse number of outputs + + + + + + Amount of outputs should be greater than 0 + + + + failed to parse Payment ID - - usage: sweep_single [<priority>] [<ring_size>] <key_image> <address> [<payment_id>] - - - - + failed to parse key image キーイメージの解析に失敗しました - + No outputs found - + Multiple transactions are created, which is not supposed to happen - + The transaction uses multiple or no inputs, which is not supposed to happen - + missing threshold amount - + invalid amount threshold - - donations are not enabled on the testnet - - - - - usage: donate [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <amount> [<payment_id>] - - - - + Claimed change does not go to a paid address - + 請求したお釣りはもうお金に送ったアドレス送りません - + Claimed change is larger than payment to the change address - + 請求したお釣りはお釣りのアドレスに送ったペイメントより大きいです - + sending %s to %s %s を %s に送ってます - + dummy output(s) - + with no destinations 目的地なし - + Loaded %lu transactions, for %s, fee %s, %s, %s, with min ring size %lu, %s. %sIs this okay? (Y/Yes/N/No): - 取引は %lu ロードした、 %s に、%s のの手数料、 %s 、 %s 、最小リングサイズ %lu 、%s。これは大丈夫ですか? はい (Y) いいえ (N): + 取引は %lu ロードした、 %s に、%s のの手数料、 %s 、 %s 、最小リングサイズ %lu 、%s。これは大丈夫ですか? はい (Y) いいえ (N): - + This is a multisig wallet, it can only sign with sign_multisig - - usage: sign_transfer [export] - - - - + Failed to sign transaction 取引を署名できませんでした - + Failed to sign transaction: 取引を署名できませんでした: - + Transaction raw hex data exported to - + Failed to load transaction from file ファイルからの取引のロードに失敗しました - - + + RPC error: RPCエラー: - + wallet is watch-only and has no spend key - - - + + + + Your original password was incorrect. - + Error with wallet rewrite: - - priority must be 0, 1, 2, 3, or 4 - - - - - - priority must be 0, 1, 2, 3, or 4 - - - - + invalid unit 不正なユニット - - + + invalid count: must be an unsigned integer - + invalid value 不正な金額 - - usage: set_log <log_level_number_0-4> | <categories> - - - - + (Y/Yes/N/No): - (はい (Y) いいえ (N)): + (はい (Y) いいえ (N)): - - + + bad m_restore_height parameter: - + date format must be YYYY-MM-DD - + Restore height is: - - + + + Is this okay? (Y/Yes/N/No): - これは大丈夫ですか? (はい (Y) いいえ (N)): + これは大丈夫ですか? (はい (Y) いいえ (N)): - + Daemon is local, assuming trusted デーモンはローカルです。信頼できるデーモン予期してます - + Password for new watch-only wallet - - invalid arguments. Please use start_mining [<number_of_threads>] [do_bg_mining] [ignore_battery], <number_of_threads> should be from 1 to - - - - + internal error: 内部エラー: - - - + + + unexpected error: 予期せぬエラー: - - - - - - - - - + + + + + + + + + + + unknown error 不明なエラー - + refresh failed: - + Blocks received: - + unlocked balance: ロック解除された残高: - - - + + + + amount 金額 - + false - + Unknown command: 未知のコマンド: - + Command usage: コマンドの使用: - + Command description: コマンドの記述: - + wallet is multisig but not yet finalized - - Enter optional seed encryption passphrase, empty to see raw seed - - - - + Failed to retrieve seed - + wallet is multisig and has no seed - - Cannot connect to daemon - - - - - Current fee is %s monero per kB - - - - + Error: failed to estimate backlog array size: - + Error: bad estimated backlog array size - + (current) - + %u block (%u minutes) backlog at priority %u%s - + %u to %u block (%u to %u minutes) backlog at priority %u - + No backlog at priority - - + + This wallet is already multisig - - + + wallet is watch-only and cannot be made multisig - - + + This wallet has been used before, please use a new wallet to create a multisig wallet - - Your password is incorrect. - - - - + Send this multisig info to all other participants, then use make_multisig <threshold> <info1> [<info2>...] with others' multisig info - + This includes the PRIVATE view key, so needs to be disclosed only to that multisig wallet's participants - - usage: make_multisig <threshold> <multisiginfo1> [<multisiginfo2>...] - - - - + Invalid threshold - + + Another step is needed - - Send this multisig info to all other participants, then use finalize_multisig <info1> [<info2>...] with others' multisig info - - - - + Error creating multisig: - + Error creating multisig: new wallet is not multisig - + multisig address: マルチサインアドレス: - - - + + + + This wallet is not multisig これはマルチシッグウォレットではありません - + + This wallet is already finalized - - usage: finalize_multisig <multisiginfo1> [<multisiginfo2>...] - - - - + Failed to finalize multisig - + Failed to finalize multisig: - - - - - + + + + + This multisig wallet is not yet finalized - - usage: export_multisig_info <filename> - - - - + Error exporting multisig info: - + Multisig info exported to - - usage: import_multisig_info <filename1> [<filename2>...] - one for each other participant - - - - + Multisig info imported - + Failed to import multisig info: - + Failed to update spent status after importing multisig info: - + Untrusted daemon, spent status may be incorrect. Use a trusted daemon and run "rescan_spent" - - - + + + This is not a multisig wallet これはマルチシッグウォレットではありません - - usage: sign_multisig <filename> - - - - + + Failed to sign multisig transaction - + Multisig error: マルチサインエラー: - + Failed to sign multisig transaction: - + It may be relayed to the network with submit_multisig - - usage: submit_multisig <filename> - - - - - + + Failed to load multisig transaction from file - - + + Multisig transaction signed by only %u signers, needs %u more signatures - - + + Transaction successfully submitted, transaction - - + + You can check its status by using the `show_transfers` command. - - usage: export_raw_multisig <filename> - - - - + Failed to export multisig transaction to file - + Saved exported multisig transaction file(s): - - - + + + ring size must be an integer >= - + could not change default ring size - + + Invalid height - - start_mining [<number_of_threads>] [bg_mining] [ignore_battery] - - - - + Start mining in the daemon (bg_mining and ignore_battery are optional booleans). - + Stop mining in the daemon. - - set_daemon <host>[:<port>] - - - - + Set another daemon to connect to. - + Save the current blockchain data. - + Synchronize the transactions and balance. - - balance [detail] - - - - + Show the wallet's balance of the currently selected account. - - incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] - - - - - Show the incoming transfers, all or filtered by availability and address index. - -Output format: -Amount, Spent("T"|"F"), "locked"|"unlocked", RingCT, Global Index, Transaction Hash, Address Index, [Public Key, Key Image] - - - - - payments <PID_1> [<PID_2> ... <PID_N>] - - - - + Show the payments for the given payment IDs. - + Show the blockchain height. - - transfer_original [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> <amount> [<payment_id>] - - - - - Transfer <amount> to <address> using an older transaction building algorithm. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding <address_2> <amount_2> etcetera (before the payment ID, if it's included) - - - - - transfer [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> <amount> [<payment_id>] - - - - - Transfer <amount> to <address>. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding <address_2> <amount_2> etcetera (before the payment ID, if it's included) - - - - - locked_transfer [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <addr> <amount> <lockblocks> [<payment_id>] - - - - - Transfer <amount> to <address> and lock it for <lockblocks> (max. 1000000). If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding <address_2> <amount_2> etcetera (before the payment ID, if it's included) - - - - + Send all unmixable outputs to yourself with ring_size 1 - - sweep_all [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> [<payment_id>] - - - - - Send all unlocked balance to an address. If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. - - - - - sweep_below <amount_threshold> [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> [<payment_id>] - - - - + Send all unlocked outputs below the threshold to an address. - - sweep_single [<priority>] [<ring_size>] <key_image> <address> [<payment_id>] - - - - + Send a single output of the given key image to an address without change. - - donate [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <amount> [<payment_id>] - - - - + Donate <amount> to the development team (donate.getmonero.org). - - sign_transfer <file> - - - - - Sign a transaction from a <file>. - - - - + Submit a signed transaction from a file. - - set_log <level>|{+,-,}<categories> - - - - + Change the current log detail (level must be <0-4>). - - account - account new <label text with white spaces allowed> - account switch <index> - account label <index> <label text with white spaces allowed> - account tag <tag_name> <account_index_1> [<account_index_2> ...] - account untag <account_index_1> [<account_index_2> ...] - account tag_description <tag_name> <description> - - - - + If no arguments are specified, the wallet shows all the existing accounts along with their balances. If the "new" argument is specified, the wallet creates a new account with its label initialized by the provided label text (which can be empty). If the "switch" argument is specified, the wallet switches to the account specified by <index>. @@ -1605,67 +1600,1177 @@ If the "tag_description" argument is specified, the tag <tag_name&g - - address [ new <label text with white spaces allowed> | all | <index_min> [<index_max>] | label <index> <label text with white spaces allowed>] - - - - + 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. - - integrated_address [<payment_id> | <address>] - - - - + 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 - - address_book [(add ((<address> [pid <id>])|<integrated address>) [<description possibly with whitespaces>])|(delete <index>)] - - - - + Print all entries in the address book, optionally adding/deleting an entry to/from it. - + Save the wallet data. - + Save a watch-only keys file. - + Display the private view key. - + Display the private spend key. - + Display the Electrum-style mnemonic seed - - set <option> [<value>] + + Display the encrypted Electrum-style mnemonic seed. - + + Rescan the blockchain for spent outputs. + + + + + Get the transaction key (r) for a given <txid>. + + + + + Check the amount going to <address> in <txid>. + + + + + Generate a signature proving funds sent to <address> in <txid>, optionally with a challenge string <message>, using either the transaction secret key (when <address> is not your wallet's address) or the view secret key (otherwise), which does not disclose the secret key. + + + + + Check the proof for funds going to <address> in <txid> with the challenge string <message> if any. + + + + + Generate a signature proving that you generated <txid> using the spend secret key, optionally with a challenge string <message>. + + + + + Check a signature proving that the signer generated <txid>, optionally with a challenge string <message>. + + + + + Generate a signature proving that you own at least this much, optionally with a challenge string <message>. +If 'all' is specified, you prove the entire sum of all of your existing accounts' balances. +Otherwise, you prove the reserve of the smallest possible amount above <amount> available in your current account. + + + + + Check a signature proving that the owner of <address> holds at least this much, optionally with a challenge string <message>. + + + + + Show the unspent outputs of a specified address within an optional amount range. + + + + + Set an arbitrary string note for a <txid>. + + + + + Get a string note for a txid. + + + + + Set an arbitrary description for the wallet. + + + + + Get the description of the wallet. + + + + + Show the wallet's status. + + + + + Show the wallet's information. + + + + + Sign the contents of a file. + + + + + Verify a signature on the contents of a file. + + + + + Import a signed key images list and verify their spent status. + + + + + Export a set of outputs owned by this wallet. + + + + + Import a set of outputs owned by this wallet. + + + + + Show information about a transfer to/from this address. + + + + + Change the wallet's password. + + + + + Generate a new random full size payment id. These will be unencrypted on the blockchain, see integrated_address for encrypted short payment ids. + + + + + Print the information about the current fee and transaction backlog. + + + + + Export data needed to create a multisig wallet + + + + + Turn this wallet into a multisig wallet + + + + + Turn this wallet into a multisig wallet, extra step for N-1/N wallets + + + + + Export multisig info for other participants + + + + + Import multisig info from other participants + + + + + Sign a multisig transaction from a file + + + + + Submit a signed multisig transaction from a file + + + + + Export a signed multisig transaction to a file + + + + + Show the help section or the documentation about a <command>. + + + + + integer >= + + + + + block height + + + + + No wallet found with that name. Confirm creation of new wallet named: + + + + + can't specify both --restore-deterministic-wallet or --restore-multisig-wallet and --non-deterministic + + + + + --restore-multisig-wallet uses --generate-new-wallet, not --wallet-file + + + + + specify a recovery parameter with the --electrum-seed="multisig seed here" + + + + + Multisig seed failed verification + + + + + + This address is a subaddress which cannot be used here. + + + + + Error: expected M/N, but got: + エラー: N/Mを欲しかったでもこれを貰いました: + + + + Error: expected N > 1 and N <= M, but got: + エラー: N > 1 と N <= M のこと欲しかったでもこれを貰いました: + + + + Error: M/N is currently unsupported. + + + + + Generating master wallet from %u of %u multisig wallet keys + + + + + failed to parse secret view key + 秘密なビューキーの解析に失敗しました + + + + failed to verify secret view key + 秘密なビューキーの検証に失敗しました + + + + Secret spend key (%u of %u): + + + + + Error: M/N is currently unsupported + + + + + Restore height + + + + + Still apply restore height? (Y/Yes/N/No): + + + + + Warning: using an untrusted daemon at %s, privacy will be lessened + + + + + Daemon either is not started or wrong port was passed. Please make sure daemon is running or change the daemon address using the 'set_daemon' command. + + + + + Your wallet has been generated! +To start synchronizing with the daemon, use the "refresh" command. +Use the "help" command to see the list of available commands. +Use "help <command>" to see a command's documentation. +Always use the "exit" command when closing monero-wallet-cli to save +your current session's state. Otherwise, you might need to synchronize +your wallet again (your wallet keys are NOT at risk in any case). + + + + + + failed to generate new mutlisig wallet + 新しいマルチシッグウォレットの生成に失敗しました + + + + Generated new %u/%u multisig wallet: + + + + + Opened %u/%u multisig wallet%s + + + + + Use "help <command>" to see a command's documentation. + + + + + + wallet is multisig and cannot save a watch-only version + + + + + Unexpected array length - Exited simple_wallet::set_daemon() + + + + + This does not seem to be a valid daemon URL. + + + + + + txid + txid + + + + + idx + idx + + + + (Some owned outputs have partial key images - import_multisig_info needed) + + + + + Currently selected account: [ + + + + + ] + ] + + + + Tag: + タグ: + + + + (No tag assigned) + + + + + Balance per address: + + + + + Address + アドレス + + + + + Balance + 残高 + + + + + Unlocked balance + ロック解除された残高 + + + + Outputs + アウトプット + + + + + + Label + ラベル + + + + %8u %6s %21s %21s %7u %21s + + + + + spent + + + + + global index + + + + + tx id + tx id + + + + + addr index + + + + + No incoming transfers + + + + + No incoming available transfers + + + + + No incoming unavailable transfers + + + + + payment + ペイメント + + + + transaction + 取引 + + + + height + + + + + unlock time + + + + + No payments with id + + + + + + + + failed to get blockchain height: + + + + + +Transaction %llu/%llu: txid=%s + + + + + +Input %llu/%llu: amount=%s + + + + + failed to get output: + + + + + output key's originating block height shouldn't be higher than the blockchain height + + + + + +Originating block heights: + + + + + +| + +| + + + + + | + + | + + + + + +Warning: Some input keys being spent are from + + + + + , which can break the anonymity of ring signature. Make sure this is intentional! + + + + + + + Ring size must not be 0 + + + + + + + ring size %u is too small, minimum is %u + + + + + wrong number of arguments + + + + + + + No payment id is included with this transaction. Is this okay? (Y/Yes/N/No): + + + + + + No outputs found, or daemon is not ready + + + + + Failed to parse donation address: + + + + + Donating %s %s to The Monero Project (donate.getmonero.org or %s). + + + + + Donating %s %s to %s. + + + + + + + failed to parse tx_key + + + + + Tx key successfully stored. + + + + + Failed to store tx key: + + + + + + block + + + + + usage: show_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] + + + + + usage: export_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] [output=<path>] + + + + + direction + + + + + timestamp + + + + + running balance + + + + + hash + + + + + payment ID + + + + + fee + + + + + destination + + + + + index + + + + + note + + + + + CSV exported to + + + + + Warning: this will lose any information which can not be recovered from the blockchain. + + + + + This includes destination addresses, tx secret keys, tx notes, etc + + + + + Rescan anyway ? (Y/Yes/N/No): + + + + + MMS received new message + + + + + Network type: + + + + + Testnet + + + + + Stagenet + + + + + Mainnet + + + + + + command only supported by HW wallet + + + + + hw wallet does not support cold KI sync + + + + + Please confirm the key image sync on the device + + + + + Key images synchronized to height + + + + + Running untrusted daemon, cannot determine which transaction output is spent. Use a trusted daemon with --trusted-daemon and run rescan_spent + + + + + spent, + + + + + unspent + + + + + Failed to import key images + + + + + Failed to import key images: + キーイメージをインポートできませんでした: + + + + Failed to reconnect device + + + + + Failed to reconnect device: + + + + + Transaction successfully saved to + + + + + + , txid + 、txid + + + + Failed to save transaction to + + + + + + Sweeping %s in %llu transactions for a total fee of %s. Is this okay? (Y/Yes/N/No): + + + + + + + Sweeping %s for a total fee of %s. Is this okay? (Y/Yes/N/No): + + + + + This is a watch only wallet + これは閲覧専用ウォレットです + + + + Double spend seen on the network: this transaction may or may not end up being mined + + + + + Transaction ID not found + + + + + true + + + + + failed to parse refresh type + + + + + + + + + + + + + + + + + + + + + + + + + + command not supported by HW wallet + + + + + + wallet is watch-only and has no seed + + + + + + wallet is non-deterministic and has no seed + + + + + Enter optional seed offset passphrase, empty to see raw seed + + + + + Incorrect password + + + + + Current fee is %s %s per %s + + + + + + Send this multisig info to all other participants, then use exchange_multisig_keys <info1> [<info2>...] with others' multisig info + + + + + Multisig wallet has been successfully created. Current wallet type: + + + + + Failed to perform multisig keys exchange: + + + + + Failed to load multisig transaction from MMS + + + + + + Invalid key image + + + + + Invalid txid + + + + + Key image either not spent, or spent with mixin 0 + + + + + Failed to get key image ring: + + + + + File doesn't exist + + + + + Invalid ring specification: + + + + + Invalid key image: + + + + + Invalid ring type, expected relative or abosolute: + + + + + + Error reading line: + + + + + Invalid ring: + + + + + Invalid relative ring: + + + + + Invalid absolute ring: + + + + + Failed to set ring for key image: + + + + + Continuing. + + + + + Missing absolute or relative keyword + + + + + + invalid index: must be a strictly positive unsigned integer + + + + + invalid index: indices wrap + + + + + invalid index: indices should be in strictly ascending order + + + + + failed to set ring + + + + + First line is not an amount + + + + + Invalid output: + + + + + Bad argument: + + + + + should be "add" + + + + + Failed to open file + + + + + Invalid output key, and file doesn't exist + + + + + Failed to mark output spent: + + + + + + Invalid output + + + + + Failed to mark output unspent: + + + + + Spent: + + + + + Not spent: + + + + + Failed to check whether output is spent: + + + + + Failed to save known rings: + + + + + Please confirm the transaction on the device + + + + + + wallet is watch-only and cannot transfer + + + + + + WARNING: this is a non default ring size, which may harm your privacy. Default is recommended. + + + + + WARNING: from v8, ring size will be fixed and this setting will be ignored. + + + + + + + priority must be either 0, 1, 2, 3, or 4, or one of: + + + + + could not change default priority + + + + + invalid argument: must be either 0/never, 1/action, or 2/encrypt/decrypt + + + + + Device name not specified + + + + + Device reconnect failed + + + + + Device reconnect failed: + + + + + Show the incoming transfers, all or filtered by availability and address index. + +Output format: +Amount, Spent("T"|"F"), "locked"|"unlocked", RingCT, Global Index, Transaction Hash, Address Index, [Public Key, Key Image] + + + + + Transfer <amount> to <address>. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) + + + + + Transfer <amount> to <address> and lock it for <lockblocks> (max. 1000000). If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) + + + + + Send all unlocked balance to an address and lock it for <lockblocks> (max. 1000000). If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. <priority> is the priority of the sweep. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. + + + + + Send all unlocked balance to an address. If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. If the parameter "outputs=<N>" is specified and N > 0, wallet splits the transaction into N even outputs. + + + + + Sign a transaction from a file. If the parameter "export_raw" is specified, transaction raw hex data suitable for the daemon RPC /sendrawtransaction is exported. + + + + Available options: seed language Set the wallet's seed language. @@ -1676,7 +2781,7 @@ If the "tag_description" argument is specified, the tag <tag_name&g store-tx-info <1|0> Whether to store outgoing tx info (destination address, payment ID, tx secret key) for future reference. default-ring-size <n> - Set the default ring size (default and minimum is 5). + Set the default ring size (obsolete). auto-refresh <1|0> Whether to automatically synchronize new blocks from the daemon. refresh-type <full|optimize-coinbase|no-coinbase|default> @@ -1684,7 +2789,7 @@ If the "tag_description" argument is specified, the tag <tag_name&g priority [0|1|2|3|4] Set the fee to default/unimportant/normal/elevated/priority. confirm-missing-payment-id <1|0> - ask-password <1|0> + ask-password <0|1|2 (or never|action|decrypt)> unit <monero|millinero|micronero|nanonero|piconero> Set the default monero (sub-)unit. min-outputs-count [n] @@ -1700,1825 +2805,1707 @@ If the "tag_description" argument is specified, the tag <tag_name&g refresh-from-block-height [n] Set the height before which to ignore blocks. auto-low-priority <1|0> - Whether to automatically use the low priority fee level when it's safe to do so. + Whether to automatically use the low priority fee level when it's safe to do so. + segregate-pre-fork-outputs <1|0> + Set this if you intend to spend outputs on both Monero AND a key reusing fork. + key-reuse-mitigation2 <1|0> + Set this if you are not sure whether you will spend on a key reusing Monero fork later. +subaddress-lookahead <major>:<minor> + Set the lookahead sizes for the subaddress hash table. + Set this if you are not sure whether you will spend on a key reusing Monero fork later. + segregation-height <n> + Set to the height of a key reusing fork you want to use, 0 to use default. - - Display the encrypted Electrum-style mnemonic seed. + + Set the transaction key (r) for a given <txid> in case the tx was made by some other device or 3rd party wallet. - - Rescan the blockchain for spent outputs. + + Show the incoming/outgoing transfers within an optional height range. + +Output format: +In or Coinbase: Block Number, "block"|"in", Time, Amount, Transaction Hash, Payment ID, Subaddress Index, "-", Note +Out: Block Number, "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Destinations, Input addresses**, "-", Note +Pool: "pool", "in", Time, Amount, Transaction Hash, Payment Id, Subaddress Index, "-", Note, Double Spend Note +Pending or Failed: "failed"|"pending", "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Input addresses**, "-", Note + +* Excluding change and fee. +** Set of address indices used as inputs in this transfer. - - get_tx_key <txid> + + export_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] [output=<filepath>] - - Get the transaction key (r) for a given <txid>. + + Export to CSV the incoming/outgoing transfers within an optional height range. - - check_tx_key <txid> <txkey> <address> + + Rescan the blockchain from scratch, losing any information which can not be recovered from the blockchain itself. - - Check the amount going to <address> in <txid>. + + Export a signed set of key images to a <filename>. - - get_tx_proof <txid> <address> [<message>] + + Synchronizes key images with the hw wallet. - - Generate a signature proving funds sent to <address> in <txid>, optionally with a challenge string <message>, using either the transaction secret key (when <address> is not your wallet's address) or the view secret key (otherwise), which does not disclose the secret key. + + Attempts to reconnect HW wallet. - - check_tx_proof <txid> <address> <signature_file> [<message>] - - - - - Check the proof for funds going to <address> in <txid> with the challenge string <message> if any. - - - - - get_spend_proof <txid> [<message>] - - - - - Generate a signature proving that you generated <txid> using the spend secret key, optionally with a challenge string <message>. - - - - - check_spend_proof <txid> <signature_file> [<message>] - - - - - Check a signature proving that the signer generated <txid>, optionally with a challenge string <message>. - - - - - get_reserve_proof (all|<amount>) [<message>] - - - - - Generate a signature proving that you own at least this much, optionally with a challenge string <message>. -If 'all' is specified, you prove the entire sum of all of your existing accounts' balances. -Otherwise, you prove the reserve of the smallest possible amount above <amount> available in your current account. - - - - - check_reserve_proof <address> <signature_file> [<message>] - - - - - Check a signature proving that the owner of <address> holds at least this much, optionally with a challenge string <message>. - - - - - show_transfers [in|out|pending|failed|pool] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] - - - - - Show the incoming/outgoing transfers within an optional height range. - - - - - unspent_outputs [index=<N1>[,<N2>,...]] [<min_amount> [<max_amount>]] - - - - - Show the unspent outputs of a specified address within an optional amount range. - - - - - Rescan the blockchain from scratch. - - - - - set_tx_note <txid> [free text note] - - - - - Set an arbitrary string note for a <txid>. - - - - - get_tx_note <txid> - - - - - Get a string note for a txid. - - - - - set_description [free text note] - - - - - Set an arbitrary description for the wallet. - - - - - Get the description of the wallet. - - - - - Show the wallet's status. - - - - - Show the wallet's information. - - - - - sign <file> - - - - - Sign the contents of a file. - - - - - verify <filename> <address> <signature> - - - - - Verify a signature on the contents of a file. - - - - - export_key_images <file> - - - - - Export a signed set of key images to a <file>. - - - - - import_key_images <file> - - - - - Import a signed key images list and verify their spent status. - - - - - export_outputs <file> - - - - - Export a set of outputs owned by this wallet. - - - - - import_outputs <file> - - - - - Import a set of outputs owned by this wallet. - - - - - show_transfer <txid> - - - - - Show information about a transfer to/from this address. - - - - - Change the wallet's password. - - - - - Generate a new random full size payment id. These will be unencrypted on the blockchain, see integrated_address for encrypted short payment ids. - - - - - Print the information about the current fee and transaction backlog. - - - - - Export data needed to create a multisig wallet - - - - - make_multisig <threshold> <string1> [<string>...] - - - - - Turn this wallet into a multisig wallet - - - - - finalize_multisig <string> [<string>...] - - - - - Turn this wallet into a multisig wallet, extra step for N-1/N wallets - - - - - export_multisig_info <filename> - - - - - Export multisig info for other participants - - - - - import_multisig_info <filename> [<filename>...] - - - - - Import multisig info from other participants - - - - - sign_multisig <filename> - - - - - Sign a multisig transaction from a file - - - - - submit_multisig <filename> - - - - - Submit a signed multisig transaction from a file - - - - - export_raw_multisig_tx <filename> - - - - - Export a signed multisig transaction to a file - - - - - help [<command>] - - - - - Show the help section or the documentation about a <command>. - - - - - integer >= - - - - - block height - - - - - No wallet found with that name. Confirm creation of new wallet named: - - - - - can't specify more than one of --generate-new-wallet="wallet_name", --wallet-file="wallet_name", --generate-from-view-key="wallet_name", --generate-from-spend-key="wallet_name", --generate-from-keys="wallet_name", --generate-from-multisig-keys="wallet_name" and --generate-from-json="jsonfilename" - - - - - can't specify both --restore-deterministic-wallet or --restore-multisig-wallet and --non-deterministic - - - - - --restore-multisig-wallet uses --generate-new-wallet, not --wallet-file - - - - - specify a recovery parameter with the --electrum-seed="multisig seed here" - - - - - Multisig seed failed verification - - - - - Enter seed encryption passphrase, empty if none - - - - - - This address is a subaddress which cannot be used here. - - - - - Error: expected M/N, but got: - エラー: N/Mを欲しかったでもこれを貰いました: - - - - Error: expected N > 1 and N <= M, but got: - エラー: N > 1 と N <= M のこと欲しかったでもこれを貰いました: - - - - Error: M/N is currently unsupported. - - - - - Generating master wallet from %u of %u multisig wallet keys - - - - - failed to parse secret view key - 秘密なビューキーの解析に失敗しました - - - - failed to verify secret view key - 秘密なビューキーの検証に失敗しました - - - - Secret spend key (%u of %u): - - - - - Error: M/N is currently unsupported - - - - - Restore height - - - - - Still apply restore height? (Y/Yes/N/No): - - - - - Warning: using an untrusted daemon at %s, privacy will be lessened - - - - - Daemon either is not started or wrong port was passed. Please make sure daemon is running or change the daemon address using the 'set_daemon' command. - - - - - Your wallet has been generated! -To start synchronizing with the daemon, use the "refresh" command. -Use the "help" command to see the list of available commands. -Use "help <command>" to see a command's documentation. -Always use the "exit" command when closing monero-wallet-cli to save -your current session's state. Otherwise, you might need to synchronize -your wallet again (your wallet keys are NOT at risk in any case). - - - - - - failed to generate new mutlisig wallet - 新しいマルチシッグウォレットの生成に失敗しました - - - - Generated new %u/%u multisig wallet: + + Performs extra multisig keys exchange rounds. Needed for arbitrary M/N multisig wallets - Opened %u/%u multisig wallet%s + Interface with the MMS (Multisig Messaging System) +<subcommand> is one of: + init, info, signer, list, next, sync, transfer, delete, send, receive, export, note, show, set, help + send_signer_config, start_auto_config, stop_auto_config, auto_config +Get help about a subcommand with: help mms <subcommand>, or mms help <subcommand> + + + + + Initialize and configure the MMS for M/N = number of required signers/number of authorized signers multisig + + + + + Display current MMS configuration + + + + + Set or modify authorized signer info (single-word label, transport address, Monero address), or list all signers + + + + + List all messages + + + + + Evaluate the next possible multisig-related action(s) according to wallet state, and execute or offer for choice +By using 'sync' processing of waiting messages with multisig sync info can be forced regardless of wallet state + + + + + Force generation of multisig sync info regardless of wallet state, to recover from special situations like "stale data" errors + + + + + Initiate transfer with MMS support; arguments identical to normal 'transfer' command arguments, for info see there + + + + + Delete a single message by giving its id, or delete all messages by using 'all' + + + + + Send a single message by giving its id, or send all waiting messages + + + + + Check right away for new messages to receive + + + + + Write the content of a message to a file "mms_message_content" - Use "help <command>" to see a command's documentation. - + Send a one-line message to an authorized signer, identified by its label, or show any waiting unread notes - - wallet is multisig and cannot save a watch-only version + + Show detailed info about a single message - - missing daemon URL argument + + Available options: + auto-send <1|0> + Whether to automatically send newly generated messages right away. + - - Unexpected array length - Exited simple_wallet::set_daemon() + + Send completed signer config to all other authorized signers - - This does not seem to be a valid daemon URL. + + Start auto-config at the auto-config manager's wallet by issuing auto-config tokens and optionally set others' labels - - - txid - txid - - - - - idx - idx - - - - (Some owned outputs have partial key images - import_multisig_info needed) + + Delete any auto-config tokens and abort a auto-config process - - Currently selected account: [ + + Start auto-config by using the token received from the auto-config manager - - ] - ] - - - - Tag: - タグ: - - - - (No tag assigned) + + Print the ring(s) used to spend a given key image or transaction (if the ring size is > 1) + +Output format: +Key Image, "absolute", list of rings - - Balance per address: + + Set the ring used for a given key image, so it can be reused in a fork - - Address - アドレス - - - - - Balance - 残高 - - - - - Unlocked balance - ロック解除された残高 - - - - Outputs - アウトプット - - - - - Label - ラベル - - - - %8u %6s %21s %21s %7u %21s + + Save known rings to the shared rings database - - usage: balance [detail] + + Mark output(s) as spent so they never get selected as fake outputs in a ring - - - usage: incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] + + Marks an output as unspent so it may get selected as a fake output in a ring - - spent + + Checks whether an output is marked as spent - - global index + + Returns version information - - tx id - tx id - - - - - addr index - - - - - No incoming transfers - - - - - No incoming available transfers - - - - - No incoming unavailable transfers - - - - - expected at least one payment ID - - - - - payment - ペイメント - - - - transaction - 取引 - - - - height - - - - - unlock time - - - - - No payments with id - - - - - - - failed to get blockchain height: - - - - - - - - - failed to connect to the daemon - - - - - -Transaction %llu/%llu: txid=%s - - - - - -Input %llu/%llu: amount=%s - - - - - failed to get output: - - - - - output key's originating block height shouldn't be higher than the blockchain height - - - - - -Originating block heights: - - - - - -| - -| - - - - - | - - | - - - - - -Warning: Some input keys being spent are from - - - - - , which can break the anonymity of ring signature. Make sure this is intentional! - - - - - - Ring size must not be 0 - - - - - - ring size %u is too small, minimum is %u - - - - - wrong number of arguments - - - - - - - No payment id is included with this transaction. Is this okay? (Y/Yes/N/No): - - - - - - No outputs found, or daemon is not ready - - - - - Transaction successfully saved to - - - - - - , txid - 、txid - - - - Failed to save transaction to - - - - - - Sweeping %s in %llu transactions for a total fee of %s. Is this okay? (Y/Yes/N/No): - - - - - - - Sweeping %s for a total fee of %s. Is this okay? (Y/Yes/N/No): - - - - - Donating - - - - - This is a watch only wallet - これは閲覧専用ウォレットです - - - - usage: show_transfer <txid> - - - - - Double spend seen on the network: this transaction may or may not end up being mined - - - - - Transaction ID not found - - - - - true - - - - - failed to parse refresh type - - - - - - wallet is watch-only and has no seed - - - - - - wallet is non-deterministic and has no seed - - - - - - wallet is watch-only and cannot transfer - - - - - could not change default priority - - - - + 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) - + + 0, 1, 2, 3, or 4, or one of + + + + + 0|1|2 (or never|action|decrypt) + + + + monero, millinero, micronero, nanonero, piconero - + + <major>:<minor> + + + + + <device_name[:device_spec]> + + + + + wrong number range, use: %s + + + + Wallet name not valid. Please try again or use Ctrl-C to quit. - + Wallet and key files found, loading... - + Key file found but not wallet file. Regenerating... - + Key file not found. Failed to open wallet: - + Generating new wallet... 新しいウォレットを生じてます... - + + NOTE: the following %s can be used to recover access to your wallet. Write them down and store them somewhere safe and secure. Please do not store them in your email or on file storage services outside of your immediate control. + + + + + + string + + + + + 25 words + + + + + Can't specify more than one of --testnet and --stagenet + + + + + can't specify more than one of --generate-new-wallet="wallet_name", --wallet-file="wallet_name", --generate-from-view-key="wallet_name", --generate-from-spend-key="wallet_name", --generate-from-keys="wallet_name", --generate-from-multisig-keys="wallet_name", --generate-from-json="jsonfilename" and --generate-from-device="wallet_name" + + + + Electrum-style word list failed verification Electrumな単語表の検証に失敗しました - - - - - - - - - - + + Enter seed offset passphrase, empty if none + + + + + + + + + + + + + No data supplied, cancelled データをもらいませんでしたのでキャンセルしました - - - - - - - - - - - - + + + + + + + + + + + + failed to parse address アドレスの解析に失敗しました - - + + failed to parse view key secret key 秘密なビューキーの解析に失敗しました - - + + failed to verify view key secret key 秘密なビューキーの検証に失敗しました - - - + + + view key does not match standard address ビューキーが一般的なアドレスと一致しませんでした - - - - - + + + + + + account creation failed - - - + + + failed to parse spend key secret key 秘密なスペンドキーの解析に失敗しました - - + + failed to verify spend key secret key 秘密なスペンドキーの検証に失敗しました - - + + spend key does not match standard address スペンドキーが一般的なアドレスと一致しませんでした - + + No restore height is specified. + + + + + Assumed you are creating a new account, restore will be done from current estimated blockchain height. + + + + + Use --restore-height if you want to restore an already setup account from a specific height + + + + + account creation aborted + + + + + can't specify --subaddress-lookahead and --wallet-file at the same time + + + + failed to open account - - - - - + + + + + wallet is null - - + + Failed to initialize ring database: privacy enhancing features will be inactive + + + + + If your display freezes, exit blind with ^C, then run again with --use-english-language-names + + + + + invalid language choice entered. Please try again. - + View key: ビューキー: - + + Generated new wallet on hw device: + + + + + Key file not found. Failed to open wallet + + + + You may want to remove the file "%s" and try again - + failed to deinitialize wallet - - - + + Watch only wallet saved as: + + + + + Failed to save watch only wallet: + + + + + + this command requires a trusted daemon. Enable with --trusted-daemon - + + Expected trusted or untrusted, got + + + + + trusted + + + + + untrusted + + + + blockchain can't be saved: - - + + NOTE: this transaction uses an encrypted payment ID: consider using subaddresses instead + + + + + WARNING: this transaction uses an unencrypted payment ID: consider using subaddresses instead + + + + + Password needed (%s) - use the refresh command + + + + + Enter password + + + + + Device requires attention + + + + + Enter device PIN + + + + + Failed to read device PIN + + + + + Please enter the device passphrase on the device + + + + + Enter device passphrase + + + + + Failed to read device passphrase + + + + + The first refresh has finished for the HW-based wallet with received money. hw_key_images_sync is needed. + + + + + Do you want to do it now? (Y/Yes/N/No): + + + + + hw_key_images_sync skipped. Run command manually before a transfer. + + + + + daemon is busy. Please try again later. デーモンは忙しいです。後でもう一度試してください。 - - + + no connection to daemon. Please make sure daemon is running. デーモンの接続が確立ありません。デーモンが実行中になっていることを確認してください。 - + refresh error: - + + (Some owned outputs have missing key images - import_key_images needed) + + + + Balance: 残高: - + + Invalid keyword: + + + + pubkey - + key image キーイメージ - - + + + unlocked - + ringct ringct - + + Heights: + + + + T T - + F F - + locked - + RingCT RingCT - + - - - + payment ID has invalid format, expected 16 or 64 character hex string: - + failed to get spent status - + + failed to find construction data for tx input + + + + the same transaction 同じ取引 - + blocks that are temporally very close - - Locked blocks too high, max 1000000 (˜4 yrs) + + (Y/Yes/N/No): - - + + Choose processing: + + + + + Sign tx + + + + + Send the tx for submission to + + + + + Send the tx for signing to + + + + + Submit tx + + + + + unknown + + + + + Choice: + + + + + Wrong choice + + + + + Id + + + + + I/O + + + + + Authorized Signer + + + + + Message Type + + + + + Height + + + + + R + + + + + Message State + + + + + Since + + + + + ago + + + + + # + + + + + Transport Address + + + + + Auto-Config Token + + + + + Monero Address + + + + + + + <not set> + + + + + Message + + + + + In/out: + + + + + State: + + + + + %s since %s, %s ago + + + + + Sent: Never + + + + + Sent: %s, %s ago + + + + + Authorized signer: + + + + + Content size: + + + + + bytes + + + + + Content: + + + + + (binary data) + + + + + Send these messages now? + + + + + Queued for sending. + + + + + Invalid message id + + + + + usage: mms init <required_signers>/<authorized_signers> <own_label> <own_transport_address> + + + + + The MMS is already initialized. Re-initialize by deleting all signer info and messages? + + + + + Error in the number of required signers and/or authorized signers + + + + + The MMS is not active. + + + + + Invalid signer number + + + + + mms signer [<number> <label> [<transport_address> [<monero_address>]]] + + + + + Invalid Monero address + + + + + Wallet state does not allow changing Monero addresses anymore + + + + + Usage: mms list + + + + + Usage: mms next [sync] + + + + + No next step: + + + + + prepare_multisig + + + + + make_multisig + + + + + exchange_multisig_keys + + + + + + export_multisig_info + + + + + import_multisig_info + + + + + sign_multisig + + + + + submit_multisig + + + + + Send tx + + + + + Process signer config + + + + + Replace current signer config with the one displayed above? + + + + + Process auto config data + + + + + Nothing ready to process + + + + + Usage: mms sync + + + + + Usage: mms delete (<message_id> | all) + + + + + Delete all messages? + + + + + Usage: mms send [<message_id>] + + + + + Usage: mms receive + + + + + Usage: mms export <message_id> + + + + + Message content saved to: + + + + + Failed to to save message content + + + + + Usage: mms note [<label> <text>] + + + + + No signer found with label + + + + + Usage: mms show <message_id> + + + + + Usage: mms set <option_name> [<option_value>] + + + + + Wrong option value + + + + + Auto-send is on + + + + + Auto-send is off + + + + + Unknown option + + + + + Usage: mms help [<subcommand>] + + + + + Usage: mms send_signer_config + + + + + Signer config not yet complete + + + + + Usage: mms start_auto_config [<label> <label> ...] + + + + + There are signers without a label set. Complete labels before auto-config or specify them as parameters here. + + + + + Auto-config is already running. Cancel and restart? + + + + + Usage: mms stop_auto_config + + + + + Delete any auto-config tokens and stop auto-config? + + + + + Usage: mms auto_config <auto_config_token> + + + + + Invalid auto-config token + + + + + Auto-config already running. Cancel and restart? + + + + + The MMS is not active. Activate using the "mms init" command + + + + + Invalid MMS subcommand + + + + + + Error in MMS command: + + + + + Good signature - - - + + + Bad signature - - usage: integrated_address [payment ID] - - - - + Standard address: - + failed to parse payment ID or address - - usage: address_book [(add (<address> [pid <long or short payment id>])|<integrated address> [<description possibly with whitespaces>])|(delete <index>)] - - - - + failed to parse payment ID - + failed to parse index - + Address book is empty. - + Index: インデックス: - - + + Address: アドレス: - + Payment ID: ペイメントID: - - + + Description: 記述: - - usage: set_tx_note [txid] free text note - - - - - usage: get_tx_note [txid] - - - - - usage: sign <filename> - - - - + wallet is watch-only and cannot sign - - - - + + + + failed to read file ファイルの読み込みに失敗しました - - usage: check_tx_proof <txid> <address> <signature_file> [<message>] - - - - - - + + + failed to load signature file - - usage: get_spend_proof <txid> [<message>] - - - - + wallet is watch-only and cannot generate the proof - - usage: check_spend_proof <txid> <signature_file> [<message>] - - - - - usage: get_reserve_proof (all|<amount>) [<message>] - - - - + The reserve proof can be generated only by a full wallet - - usage: check_reserve_proof <address> <signature_file> [<message>] - - - - + Address must not be a subaddress アドレスはサブアドレスであってはならないです - + Good signature -- total: %s, spent: %s, unspent: %s - - usage: show_transfers [in|out|all|pending|failed] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] - - - - + [Double spend seen on the network: this transaction may or may not end up being mined] - - usage: unspent_outputs [index=<N1>[,<N2>,...]] [<min_amount> [<max_amount>]] - - - - + There is no unspent output in the specified address - + (no daemon) (デーモンありません) - + (out of sync) - + (Untitled account) - - - - - - + + + + + + failed to parse index: インデックスの解析に失敗しました: - - + + specify an index between 0 and - - usage: - account - account new <label text with white spaces allowed> - account switch <index> - account label <index> <label text with white spaces allowed> - account tag <tag_name> <account_index_1> [<account_index_2> ...] - account untag <account_index_1> [<account_index_2> ...] - account tag_description <tag_name> <description> - - - - + Grand total: Balance: - + , unlocked balance: 、ロック解除された残高: - + Untagged accounts: - + Tag %s is unregistered. - + タグ %s を登録してません。 - + Accounts with tag: タグを持ってるアカウント: - + Tag's description: タグの記述: - + Account - + %c%8u %6s %21s %21s %21s %c%8u %6s %21s %21s %21s - + ---------------------------------------------------------------------------------- ---------------------------------------------------------------------------------- - + %15s %21s %21s %15s %21s %21s - + Primary address プライマリアドレス - + (used) - + (Untitled address) - + <index_min> is already out of bound - + <index_max> exceeds the bound - - usage: address [ new <label text with white spaces allowed> | all | <index_min> [<index_max>] | label <index> <label text with white spaces allowed> ] - - - - - + + Integrated addresses can only be created for account 0 - + Integrated address: %s, payment ID: %s - + Subaddress: サブアドレス: - - usage: get_description - - - - + no description found 記述を見つかれませんでした - + description found: 記述を見つかれました: - + Filename: ファイル名: - + Watch only 閲覧専用 - + %u/%u multisig%s %u/%u マルチサイン%s - + Normal ノーマル - + + Type: タイプ: - - Testnet: - テストネット: - - - - Yes - はい - - - - No - いいえ - - - + This wallet is multisig and cannot sign - - usage: verify <filename> <address> <signature> - - - - + Bad signature from - + Good signature from - - usage: export_key_images <filename> - - - - + wallet is watch-only and cannot export key images - - - + + + failed to save file ファイルを保存できませんでした - + Signed key images exported to - - usage: import_key_images <filename> - - - - - usage: export_outputs <filename> - - - - + Outputs exported to - - usage: import_outputs <filename> - - - - - - - + + + + + amount is wrong: - + + expected number from 0 to - + Sweeping - + Money successfully sent, transaction: - + Change goes to more than one address - + お釣りは複数のアドレスに送ります - + %s change to %s %s のお釣り %s に - + no change お釣りありません - - - + + + Transaction successfully signed to file - - usage: get_tx_key <txid> - - - - - - - - - - - - + + + + + + + + + + failed to parse txid txidの解析に失敗しました - + Tx key: txキー: - + no tx keys found for this txid - + このtxidのためにtxキーを見つかれませんでした - - usage: get_tx_proof <txid> <address> [<message>] - - - - - - + + + signature file saved to: - - - + + + failed to save signature file - - usage: check_tx_key <txid> <txkey> <address> - - - - - + + failed to parse tx key txキーの解析に失敗しました - - - + + + error: エラー: - - + + received 貰いました - - + + in txid txidに - - + + received nothing in txid - - + + WARNING: this transaction is not yet included in the blockchain! - - + + This transaction has %u confirmations - - + + WARNING: failed to determine number of confirmations! - + bad min_height parameter: - + bad max_height parameter: - + in - - - out - - - - - failed - 失敗 - - - - pending - - - - + <min_amount> should be smaller than <max_amount> - + Amount: 金額: - + , number of keys: 、キーの数: - + - + Min block height: - + Max block height: - + Min amount found: - + Max amount found: - + Total count: - + Bin size: - + Outputs per *: - + count ^ - + | | - + + + - + +--> block height +--> ブロック高 - + ^ ^ - + ^ ^ - + - + wallet ウォレット - - + + Random payment ID: ランダムなペイメントID: - + Matching integrated address: @@ -3551,19 +4538,29 @@ Outputs per *: テストネットのマルチサインウォレットを作る - + + Create stagenet multisig wallets + + + + + Create an address file for new wallets + + + + Generating %u %u/%u multisig wallets %u %u/%u マルチサインウォレットを生じてます - - Error verifying multisig extra info - マルチサインの追加情報を検証中にエラーありました + + Failed to verify multisig info + - - Error finalizing multisig - マルチサイン締結中にエラーありました + + Error verifying multisig extra info + マルチサインの追加情報を検証中にエラーありました @@ -3576,132 +4573,495 @@ Outputs per *: マルチサインウォレットを樹立中にエラーありました: - + This program generates a set of multisig wallets - use this simpler scheme only if all the participants trust each other - このプログラムはマルチサインウォレットのセットを生じます - みんながみんなを信用する場合にだけこの単純なスキームを使ってください + このプログラムはマルチサインウォレットのセットを生じます - みんながみんなを信用する場合にだけこの単純なスキームを使ってください - + + Error: Can't specify more than one of --testnet and --stagenet + + + + Error: expected N/M, but got: エラー: N/Mを欲しかったでもこれを貰いました: - - + + Error: either --scheme or both of --threshold and --participants may be given エラー: --scheme あるいは--threshold と --participants を上げられる - + Error: expected N > 1 and N <= M, but got N==%u and M==%d エラー: N > 1 と N <= M のこと欲しかったでも N==%u と M==%d を貰いました - + Error: --filename-base is required エラー: --filename-baseを使う必要だがあります + + + mms::message_store - - Error: unsupported scheme: only N/N and N-1/N are supported - エラー: 不正なスキーム: N/N や N-1/N`のことをできます + + Use PyBitmessage instance at URL <arg> + + + + + Specify <arg> as username:password for PyBitmessage API + + + + + Auto-config cannot proceed because auto config data from other signers is not complete + + + + + The signer config is not complete. + + + + + Wallet can't go multisig because key sets from other signers are missing or not complete. + + + + + Wallet can't start another key exchange round because key sets from other signers are missing or not complete. + + + + + Syncing not done because multisig sync data from other signers are missing or not complete. + + + + + There are waiting messages, but nothing is ready to process under normal circumstances + + + + + +Use "mms next sync" if you want to force processing of the waiting sync data + + + + + +Use "mms note" to display the waiting notes + + + + + There are no messages waiting to be processed. + + + + + key set + + + + + additional key set + + + + + multisig sync data + + + + + partially signed tx + + + + + fully signed tx + + + + + note + + + + + signer config + + + + + auto-config data + + + + + unknown message type + + + + + in + + + + + out + + + + + unknown message direction + + + + + ready to send + + + + + sent + + + + + waiting + + + + + processed + + + + + cancelled + + + + + unknown message state + sw - + Generate new wallet and save it to <arg> 新しいウォレットを生じろ <arg> をこっちにセーブしてください - + + Generate new wallet from device and save it to <arg> + + + + Generate incoming-only wallet from view key ビューキーで閲覧専用ウォレットを生じろください - + Generate deterministic wallet from spend key スペンドキーで決定論的なウォレットを生じろください - + Generate wallet from private keys 秘密なキーでウォレットを生じろください - + Generate a master wallet from multisig wallet keys マルチシガーウォレットキーでマスターウォレットを生じろください - + Language for mnemonic ニーモニックのための言語 - + Specify Electrum seed for wallet recovery/creation ウォレットの回収や作成のためにElectrumなニーモニックシードを指定してください - + Recover wallet using Electrum-style mnemonic seed Electrumなニーモニックシードでウォレットを復元してください - + Recover multisig wallet using Electrum-style mnemonic seed Electrumなニーモニックシードでマルチシガーウォレットを復元してください - + Generate non-deterministic view and spend keys 非決定論的のビューとスペンドキーを生じろください - - Enable commands which rely on a trusted daemon - 必要な信用できるデーモンのコマンドをエネーブルしてください + + invalid argument: must be either 0/1, true/false, y/n, yes/no + - + + DNSSEC validation passed + + + + + WARNING: DNSSEC validation was unsuccessful, this address may not be correct! + + + + + For URL: + + + + + Monero Address = + + + + + Is this OK? (Y/n) + + + + + you have cancelled the transfer request + + + + + failed to parse index: + インデックスの解析に失敗しました: + + + + invalid format for subaddress lookahead; must be <major>:<minor> + + + + + no connection to daemon. Please make sure daemon is running. + デーモンの接続が確立ありません。デーモンが実行中になっていることを確認してください。 + + + + RPC error: + RPCエラー: + + + + failed to get random outputs to mix: + + + + + + Not enough money in unlocked balance + + + + + Failed to find a way to create transactions. This is usually due to dust which is so small it cannot pay for itself in fees, or trying to send more money than the unlocked balance, or not leaving enough for fees + + + + + not enough outputs for specified ring size + 指定したリングサイズのアウトプットが不十分です + + + + output amount + アウトプットの金額 + + + + found outputs to use + 使うためにアウトプットを見つかれました + + + + Please use sweep_unmixable. + + + + + transaction was not constructed + 取引を作りませんでした + + + + transaction %s was rejected by daemon with status: + 取引 %s がデーモンによって拒否しました。ステータス: + + + + Reason: + + + + + one of destinations is zero + 宛先の1つはゼロです + + + + failed to find a suitable way to split transactions + 取引を分割する適切な方法を見つけることができませんでした + + + + unknown transfer error: + 不明な転送エラー: + + + + Multisig error: + マルチサインエラー: + + + + internal error: + 内部エラー: + + + + unexpected error: + 予期せぬエラー: + + + + There was an error, which could mean the node may be trying to get you to retry creating a transaction, and zero in on which outputs you own. Or it could be a bona fide error. It may be prudent to disconnect from this node, and not try to send a transaction immediately. Alternatively, connect to another node so the original node cannot correlate information. + + + + + File %s likely stores wallet private keys! Use a different file name. + + + + + File %s already exists. Are you sure to overwrite it? (Y/Yes/N/No): + + + + + seconds + + + + + minutes + + + + + hours + + + + + days + + + + + months + + + + + a long time + + + + + This is the command line monero wallet. It needs to connect to a monero +daemon to work correctly. +WARNING: Do not reuse your Monero keys on another fork, UNLESS this fork has key reuse mitigations built in. Doing so will harm your privacy. + + + + + Unknown command: + 未知のコマンド: + + + Allow communicating with a daemon that uses a different RPC version 別のRPCバージョンを使用してるデーモンとの通信を許可してください - + Restore from specific blockchain height 特定ブロックチェイン高で復元してください - + The newly created transaction will not be relayed to the monero network 新しい取引をネットワークに中継しません - + + Create an address file for new wallets + + + + + Display English language names + + + + + failed to read wallet password + + + + + Enter a new password for the wallet + + + + + Wallet password + + + + + daemon is busy. Please try again later. デーモンは忙しいです。後でもう一度試してください。 - + possibly lost connection to daemon デモンの接続が切れましたかもしりません - + Error: エラー: - - This is the command line monero wallet. It needs to connect to a monero -daemon to work correctly. - これはMoneroのコマンドラインウォレットです。別のMoneroデモンと接続する必要があります。 - - - + Failed to initialize wallet ウォレットを初期化できませんでした @@ -3709,299 +5069,359 @@ daemon to work correctly. tools::wallet2 - + Use daemon instance at <host>:<port> <host>:<port>でデーモンインスタンスを使ってください - + Use daemon instance at host <arg> instead of localhost localhostの代わりにホスト <arg>でデーモンインスタンスを使ってください - + Wallet password file ウォレットのパスワードファイル - + Use daemon instance at port <arg> instead of 18081 18081の代わりにポート <arg>でデーモンインスタンスを使ってください - + For testnet. Daemon must also be launched with --testnet flag テストネットのためにデーモンは --testnet のフラグで開始する必要があります - - Restricts to view-only commands - 閲覧専用コマンドに限ります - - - + can't specify daemon host or port more than once デーモンのホストやポートを複数回指定することはできません - + can't specify more than one of --password and --password-file --password と --passwordfile を1つしか指定しません - + the password file specified could not be read 指定されたパスワードファイルを読み取れません - + Failed to load file ファイルのロードに失敗しました - + Wallet password (escape/quote as needed) ウォレットのパスワード(随時にエスケープ文字を使ってください) - + + Enable commands which rely on a trusted daemon + 必要な信用できるデーモンのコマンドをエネーブルしてください + + + + Disable commands which rely on a trusted daemon + + + + Specify username[:password] for daemon RPC client デーモンのRPCクライアントを使うためにユーザー名[:パスワード]を指定してください + + + For stagenet. Daemon must also be launched with --stagenet flag + + + + + Set shared ring database path + + + + + Number of rounds for the key derivation function + + + HW device to use + + + + + HW device wallet derivation path (e.g., SLIP-10) + + + + + --trusted-daemon and --untrusted-daemon are both seen, assuming untrusted + + + + + Daemon is local, assuming trusted + デーモンはローカルです。信頼できるデーモン予期してます + + + no password specified; use --prompt-for-password to prompt for a password パスワードを指定しませんでした。パスワードプロンプトを見るために--prompt-for-password を使ってください - + + Enter a new password for the wallet + + + + + Wallet password + + + + Failed to parse JSON JSONを解析に失敗しました - + Version %u too new, we can only grok up to %u バージョン %u 新しすぎるです。%u までグロークできます - + failed to parse view key secret key 秘密なビューキーの解析に失敗しました - - - + + + failed to verify view key secret key 秘密なビューキーの検証に失敗しました - + failed to parse spend key secret key 秘密なスペンドキーの解析に失敗しました - - - + + + failed to verify spend key secret key 秘密なスペンドキーの検証に失敗しました - + Electrum-style word list failed verification Electrumな単語表の検証に失敗しました - - At least one of Electrum-style word list and private view key and private spend key must be specified - Electrumな単語表と秘密なビューキーと秘密なスペンドキーの少なくとも1つを指定する必要があります + + At least one of either an Electrum-style word list, private view key, or private spend key must be specified + - + Both Electrum-style word list and private key(s) specified Electrumな単語表と秘密なキーを指定しました - + invalid address 不正なアドレス - + view key does not match standard address ビューキーが一般的なアドレスと一致しませんでした - + spend key does not match standard address スペンドキーが一般的なアドレスと一致しませんでした - + Cannot generate deprecated wallets from JSON JSONで非推奨のウォレットを生成することはできません - + failed to parse address: アドレスの解析に失敗しました: - + Address must be specified in order to create watch-only wallet 閲覧専用ウォレットを作るためにアドレスを指定する必要があります - + failed to generate new wallet: 新しいウォレットの生成に失敗しました: - - - - - - - - + + Password is needed to compute key image for incoming monero + + + + + Invalid password: password is needed to compute key image for incoming monero + + + + + + Primary account プライマリア カウント - + No funds received in this tx. この取引から資金貰いませんでした。 - + failed to read file ファイルの読み込みに失敗しました + + + Set subaddress lookahead sizes to <major>:<minor> + + tools::wallet_rpc_server - - Daemon is local, assuming trusted - デーモンはローカルです。信頼できるデーモン予期してます - - - + Failed to create directory ディレクトリの作成に失敗しました - + Failed to create directory %s: %s %s %s ディレクトリの作成に失敗しました - + Cannot specify -- これを指定しません: -- - + and -- と -- - + Failed to create file ファイルの作成に失敗しました - + . Check permissions or remove file 。 パーミッションを確認するか、ファイルを削除してください - + Error writing to file ファイルへの書き込みエラー - + RPC username/password is stored in file RPCユーザー名/パスワードはファイルに保存しました - + Tag %s is unregistered. タグ %s を登録してません。 - + Transaction not possible. Available only %s, transaction amount %s = %s + %s (fee) 取引は無理です。利用可能な金額 %s、 取引の金額 %s = %s + %s (手数料) - + This is the RPC monero wallet. It needs to connect to a monero daemon to work correctly. これはMoneroのコマンドラインウォレットです。別のMoneroデモンと接続する必要があります。 - + Can't specify more than one of --wallet-file and --generate-from-json --wallet-file と --generate-from-json を1つしか指定しません - + + Can't specify more than one of --testnet and --stagenet + + + + Must specify --wallet-file or --generate-from-json or --wallet-dir --wallet-file や --generate-from-json や --wallet-dir を指定する必要があります - + Loading wallet... ウォレットをロードしてます... - - + + Saving wallet... ウォレットを保存してます... - - + + Successfully saved 保存しました - + Successfully loaded ロードしました - + Wallet initialization failed: ウォレットを初期化できませんでした: - + Failed to initialize wallet RPC server ウォレットのRPCサーバを初期化できませんでした - + Starting wallet RPC server ウォレットのRPCサーバを開始してます - + Failed to run wallet: ウォレットを起動することできませんでした: - + Stopped wallet RPC server ウォレットのRPCサーバを停止しました - + Failed to save wallet: ウォレットを保存することできませんでした: @@ -4009,9 +5429,9 @@ daemon to work correctly. wallet_args - - - + + + Wallet options ウォレットのオプション @@ -4026,48 +5446,58 @@ daemon to work correctly. ウォレットの <arg> を使てください - + Max number of threads to use for a parallel job 並列ジョブのために最大スレッドの数 - + Specify log file ログファイルを指定してください - + Config file 設定ファイル - + General options ジェネラルオプション - + This is the command line monero wallet. It needs to connect to a monero daemon to work correctly. これはMoneroのコマンドラインウォレットです。別のMoneroデモンと接続する必要があります。 - + Can't find config file 設定ファイルを見つかりませんでした - + Logging to: こっちにログをしてます: - + Logging to %s %s にログをしてます - + + WARNING: You may not have a high enough lockable memory limit + + + + + see ulimit -l + + + + Usage: 使用: diff --git a/translations/monero_sv.ts b/translations/monero_sv.ts index 26ad43f7b..f4704fdd6 100644 --- a/translations/monero_sv.ts +++ b/translations/monero_sv.ts @@ -1,6 +1,6 @@ - + Monero::AddressBookImpl @@ -27,45 +27,55 @@ Monero::PendingTransactionImpl - + Attempting to save transaction to file, but specified file(s) exist. Exiting to not risk overwriting. File: Försöker spara transaktion till fil, men angiven fil finns redan. Avslutar för att inte riskera att skriva över någonting. Fil: - + Failed to write transaction(s) to file Det gick inte att skriva transaktioner till fil - + daemon is busy. Please try again later. daemonen är upptagen. Försök igen senare. - + no connection to daemon. Please make sure daemon is running. ingen anslutning till daemonen. Se till att daemonen körs. - + transaction %s was rejected by daemon with status: transaktionen %s avvisades av daemonen med status: - + . Reason: . Orsak: - + Unknown exception: Okänt undantag: - + Unhandled exception Ohanterat undantag + + + Couldn't multisig sign data: + + + + + Couldn't sign multisig transaction: + + Monero::UnsignedTransactionImpl @@ -124,281 +134,407 @@ Monero::WalletImpl - + payment id has invalid format, expected 16 or 64 character hex string: betalnings-ID har ogiltigt format. En hexadecimal sträng med 16 eller 64 tecken förväntades: - + Failed to add short payment id: Det gick inte att lägga till kort betalnings-ID: - - + + daemon is busy. Please try again later. daemonen är upptagen. Försök igen senare. - - + + no connection to daemon. Please make sure daemon is running. ingen anslutning till daemonen. Se till att daemonen körs. - - + + RPC error: RPC-fel: - - + + not enough outputs for specified ring size inte tillräckligt med utgångar för angiven ringstorlek - - + + found outputs to use hittade utgångar att använda - + Please sweep unmixable outputs. Svep upp omixbara utgångar. - - failed to get random outputs to mix - det gick inte att hämta slumpmässiga utgångar att mixa - - - - + + not enough money to transfer, available only %s, sent amount %s inte tillräckligt med pengar för överföring, endast tillgängligt %s, skickat belopp %s - + failed to parse address det gick inte att parsa adressen - + failed to parse secret spend key det gick inte att parsa hemlig spendernyckel - - No view key supplied, cancelled - Ingen granskningsnyckel angiven, avbruten - - - + failed to parse secret view key det gick inte att parsa hemlig granskningsnyckel - + failed to verify secret spend key det gick inte att verifiera hemlig spendernyckel - + spend key does not match address spendernyckel matchar inte adress - + failed to verify secret view key det gick inte att verifiera hemlig granskningsnyckel - + view key does not match address granskningsnyckel matchar inte adress - + + failed to generate new wallet: det gick inte att skapa ny plånbok: - + Failed to send import wallet request Det gick inte att skicka begäran om att importera plånbok - + Failed to load unsigned transactions Det gick inte att läsa in osignerade transaktioner - + Failed to load transaction from file Det gick inte att läsa in transaktion från fil - + Wallet is view only Plånboken är endast för granskning - + failed to save file det gick inte att spara fil - + Key images can only be imported with a trusted daemon Nyckelavbildningar kan bara importeras med en betrodd daemon - + Failed to import key images: Det gick inte att importera nyckelavbildningar: - + Failed to get subaddress label: Det gick inte att hämta etikett för underadress: - + Failed to set subaddress label: Det gick inte att ange etikett för underadress: - - failed to get random outputs to mix: %s - det gick inte att hitta slumpmässiga utgångar att mixa: %s + + Neither view key nor spend key supplied, cancelled + - - + + Electrum seed is empty + + + + + Electrum-style word list failed verification + Det gick inte att verifiera ordlista av Electrum-typ + + + + Failed to get multisig info: + + + + + + Failed to make multisig: + + + + + Failed to finalize multisig wallet creation + + + + + Failed to finalize multisig wallet creation: + + + + + Failed to export multisig images: + + + + + Failed to parse imported multisig images + + + + + Failed to import multisig images: + + + + + Failed to check for partial multisig key images: + + + + + Failed to restore multisig transaction: + + + + + Invalid destination address + Ogiltig måladress + + + + failed to get outputs to mix: %s + + + + + not enough money to transfer, overall balance only %s, sent amount %s inte tillräckligt med pengar för överföring, totalt saldo är bara %s, skickat belopp %s - - + + not enough money to transfer, available only %s, transaction amount %s = %s + %s (fee) ej tillräckligt med pengar för överföring, endast tillgängligt %s, transaktionsbelopp %s = %s + %s (avgift) - - + + output amount utgångens belopp - - + + transaction was not constructed transaktionen konstruerades inte - - + + transaction %s was rejected by daemon with status: transaktionen %s avvisades av daemonen med status: - - + + one of destinations is zero ett av målen är noll - - + + failed to find a suitable way to split transactions det gick inte att hitta ett lämpligt sätt att dela upp transaktioner - - + + unknown transfer error: okänt överföringsfel: - - + + internal error: internt fel: - - + + unexpected error: oväntat fel: - - + + unknown error okänt fel - - - - - - + + failed to get outputs to mix + + + + + + + + + + Failed to parse txid Det gick inte att parsa txid - + no tx keys found for this txid inga tx-nycklar kunde hittas för detta txid - - + + Failed to parse tx key Det gick inte att parsa txnyckel - - - - + + + + Failed to parse address Det gick inte att parsa adressen - + Address must not be a subaddress Adressen får inte vara en underadress - + + The wallet must be in multisig ready state + + + + + Given string is not a key + + + + Rescan spent can only be used with a trusted daemon Genomsök efter spenderade kan endast användas med en betrodd daemon + + + Invalid output: + + + + + Failed to mark outputs as spent + + + + + + Failed to parse output amount + + + + + + Failed to parse output offset + + + + + Failed to mark output as spent + + + + + Failed to mark output as unspent + + + + + + Failed to parse key image + + + + + Failed to get ring + + + + + Failed to get rings + + + + + Failed to set ring + + Wallet - + Failed to parse address Det gick inte att parsa adressen - + Failed to parse key Det gick inte att parsa nyckeln - + failed to verify key det gick inte att verifiera nyckeln - + key does not match address nyckeln matchar inte adressen @@ -406,12 +542,12 @@ command_line - + yes ja - + no nej @@ -449,18 +585,18 @@ tillåter inkommande okrypterade externa anslutningar. Överväg att använda SSH-tunnel eller SSL-proxy istället. Åsidosätt med -- - + Username specified with -- Användarnamn angivet med -- - - + + cannot be empty får inte vara tomt - + requires RPC server password -- kräver lösenord till RPC-server -- @@ -468,1372 +604,1091 @@ cryptonote::simple_wallet - + Commands: Kommandon: - + failed to read wallet password det gick inte att läsa lösenord för plånboken - + invalid password ogiltigt lösenord - + set seed: needs an argument. available options: language set seed: kräver ett argument. tillgängliga alternativ: språk - + set: unrecognized argument(s) set: okända argument - + wallet file path not valid: ogiltig sökväg till plånbok: - + Attempting to generate or restore wallet, but specified file(s) exist. Exiting to not risk overwriting. Försöker skapa eller återställa plånbok, men angivna filer finns redan. Avslutar för att inte riskera att skriva över någonting. - - usage: payment_id - användning: payment_id - - - + needs an argument kräver ett argument - - - - - - - - - - + + + + + + + + + + + + + 0 or 1 0 eller 1 - - 0, 1, 2, 3, or 4 - 0, 1, 2, 3 eller 4 - - - - + + + unsigned integer positivt heltal - - NOTE: the following 25 words can be used to recover access to your wallet. Write them down and store them somewhere safe and secure. Please do not store them in your email or on file storage services outside of your immediate control. - - OBS: följande 25 ord kan användas för att återställa åtkomst till din plånbok. Skriv ner och spara dem på ett säkert ställe. Spara dem inte i din e-post eller på något lagringsutrymme som du inte har direkt kontroll över. - - - - + --restore-deterministic-wallet uses --generate-new-wallet, not --wallet-file --restore-deterministic-wallet använder --generate-new-wallet, inte --wallet-file - + specify a recovery parameter with the --electrum-seed="words list here" ange en återställningsparameter med --electrum-seed="ordlista här" - + specify a wallet path with --generate-new-wallet (not --wallet-file) ange sökväg till en plånbok med --generate-new-wallet (inte --wallet-file) - + wallet failed to connect to daemon: plånboken kunde inte ansluta till daemonen: - + Daemon uses a different RPC major version (%u) than the wallet (%u): %s. Either update one of them, or use --allow-mismatched-daemon-version. Daemonen använder en högre version av RPC (%u) än plånboken (%u): %s. Antingen uppdatera en av dem, eller använd --allow-mismatched-daemon-version. - + List of available languages for your wallet's seed: Lista över tillgängliga språk för din plånboks startvärde: - + Enter the number corresponding to the language of your choice: Ange det tal som motsvarar det språk du vill använda: - + You had been using a deprecated version of the wallet. Please use the new seed that we provide. Du hade använt en inaktuell version av plånboken. Använd det nya startvärde som tillhandahålls. - - + + Generated new wallet: Ny plånbok skapad: - - - + + + + failed to generate new wallet: det gick inte att skapa ny plånbok: - + Opened watch-only wallet Öppnade plånbok för granskning - + Opened wallet Öppnade plånbok - + You had been using a deprecated version of the wallet. Please proceed to upgrade your wallet. Du hade använt en inaktuell version av plånboken. Fortsätt för att uppgradera din plånbok. - + You had been using a deprecated version of the wallet. Your wallet file format is being upgraded now. Du hade använt en inaktuell version av plånboken. Plånbokens filformat kommer nu att uppgraderas. - + failed to load wallet: det gick inte att läsa in plånboken: - + Use the "help" command to see the list of available commands. Använd kommandot "help" för att visa en lista över tillgängliga kommandon. - + Wallet data saved Plånboksdata sparades - + Mining started in daemon Brytning startad i daemonen - + mining has NOT been started: brytning har INTE startats: - + Mining stopped in daemon Brytning stoppad i daemonen - + mining has NOT been stopped: brytning har INTE stoppats: - + Blockchain saved Blockkedjan sparades - - - + + Height Höjd - - transaction - transaktion - - - + spent spenderat - - unsupported transaction format - transaktionsformatet stöds inte - - - + Starting refresh... Startar uppdatering … - + Refresh done, blocks received: Uppdatering färdig, mottagna block: - - + payment id has invalid format, expected 16 or 64 character hex string: betalnings-ID har ogiltigt format. En hexadecimal sträng med 16 eller 64 tecken förväntades: - + bad locked_blocks parameter: felaktig parameter för locked_blocks: - - - + + a single transaction cannot use more than one payment id: en enda transaktion kan inte använda fler än ett betalnings-ID: - - - - + + + + failed to set up payment id, though it was decoded correctly det gick inte att upprätta betalnings-ID, trots att det avkodades korrekt - - - - - - - - + + + + ring size %u is too large, maximum is %u + + + + + + Unencrypted payment IDs are bad for privacy: ask the recipient to use subaddresses instead + + + + + payment id failed to encode + + + + + + Locked blocks too high, max 1000000 (˜4 yrs) + + + + + failed to parse short payment ID from URI + + + + + + Invalid last argument: + + + + + a single transaction cannot use more than one payment id + + + + + failed to parse payment id, though it was detected + + + + + + + + + + + transaction cancelled. transaktion avbruten. - - + + Is this okay anyway? (Y/Yes/N/No): Är detta okej ändå? (J/Ja/N/Nej): - + There is currently a %u block backlog at that fee level. Is this okay? (Y/Yes/N/No): Det finns för närvarande en %u blocks eftersläpning på den avgiftsnivån. Är detta okej? (J/Ja/N/Nej): - + Failed to check for backlog: Det gick inte att kontrollera eftersläpning: - - + + Transaction Transaktion - - + + Spending from address index %d Spendera från adressindex %d - - + + WARNING: Outputs of multiple addresses are being used together, which might potentially compromise your privacy. VARNING: Utgångar från flera adresser används tillsammans, vilket möjligen kan kompromettera din sekretess. - + Sending %s. Skickar %s. - + Your transaction needs to be split into %llu transactions. This will result in a transaction fee being applied to each transaction, for a total fee of %s Transaktionen behöver delas upp i %llu transaktioner. Detta gör att en transaktionsavgift läggs till varje transaktion, med ett totalbelopp på %s - + The transaction fee is %s Transaktionsavgiften är %s - + , of which %s is dust from change , varav %s är damm från växel - + . . - + A total of %s from dust change will be sent to dust address Ett totalt belopp på %s från växeldamm skickas till damm-adressen - + . This transaction will unlock on block %llu, in approximately %s days (assuming 2 minutes per block) . Denna transaktion låses upp vid block %llu, om ungefär %s dagar (förutsatt en blocktid på 2 minuter) - - - - - - - - + + Unsigned transaction(s) successfully written to MMS + + + + + + + + + + + Failed to write transaction(s) to file Det gick inte att skriva transaktioner till fil - - - - - - - - + + + + + + + + Unsigned transaction(s) successfully written to file: Osignerade transaktioner skrevs till fil: - + + + Failed to cold sign transaction with HW wallet + + + + No unmixable outputs found Inga omixbara utgångar kunde hittas - + + Not enough money in unlocked balance + + + + + Discarding %s of unmixable outputs that cannot be spent, which can be undone by "rescan_spent". Is this okay? (Y/Yes/N/No): + + + + No address given Ingen adress har angivits - + + missing lockedblocks parameter + + + + + bad locked_blocks parameter + + + + + + Failed to parse number of outputs + + + + + + Amount of outputs should be greater than 0 + + + + failed to parse Payment ID det gick inte att parsa betalnings-ID - - usage: sweep_single [<priority>] [<ring_size>] <key_image> <address> [<payment_id>] - användning: sweep_single [<prioritet>] [<ringstorlek>] <nyckelavbildning> <adress> [<betalnings_id>] - - - + failed to parse key image det gick inte att parsa nyckelavbildning - + No outputs found Inga utgångar kunde hittas - + Multiple transactions are created, which is not supposed to happen Flera transaktioner skapas, vilket inte ska kunna inträffa - + The transaction uses multiple or no inputs, which is not supposed to happen Transaktionen använder flera eller inga ingångar, vilket inte ska kunna inträffa - + missing threshold amount tröskelbelopp saknas - + invalid amount threshold ogiltigt tröskelbelopp - - donations are not enabled on the testnet - donationer är inte aktiverade på testnet - - - - usage: donate [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <amount> [<payment_id>] - användning: donate [index=<N1>[, <N2>, …]] [<prioritet>] [<ringstorlek>] <belopp> [<betalnings_id>] - - - + Claimed change does not go to a paid address Begärd växel går inte till en betald adress - + Claimed change is larger than payment to the change address Begärd växel är större än betalning till växeladressen - + sending %s to %s skickar %s till %s - + dummy output(s) dummy-utgångar - + with no destinations utan några mål - + Loaded %lu transactions, for %s, fee %s, %s, %s, with min ring size %lu, %s. %sIs this okay? (Y/Yes/N/No): Läste in %lu transaktioner, för %s, avgift %s, %s, %s, med minsta ringstorlek %lu, %s. %sÄr detta okej? (J/Ja/N/Nej): - + This is a multisig wallet, it can only sign with sign_multisig Detta är en multisig-plånbok, som endast kan signera med sign_multisig - - usage: sign_transfer [export] - användning: sign_transfer [export] - - - + Failed to sign transaction Det gick inte att signera transaktionen - + Failed to sign transaction: Det gick inte att signera transaktionen: - + Transaction raw hex data exported to Hexadecimala rådata för transaktionen exporterades till - + Failed to load transaction from file Det gick inte att läsa in transaktion från fil - - + + RPC error: RPC-fel: - + wallet is watch-only and has no spend key plånboken är enbart för granskning och har ingen spendernyckel - - - + + + + Your original password was incorrect. Ditt ursprungliga lösenord var fel. - + Error with wallet rewrite: Ett fel uppstod vid återskrivning av plånbok: - - priority must be 0, 1, 2, 3, or 4 - prioritet måste vara 0, 1, 2, 3 eller 4 - - - - - priority must be 0, 1, 2, 3, or 4 - prioritet måste vara 0, 1, 2, 3 eller 4 - - - + invalid unit ogiltig enhet - - + + invalid count: must be an unsigned integer ogiltigt värde för count: måste vara ett heltal utan tecken - + invalid value ogiltigt värde - - usage: set_log <log_level_number_0-4> | <categories> - användning: set_log <loggnivå_nummer_0-4> | <kategorier> - - - + (Y/Yes/N/No): (J/Ja/N/Nej): - - + + bad m_restore_height parameter: felaktig parameter för m_restore_height: - + date format must be YYYY-MM-DD datumformat måste vara ÅÅÅÅ-MM-DD - + Restore height is: Återställningshöjd är: - - + + + Is this okay? (Y/Yes/N/No): Är detta okej? (J/Ja/N/Nej): - + Daemon is local, assuming trusted Daemonen är lokal, utgår från att den är betrodd - + Password for new watch-only wallet Lösenord för ny granskningsplånbok - - invalid arguments. Please use start_mining [<number_of_threads>] [do_bg_mining] [ignore_battery], <number_of_threads> should be from 1 to - ogiltiga argument. Använd start_mining [<antal_trådar>] [do_bg_mining] [ignore_battery], <antal_trådar> ska vara från 1 till - - - + internal error: internt fel: - - - + + + unexpected error: oväntat fel: - - - - - - - - - + + + + + + + + + + + unknown error okänt fel - + refresh failed: det gick inte att uppdatera: - + Blocks received: Mottagna block: - + unlocked balance: upplåst saldo: - - - + + + + amount belopp - + false falskt - + Unknown command: Okänt kommando: - + Command usage: Användning av kommando: - + Command description: Beskrivning av kommando: - + wallet is multisig but not yet finalized plånboken är multisig men är ännu inte slutförd - - Enter optional seed encryption passphrase, empty to see raw seed - Ange valfri lösenfras för kryptering av startvärdet, lämna tomt för att se rådata för startvärdet - - - + Failed to retrieve seed Det gick inte att hämta startvärde - + wallet is multisig and has no seed plånboken är multisig och har inget startvärde - - Cannot connect to daemon - Det går inte att ansluta till daemonen - - - - Current fee is %s monero per kB - Aktuell avgift är %s monero per kB - - - + Error: failed to estimate backlog array size: Fel: det gick inte att uppskatta eftersläpningsmatrisens storlek: - + Error: bad estimated backlog array size Fel: felaktigt uppskattat värde för eftersläpningsmatrisens storlek - + (current) (aktuellt) - + %u block (%u minutes) backlog at priority %u%s %u blocks (%u minuters) eftersläpning vid prioritet %u%s - + %u to %u block (%u to %u minutes) backlog at priority %u %u till %u blocks (%u till %u minuters) eftersläpning vid prioritet %u - + No backlog at priority Ingen eftersläpning vid prioritet - - + + This wallet is already multisig Denna plånbok är redan multisig - - + + wallet is watch-only and cannot be made multisig plånboken är enbart för granskning och kan inte göras om till multisig - - + + This wallet has been used before, please use a new wallet to create a multisig wallet Denna plånbok har använts tidigare. Använd en ny plånbok för att skapa en multisig-plånbok - - Your password is incorrect. - Ditt lösenord är fel. - - - + Send this multisig info to all other participants, then use make_multisig <threshold> <info1> [<info2>...] with others' multisig info Skicka denna multisig-info till alla andra deltagare och använd sedan make_multisig <tröskelvärde> <info1> [<info2>…] med de andras multisig-info - + This includes the PRIVATE view key, so needs to be disclosed only to that multisig wallet's participants Detta innefattar den PRIVATA granskningsnyckeln, så den behöver endast lämnas ut till den multisig-plånbokens deltagare - - usage: make_multisig <threshold> <multisiginfo1> [<multisiginfo2>...] - användning: make_multisig <tröskelvärde> <multisiginfo1> [<multisiginfo2>…] - - - + Invalid threshold Ogiltigt tröskelvärde - + + Another step is needed Ytterligare ett steg krävs - - Send this multisig info to all other participants, then use finalize_multisig <info1> [<info2>...] with others' multisig info - Skicka denna multisig-info till alla andra deltagare, använd sedan finalize_multisig <info1> [<info2>…] med de andras multisig-info - - - + Error creating multisig: Ett fel uppstod när multisig skapades: - + Error creating multisig: new wallet is not multisig Ett fel uppstod när multisig skapades: den nya plånboken är inte multisig - + multisig address: multisig-adress: - - - + + + + This wallet is not multisig Denna plånbok är inte multisig - + + This wallet is already finalized Denna plånbok är redan slutförd - - usage: finalize_multisig <multisiginfo1> [<multisiginfo2>...] - användning: finalize_multisig <multisiginfo1> [<multisiginfo2>…] - - - + Failed to finalize multisig Det gick inte att slutföra multisig - + Failed to finalize multisig: Det gick inte att slutföra multisig: - - - - - + + + + + This multisig wallet is not yet finalized Denna multisig-plånbok är inte slutförd ännu - - usage: export_multisig_info <filename> - användning: export_multisig_info <filnamn> - - - + Error exporting multisig info: Ett fel uppstod när multisig-info exporterades: - + Multisig info exported to Multisig-info exporterades till - - usage: import_multisig_info <filename1> [<filename2>...] - one for each other participant - användning: import_multisig_info <filename1> [<filename2>…] - en för varje annan deltagare - - - + Multisig info imported Multisig-info importerades - + Failed to import multisig info: Det gick inte att importera multisig-info: - + Failed to update spent status after importing multisig info: Det gick inte att uppdatera spenderstatus efter import av multisig-info: - + Untrusted daemon, spent status may be incorrect. Use a trusted daemon and run "rescan_spent" Ej betrodd daemon. Spenderstatus kan vara felaktig. Använd en betrodd daemon och kör "rescan_spent" - - - + + + This is not a multisig wallet Detta är inte en multisig-plånbok - - usage: sign_multisig <filename> - användning: sign_multisig <filnamn> - - - + + Failed to sign multisig transaction Det gick inte att signera multisig-transaktion - + Multisig error: Multisig-fel: - + Failed to sign multisig transaction: Det gick inte att signera multisig-transaktion: - + It may be relayed to the network with submit_multisig Den kan skickas vidare till nätverket med submit_multisig - - usage: submit_multisig <filename> - användning: submit_multisig <filnamn> - - - - + + Failed to load multisig transaction from file Det gick inte att läsa in multisig-transaktion från fil - - + + Multisig transaction signed by only %u signers, needs %u more signatures Multisig-transaktion har signerats av bara %u signerare. Den behöver %u ytterligare signaturer - - + + Transaction successfully submitted, transaction Transaktionen skickades, transaktion - - + + You can check its status by using the `show_transfers` command. Du kan kontrollera dess status genom att använda kommandot 'show_transfers'. - - usage: export_raw_multisig <filename> - användning: export_raw_multisig <filnamn> - - - + Failed to export multisig transaction to file Det gick inte att exportera multisig-transaktion till fil - + Saved exported multisig transaction file(s): Sparade filer med exporterade multisig-transaktioner: - - - + + + ring size must be an integer >= ringstorlek måste vara ett heltal >= - + could not change default ring size det gick inte att ändra standardinställning för ringstorlek - + + Invalid height Ogiltig höjd - - start_mining [<number_of_threads>] [bg_mining] [ignore_battery] - start_mining [<antal_trådar>] [<bgbrytning>] [<ignorera_batteri>] - - - + Start mining in the daemon (bg_mining and ignore_battery are optional booleans). Starta brytning i daemonen (bgbrytning och ignorera_batteri är valfri booleska värden). - + Stop mining in the daemon. Stoppa brytning i daemonen. - - set_daemon <host>[:<port>] - set_daemon <värddator>[:<port>] - - - + Set another daemon to connect to. Ange en annan daemon att ansluta till. - + Save the current blockchain data. Spara aktuella blockkedjedata. - + Synchronize the transactions and balance. Synkronisera transaktionerna och saldot. - - balance [detail] - balance [detail] - - - + Show the wallet's balance of the currently selected account. Visa plånbokens saldo för det aktiva kontot. - - incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] - incoming_transfers [available|unavailable] [verbose] [index=<N1>[, <N2>[, …]]] - - - - Show the incoming transfers, all or filtered by availability and address index. - -Output format: -Amount, Spent("T"|"F"), "locked"|"unlocked", RingCT, Global Index, Transaction Hash, Address Index, [Public Key, Key Image] - Visa inkommande överföringar: alla eller filtrerade efter tillgänglighet och adressindex. - - - - payments <PID_1> [<PID_2> ... <PID_N>] - payments <BID_1> [<BID_2> … <BID_N>] - - - + Show the payments for the given payment IDs. Visa betalningar för givna betalnings-ID. - + Show the blockchain height. Visa blockkedjans höjd. - - transfer_original [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> <amount> [<payment_id>] - transfer_original [index=<N1>[, <N2>, …]] [<prioritet>] [<ringstorlek>] <adress> <belopp> [<betalnings_id>] - - - - Transfer <amount> to <address> using an older transaction building algorithm. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding <address_2> <amount_2> etcetera (before the payment ID, if it's included) - Överför <belopp> till <adress> genom att använda en äldre algoritm för att bygga transaktioner. Om parametern "index=<N1>[, <N2>, …]" anges använder plånboken utgångar som tagits emot av adresser vid dessa index. Om parametern utelämnas väljer plånboken slumpmässigt adressindex att använda. Oavsett vilket kommer den att göra sitt bästa för att inte kombinera utgångar från flera adresser. <prioritet> är transaktionens prioritet. Ju högre prioritet, desto högre transaktionsavgift. Giltiga värden i prioritetsordning (från lägsta till högsta) är: unimportant, normal, elevated, priority. Om värdet utelämnas kommer standardvärdet att användas (se kommandot "set priority"). <ringstorlek> är det antal ingångar som ska inkluderas för att uppnå ospårbarhet. Flera betalningar kan göras på en gång genom att lägga till <adress_2> <belopp_2> osv (före betalnings-ID, om det inkluderas) - - - - transfer [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> <amount> [<payment_id>] - transfer [index=<N1>[, <N2>, …]] [<prioritet>] [<ringstorlek>] <adress> <belopp> [<betalnings_id>] - - - - Transfer <amount> to <address>. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding <address_2> <amount_2> etcetera (before the payment ID, if it's included) - Överför <belopp> till <adress>. Om parametern "index=<N1>[, <N2>, …]" anges använder plånboken utgångar som tagits emot av adresser vid dessa index. Om parametern utelämnas väljer plånboken slumpmässigt adressindex att använda. Oavsett vilket kommer den att göra sitt bästa för att inte kombinera utgångar från flera adresser. <prioritet> är transaktionens prioritet. Ju högre prioritet, desto högre transaktionsavgift. Giltiga värden i prioritetsordning (från lägsta till högsta) är: unimportant, normal, elevated, priority. Om värdet utelämnas kommer standardvärdet att användas (se kommandot "set priority"). <ringstorlek> är det antal ingångar som ska inkluderas för att uppnå ospårbarhet. Flera betalningar kan göras på en gång genom att lägga till <adress_2> <belopp_2> osv (före betalnings-ID, om det inkluderas) - - - - locked_transfer [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <addr> <amount> <lockblocks> [<payment_id>] - locked_transfer [index=<N1>[, <N2>, …]] [<prioritet>] [<ringstorlek>] <adress> <belopp> <låsblock> [<betalnings_id>] - - - - Transfer <amount> to <address> and lock it for <lockblocks> (max. 1000000). If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding <address_2> <amount_2> etcetera (before the payment ID, if it's included) - Överför <belopp> till <adress> och lås det i <låsblock> (max. 1000000). Om parametern "index=<N1>[, <N2>, …]" anges använder plånboken utgångar som tagits emot av adresser vid dessa index. Om parametern utelämnas väljer plånboken slumpmässigt adressindex att använda. Oavsett vilket kommer den att göra sitt bästa för att inte kombinera utgångar från flera adresser. <prioritet> är transaktionens prioritet. Ju högre prioritet, desto högre transaktionsavgift. Giltiga värden i prioritetsordning (från lägsta till högsta) är: unimportant, normal, elevated, priority. Om värdet utelämnas kommer standardvärdet att användas (se kommandot "set priority"). <ringstorlek> är det antal ingångar som ska inkluderas för att uppnå ospårbarhet. Flera betalningar kan göras på en gång genom att lägga till <adress_2> <belopp_2> osv (före betalnings-ID, om det inkluderas) - - - + Send all unmixable outputs to yourself with ring_size 1 Skicka alla omixbara utgångar till dig själv med ringstorlek 1 - - sweep_all [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> [<payment_id>] - sweep_all [index=<N1>[, <N2>, …]] [<prioritet>] [<ringstorlek>] <adress> [<betalnings_id>] - - - - Send all unlocked balance to an address. If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. - Skicka allt upplåst saldo till en adress. Om parametern "index<N1>[, <N2>, …]" anges sveper plånboken upp utgångar som tagits emot av adresserna vid dessa index. Om parametern utelämnas väljer plånboken slumpmässigt ett adressindex att använda. - - - - sweep_below <amount_threshold> [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <address> [<payment_id>] - sweep_below <tröskelbelopp> [index=<N1>[, <N2>, …]] [<prioritet>] [<ringstorlek>] <adress> [<betalnings_id>] - - - + Send all unlocked outputs below the threshold to an address. Skicka alla upplåsta utgångar under tröskelvärdet till en adress. - - sweep_single [<priority>] [<ring_size>] <key_image> <address> [<payment_id>] - sweep_single [<prioritet>] [<ringstorlek>] <nyckelavbildning> <adress> [<betalnings_id>] - - - + Send a single output of the given key image to an address without change. Skicka en enda utgång hos den givna nyckelavbildningen till en adress utan växel. - - donate [index=<N1>[,<N2>,...]] [<priority>] [<ring_size>] <amount> [<payment_id>] - donate [index=<N1>[, <N2>, …]] [<prioritet>] [<ringstorlek>] <belopp> [<betalnings_id>] - - - + Donate <amount> to the development team (donate.getmonero.org). Donera <belopp> till utvecklingsteamet (donate.getmonero.org). - - sign_transfer <file> - sign_transfer <fil> - - - - Sign a transaction from a <file>. - Signera en transaktion från <fil>. - - - + Submit a signed transaction from a file. Skicka en signerad transaktion från en fil. - - set_log <level>|{+,-,}<categories> - set_log <nivå>|{+,-,}<kategorier> - - - + Change the current log detail (level must be <0-4>). Ändra detaljnivån för aktuell logg (nivå måste vara 0-4). - - account - account new <label text with white spaces allowed> - account switch <index> - account label <index> <label text with white spaces allowed> - account tag <tag_name> <account_index_1> [<account_index_2> ...] - account untag <account_index_1> [<account_index_2> ...] - account tag_description <tag_name> <description> - account - account new <etikettext med blanktecken tillåtna> - account switch <index> - account label <index> <etikettext med blanktecken tillåtna> - account tag <taggnamn> <kontoindex_1> [<kontoindex_2> …] - account untag <kontoindex_1> [<kontoindex_2> …] - account tag_description <taggnamn> <beskrivning> - - - + If no arguments are specified, the wallet shows all the existing accounts along with their balances. If the "new" argument is specified, the wallet creates a new account with its label initialized by the provided label text (which can be empty). -If the "switch" argument is specified, the wallet switches to the account specified by <index>. -If the "label" argument is specified, the wallet sets the label of the account specified by <index> to the provided label text. -If the "tag" argument is specified, a tag <tag_name> is assigned to the specified accounts <account_index_1>, <account_index_2>, .... -If the "untag" argument is specified, the tags assigned to the specified accounts <account_index_1>, <account_index_2> ..., are removed. -If the "tag_description" argument is specified, the tag <tag_name> is assigned an arbitrary text <description>. +If the "switch" argument is specified, the wallet switches to the account specified by <index>. +If the "label" argument is specified, the wallet sets the label of the account specified by <index> to the provided label text. +If the "tag" argument is specified, a tag <tag_name> is assigned to the specified accounts <account_index_1>, <account_index_2>, .... +If the "untag" argument is specified, the tags assigned to the specified accounts <account_index_1>, <account_index_2> ..., are removed. +If the "tag_description" argument is specified, the tag <tag_name> is assigned an arbitrary text <description>. Om inga argument anges visas plånbokens samtliga befintliga konton, tillsammans med deras respektive saldo. Om argumentet "new" anges, skapar plånboken ett nytt konto med etiketten satt till med den angivna etikettexten (som kan vara tom). -Om argumentet "switch" anges, växlar plånboken till det konto som anges av <index>. -Om argumentet "label" anges, sätter plånboken etiketten för kontot som anges av <index> till den angivna etikettexten. -Om argumentet "tag" anges, så tilldelas taggen <taggnamn> till det angivna kontona <kontoindex_1>, <kontoindex_2>, … -Om argumentet "untag" anges, tas tilldelade taggar bort från de angivna kontona <kontoindex_1>, <kontoindex_2> … -Om argumentet "tag_description" anges, så tilldelas taggen <taggnamn> den godtyckliga texten <beskrivning>. +Om argumentet "switch" anges, växlar plånboken till det konto som anges av <index>. +Om argumentet "label" anges, sätter plånboken etiketten för kontot som anges av <index> till den angivna etikettexten. +Om argumentet "tag" anges, så tilldelas taggen <taggnamn> till det angivna kontona <kontoindex_1>, <kontoindex_2>, … +Om argumentet "untag" anges, tas tilldelade taggar bort från de angivna kontona <kontoindex_1>, <kontoindex_2> … +Om argumentet "tag_description" anges, så tilldelas taggen <taggnamn> den godtyckliga texten <beskrivning>. - - address [ new <label text with white spaces allowed> | all | <index_min> [<index_max>] | label <index> <label text with white spaces allowed>] - address [new <etikettext med blanktecken tillåtna> | all | <index_min> [<index_max>] | label <index> <etikettext med blanktecken tillåtna>] - - - - If no arguments are specified or <index> is specified, the wallet shows the default or specified address. If "all" is specified, the walllet 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. - Om inga argument anges, eller om <index> anges, visar plånboken standardadressen eller den angivna adressen. Om argumentet "all" anges visar plånboken samtliga befintliga adresser i det aktiva kontot. Om argumentet "new " anges skapar plånboken en ny adress med den angivna etikettexten (som kan vara tom). Om argumentet "label" anges sätter plånboken etiketten för adressen som anges av <index> till den angivna etikettexten. - - - - integrated_address [<payment_id> | <address>] - integrated_address [<betalnings-id> | <adress>] - - - + 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 Koda ett betalnings-ID till en integrerad adress för den aktuella plånbokens publika adress (om inget argument anges används ett slumpmässigt betalnings-ID), eller avkoda en integrerad adress till en standardadress och ett betalnings-ID - - address_book [(add ((<address> [pid <id>])|<integrated address>) [<description possibly with whitespaces>])|(delete <index>)] - address_book [(add ((<adress> [pid <id>])|<integrerad adress>) [<beskrivning eventuellt med blanktecken>])|(delete <index>)] - - - + Print all entries in the address book, optionally adding/deleting an entry to/from it. Skriv ut alla poster i adressboken, och valfritt lägg till/ta bort en post i den. - + Save the wallet data. Spara plånboksdata. - + Save a watch-only keys file. Spara en fil med granskningsnycklar. - + Display the private view key. Visa privat granskningsnyckel. - + Display the private spend key. Visa privat spendernyckel. - + Display the Electrum-style mnemonic seed Visa det minnesbaserade startvärdet (Electrum-typ) - - set <option> [<value>] - set <alternativ> [<värde>] - - - - Available options: - seed language - Set the wallet's seed language. - always-confirm-transfers <1|0> - Whether to confirm unsplit txes. - print-ring-members <1|0> - Whether to print detailed information about ring members during confirmation. - store-tx-info <1|0> - Whether to store outgoing tx info (destination address, payment ID, tx secret key) for future reference. - default-ring-size <n> - Set the default ring size (default and minimum is 5). - auto-refresh <1|0> - Whether to automatically synchronize new blocks from the daemon. - refresh-type <full|optimize-coinbase|no-coinbase|default> - Set the wallet's refresh behaviour. - priority [0|1|2|3|4] - Set the fee to default/unimportant/normal/elevated/priority. - confirm-missing-payment-id <1|0> - ask-password <1|0> - unit <monero|millinero|micronero|nanonero|piconero> - Set the default monero (sub-)unit. - min-outputs-count [n] - Try to keep at least that many outputs of value at least min-outputs-value. - min-outputs-value [n] - Try to keep at least min-outputs-count outputs of at least that value. - merge-destinations <1|0> - Whether to merge multiple payments to the same destination address. - confirm-backlog <1|0> - Whether to warn if there is transaction backlog. - confirm-backlog-threshold [n] - Set a threshold for confirm-backlog to only warn if the transaction backlog is greater than n blocks. - refresh-from-block-height [n] - Set the height before which to ignore blocks. - auto-low-priority <1|0> - Whether to automatically use the low priority fee level when it's safe to do so. - Tillgängliga alternativ: - språk för startvärde - Ange plånbokens språk för startvärde. - always-confirm-transfers <1|0> - Om ej delade transaktioner ska bekräftas. - print-ring-members <1|0> - Om detaljerad information om ringmedlemmar ska skrivas ut vid bekräftelse. - store-tx-info <1|0> - Om information om utgående transaktion ska sparas (måladress, betalnings-ID, hemlig tx-nyckel) som referens. - default-ring-size <n> - Ange standardinställning för ringstorlek (standard och minimum är 5). - auto-refresh <1|0> - Om nya block ska synkas automatiskt från daemonen. - refresh-type <full|optimize-coinbase|no-coinbase|default> - Ange plånbokens uppdateringsbeteende. - priority [0|1|2|3|4] - Sätt avgiften till default/unimportant/normal/elevated/priority. - confirm-missing-payment-id <1|0> - ask-password <1|0> - unit <monero|millinero|micronero|nanonero|piconero> - Ange standardvärde för moneroenhet. - min-outputs-count [n] - Försök att behålla åtminstone så många utgångar med åtminstone värdet min-outputs-value. - min-outputs-value [n] - Försök att behålla åtminstone min-outputs-count utgångar med åtminstone det värdet. - merge-destinations <1|0> - Om flera betalningar till samma måladress ska sammanslås. - confirm-backlog <1|0> - Om en varning ska visas om det föreligger transaktionseftersläpning. - confirm-backlog-threshold [n] - Ange ett tröskelvärde för confirm-backlog för att endast varna om transaktionseftersläpningen är större än n block. - refresh-from-block-height [n] - Ange höjden upp till vilken block ska ignoreras. - auto-low-priority <1|0> - Om avgiftsnivån för låg prioritet automatiskt ska användas när detta är säkert att göra. - - - + Display the encrypted Electrum-style mnemonic seed. Visa det krypterade minnesbaserade startvärdet (Electrum-typ). - + Rescan the blockchain for spent outputs. Genomsök blockkedjan efter spenderade utgångar. - - get_tx_key <txid> - get_tx_key <txid> - - - + Get the transaction key (r) for a given <txid>. Hämta transaktionsnyckel (r) för ett givet <txid>. - - check_tx_key <txid> <txkey> <address> - check_tx_key <txid> <txkey> <adress> - - - + Check the amount going to <address> in <txid>. Kontrollera belopp som går till <adress> i <txid>. - - get_tx_proof <txid> <address> [<message>] - get_tx_proof <txid> <adress> [<meddelande>] - - - + Generate a signature proving funds sent to <address> in <txid>, optionally with a challenge string <message>, using either the transaction secret key (when <address> is not your wallet's address) or the view secret key (otherwise), which does not disclose the secret key. Skapa en signatur som bevisar att pengar skickades till <adress> i <txid>, valfritt med kontrollsträngen <meddelande>, genom att använda antingen transaktionens hemliga nyckel (när <adress> inte är din plånboks adress) eller den hemliga granskningsnyckeln (annars), vilket inte lämnar ut den hemliga nyckeln. - - check_tx_proof <txid> <address> <signature_file> [<message>] - check_tx_proof <txid> <adress> <signaturfil> [<meddelande>] - - - + Check the proof for funds going to <address> in <txid> with the challenge string <message> if any. Kontrollera beviset för pengar som skickats till <adress> i <txid> med kontrollsträngen <meddelande>, om den angivits. - - get_spend_proof <txid> [<message>] - get_spend_proof <txid> [<meddelande>] - - - + Generate a signature proving that you generated <txid> using the spend secret key, optionally with a challenge string <message>. Skapa en signatur som bevisar att du skapade <txid> genom att använda den hemliga spendernyckeln, valfritt med kontrollsträngen <meddelande>. - - check_spend_proof <txid> <signature_file> [<message>] - check_spend_proof <txid> <signaturfil> [<meddelande>] - - - + Check a signature proving that the signer generated <txid>, optionally with a challenge string <message>. Kontrollera en signatur som bevisar att signeraren skapade <txid>, valfritt med kontrollsträngen <meddelande>. - - get_reserve_proof (all|<amount>) [<message>] - get_reserve_proof (all|<belopp>) [<meddelande>] - - - + Generate a signature proving that you own at least this much, optionally with a challenge string <message>. If 'all' is specified, you prove the entire sum of all of your existing accounts' balances. Otherwise, you prove the reserve of the smallest possible amount above <amount> available in your current account. @@ -1842,381 +1697,242 @@ Om 'all' anges, bevisar du totalsumman av alla dina befintliga kontons Annars bevisar du reserven för det minsta möjliga belopp över <belopp> som är tillgängligt på ditt aktuella konto. - - check_reserve_proof <address> <signature_file> [<message>] - check_reserve_proof <adress> <signaturfil> [<meddelande>] - - - + Check a signature proving that the owner of <address> holds at least this much, optionally with a challenge string <message>. Kontrollera en signatur som bevisar att ägaren till <adress> har åtminstone så här mycket, valfritt med kontrollsträngen <meddelande>. - - show_transfers [in|out|pending|failed|pool] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] - show_transfers [in|out|pending|failed|pool] [index=<N1>[, <N2>, …]] [<min_höjd> [<max_höjd>]] - - - - Show the incoming/outgoing transfers within an optional height range. - -Output format: -In or Coinbase: Block Number, "block"|"in", Time, Amount, Transaction Hash, Payment ID, Subaddress Index, "-", Note\ -Out: Block Number, "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Destinations, Input addresses**, "-", Note -Pool: "pool", "in", Time, Amount, Transaction Hash, Payment Id, Subaddress Index, "-", Note, Double Spend Note\ -Pending or Failed: "failed"|"pending", "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Input addresses**, "-", Note - -* Excluding change and fee. -** Set of address indices used as inputs in this transfer. - Visa inkommande/utgående överföringar inom ett valfritt höjdintervall. - - - - unspent_outputs [index=<N1>[,<N2>,...]] [<min_amount> [<max_amount>]] - unspent_outputs [index=<N1>[, <N2>, …]] [<min_belopp> [<max_belopp>]] - - - + Show the unspent outputs of a specified address within an optional amount range. Visa de ej spenderade utgångarna hos en angiven adress inom ett valfritt beloppsintervall. - - Rescan the blockchain from scratch. - Genomsök blockkedjan från början. - - - - set_tx_note <txid> [free text note] - set_tx_note <txid> [<fritextanteckning>] - - - + Set an arbitrary string note for a <txid>. Ange en godtycklig stränganteckning för <txid>. - - get_tx_note <txid> - get_tx_note <txid> - - - + Get a string note for a txid. Hämta en stränganteckning för ett txid. - - set_description [free text note] - set_description [<fritextanteckning>] - - - + Set an arbitrary description for the wallet. Ange en godtycklig beskrivning av plånboken. - + Get the description of the wallet. Hämta plånbokens beskrivning. - + Show the wallet's status. Visa plånbokens status. - + Show the wallet's information. Visa information om plånboken. - - sign <file> - sign <fil> - - - + Sign the contents of a file. Signera innehållet i en fil. - - verify <filename> <address> <signature> - verify <filnamn> <adress> <signatur> - - - + Verify a signature on the contents of a file. Verifiera en signatur av innehållet in en fil. - - export_key_images <file> - export_key_images <fil> - - - - Export a signed set of key images to a <file>. - Exportera en signerad uppsättning nyckelavbildningar till <fil>. - - - - import_key_images <file> - import_key_images <fil> - - - + Import a signed key images list and verify their spent status. Importera en signerad lista av nyckelavbildningar och verifiera deras spenderstatus. - - export_outputs <file> - export_outputs <fil> - - - + Export a set of outputs owned by this wallet. Exportera en uppsättning utgångar som ägs av denna plånbok. - - import_outputs <file> - import_outputs <fil> - - - + Import a set of outputs owned by this wallet. Importera en uppsättning utgångar som ägs av denna plånbok. - - show_transfer <txid> - show_transfer <txid> - - - + Show information about a transfer to/from this address. Visa information om en transktion till/från denna adress. - + Change the wallet's password. Ändra plånbokens lösenord. - + Generate a new random full size payment id. These will be unencrypted on the blockchain, see integrated_address for encrypted short payment ids. Skapa ett nytt slumpmässigt betalnings-ID av normalstorlek. Dessa kommer att vara okrypterade på blockkedjan. Se integrated_address för krypterade korta betalnings-ID. - + Print the information about the current fee and transaction backlog. Skriv ut information om aktuell avgift och transaktionseftersläpning. - + Export data needed to create a multisig wallet Exportera data som krävs för att skapa en multisig-plånbok - - make_multisig <threshold> <string1> [<string>...] - make_multisig <tröskelvärde> <string1> [<sträng>…] - - - + Turn this wallet into a multisig wallet Gör denna plånbok till en multisig-plånbok - - finalize_multisig <string> [<string>...] - finalize_multisig <sträng> [<sträng>…] - - - + Turn this wallet into a multisig wallet, extra step for N-1/N wallets Gör denna plånbok till en multisig-plånbok, extra steg för plånböcker med N-1/N - - export_multisig_info <filename> - export_multisig_info <filnamn> - - - + Export multisig info for other participants Exportera multisig-info för andra deltagare - - import_multisig_info <filename> [<filename>...] - import_multisig_info <filnamn> [<filnamn>…] - - - + Import multisig info from other participants Importera multisig-info från andra deltagare - - sign_multisig <filename> - sign_multisig <filnamn> - - - + Sign a multisig transaction from a file Signera en a multisig-transaktion från en fil - - submit_multisig <filename> - submit_multisig <filnamn> - - - + Submit a signed multisig transaction from a file Skicka en signerad multisig-transaktion från en fil - - export_raw_multisig_tx <filename> - export_raw_multisig_tx <filnamn> - - - + Export a signed multisig transaction to a file Exportera en signerad multisig-transaktion till en fil - - help [<command>] - help [<kommando>] - - - + Show the help section or the documentation about a <command>. Visa hjälpavsnittet eller dokumentationen för <kommando>. - + integer >= heltal >= - + block height blockhöjd - + No wallet found with that name. Confirm creation of new wallet named: Ingen plånbok med det namnet kunde hittas. Bekräfta skapande av ny plånbok med namn: - - can't specify more than one of --generate-new-wallet="wallet_name", --wallet-file="wallet_name", --generate-from-view-key="wallet_name", --generate-from-spend-key="wallet_name", --generate-from-keys="wallet_name", --generate-from-multisig-keys="wallet_name" and --generate-from-json="jsonfilename" - det går inte att ange fler än en av --generate-new-wallet="plånboksnamn", --wallet-file="plånboksnamn", --generate-from-view-key="plånboksnamn", --generate-from-spend-key="plånboksnamn", --generate-from-keys="plånboksnamn", --generate-from-multisig-keys="plånboksnamn" och --generate-from-json="json-filnamn" - - - + can't specify both --restore-deterministic-wallet or --restore-multisig-wallet and --non-deterministic det går inte att ange både --restore-deterministic-wallet eller --restore-multisig-wallet och --non-deterministic - + --restore-multisig-wallet uses --generate-new-wallet, not --wallet-file --restore-multisig-wallet använder --generate-new-wallet, inte --wallet-file - + specify a recovery parameter with the --electrum-seed="multisig seed here" ange en återställningsparameter med --electrum-seed="startvärde för multisig" - + Multisig seed failed verification Startvärde för multisig kunde inte verifieras - - Enter seed encryption passphrase, empty if none - Ange lösenfras för kryptering av startvärde, lämna tomt om ingen - - - - + + This address is a subaddress which cannot be used here. Denna adress är en underadress som inte kan användas här. - + Error: expected M/N, but got: Fel: förväntade M/N, men fick: - + Error: expected N > 1 and N <= M, but got: Fel: förväntade N > 1 och N <= M, men fick: - + Error: M/N is currently unsupported. Fel: M/N stöds för närvarande inte. - + Generating master wallet from %u of %u multisig wallet keys Skapar huvudplånbok från %u av %u multisig-plånboksnycklar - + failed to parse secret view key det gick inte att parsa hemlig granskningsnyckel - + failed to verify secret view key det gick inte att verifiera hemlig granskningsnyckel - + Secret spend key (%u of %u): Hemlig spendernyckel (%u av %u): - + Error: M/N is currently unsupported Fel: M/N stöds för närvarande inte - + Restore height Återställningshöjd - + Still apply restore height? (Y/Yes/N/No): Ska återställningshöjd fortfarande appliceras? (J/Ja/N/Nej): - + Warning: using an untrusted daemon at %s, privacy will be lessened Varning: använder en ej betrodd daemon på %s; sekretessen kommer att vara mindre - + Daemon either is not started or wrong port was passed. Please make sure daemon is running or change the daemon address using the 'set_daemon' command. Antingen har daemonen inte startat eller så angavs fel port. Se till att daemonen körs eller byt daemonadress med kommandot 'set_daemon'. - + Your wallet has been generated! To start synchronizing with the daemon, use the "refresh" command. Use the "help" command to see the list of available commands. -Use "help <command>" to see a command's documentation. +Use "help <command>" to see a command's documentation. Always use the "exit" command when closing monero-wallet-cli to save your current session's state. Otherwise, you might need to synchronize your wallet again (your wallet keys are NOT at risk in any case). @@ -2224,877 +1940,2168 @@ your wallet again (your wallet keys are NOT at risk in any case). Din plånbok har skapats! Använd kommandot "refresh" för att starta synkronisering med daemonen. Använd kommandot "help" för att visa en lista över tillgängliga kommandon. -Använd "help <kommando>" för att visa dokumentation för kommandot. +Använd "help <kommando>" för att visa dokumentation för kommandot. Använd alltid kommandot "exit" när du stänger monero-wallet-cli så att ditt aktuella sessionstillstånd sparas. Annars kan du bli tvungen att synkronisera din plånbok igen (din plånboks nycklar är dock INTE hotade i vilket fall som helst). - + failed to generate new mutlisig wallet det gick inte att skapa ny multisig-plånbok - + Generated new %u/%u multisig wallet: Skapa ny %u/%u-multisig-plånbok: - + Opened %u/%u multisig wallet%s Öppnade %u/%u-multisig-plånbok%s - - Use "help <command>" to see a command's documentation. + + Use "help <command>" to see a command's documentation. - Använd "help <kommando>" för att visa dokumentation för kommandot. + Använd "help <kommando>" för att visa dokumentation för kommandot. - + wallet is multisig and cannot save a watch-only version plånboken är multisig och kan inte spara en granskningsversion - - missing daemon URL argument - argument för URL till daemon saknas - - - + Unexpected array length - Exited simple_wallet::set_daemon() Oväntad matrislängd - Lämnade simple_wallet::set_daemon() - + This does not seem to be a valid daemon URL. Detta verkar inte vara en giltig daemon-URL. - - + + txid txid - - + + idx idx - + (Some owned outputs have partial key images - import_multisig_info needed) (Några ägda utgångar har partiella nyckelavbildningar - import_multisig_info krävs) - + Currently selected account: [ Aktuellt valt konto: [ - + ] ] - + Tag: Tagg: - + (No tag assigned) (Ingen tagg tilldelad) - + Balance per address: Saldo per adress: - + Address Adress - - + + Balance Saldo - - + + Unlocked balance Upplåst saldo - + Outputs Utgångar - - + + + Label Etikett - + %8u %6s %21s %21s %7u %21s %8u %6s %21s %21s %7u %21s - - usage: balance [detail] - användning: balance [detail] - - - - - usage: incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] - användning: incoming_transfers [available|unavailable] [verbose] [index=<N1>[,<N2>[,...]]] - - - + spent spenderat - + global index globalt index - + tx id tx-ID - - + + addr index addr index - + No incoming transfers Inga inkommande överföringar - + No incoming available transfers Inga inkommande tillgängliga överföringar - + No incoming unavailable transfers Inga inkommande otillgängliga överföringar - - expected at least one payment ID - åtminstone ett betalnings-ID förväntades - - - + payment betalning - + transaction transaktion - + height höjd - + unlock time upplåsningstid - + No payments with id Inga betalningar med ID - - - + + + + failed to get blockchain height: det gick inte att hämta blockkedjans höjd: - - - - - - failed to connect to the daemon - det gick inte att ansluta till daemonen - - - + Transaction %llu/%llu: txid=%s Transaktion %llu/%llu: txid=%s - + Input %llu/%llu: amount=%s Ingång %llu/%llu: belopp=%s - + failed to get output: det gick inte att hämta utgång: - + output key's originating block height shouldn't be higher than the blockchain height utgångsnyckelns ursprungsblockhöjd får inte vara högre än blockkedjans höjd - + Originating block heights: Ursprungsblockhöjder: - + | | - - + + | | - + Warning: Some input keys being spent are from Varning: Några ingångsnycklar som spenderas kommer från - + , which can break the anonymity of ring signature. Make sure this is intentional! , vilket kan bryta ringsignaturens anonymitet. Se till att detta är avsiktligt! - - + + + Ring size must not be 0 Ringstorlek för inte vara 0 - - + + + ring size %u is too small, minimum is %u ringstorlek %uär för liten, minimum är %u - + wrong number of arguments fel antal argument - - - + + + No payment id is included with this transaction. Is this okay? (Y/Yes/N/No): Inget betalnings-ID har inkluderats med denna transaktion. Är detta okej? (J/Ja/N/Nej): - - + + No outputs found, or daemon is not ready Inga utgångar hittades, eller så är daemonen inte klar - + + Failed to parse donation address: + + + + + Donating %s %s to The Monero Project (donate.getmonero.org or %s). + + + + + Donating %s %s to %s. + + + + + + + failed to parse tx_key + + + + + Tx key successfully stored. + + + + + Failed to store tx key: + + + + + + block + + + + + usage: show_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] + + + + + usage: export_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] [output=<path>] + + + + + direction + + + + + timestamp + + + + + running balance + + + + + hash + + + + + payment ID + + + + + fee + + + + + destination + + + + + index + + + + + note + + + + + CSV exported to + + + + + Warning: this will lose any information which can not be recovered from the blockchain. + + + + + This includes destination addresses, tx secret keys, tx notes, etc + + + + + Rescan anyway ? (Y/Yes/N/No): + + + + + MMS received new message + + + + + Network type: + + + + + Testnet + + + + + Stagenet + + + + + Mainnet + + + + + + command only supported by HW wallet + + + + + hw wallet does not support cold KI sync + + + + + Please confirm the key image sync on the device + + + + + Key images synchronized to height + + + + + Running untrusted daemon, cannot determine which transaction output is spent. Use a trusted daemon with --trusted-daemon and run rescan_spent + + + + + spent, + + + + + unspent + + + + + Failed to import key images + + + + + Failed to import key images: + Det gick inte att importera nyckelavbildningar: + + + + Failed to reconnect device + + + + + Failed to reconnect device: + + + + Transaction successfully saved to Transaktionen sparades till - - + + , txid , txid - + Failed to save transaction to Det gick inte att spara transaktion till - - + + Sweeping %s in %llu transactions for a total fee of %s. Is this okay? (Y/Yes/N/No): Sveper upp %s i %llu transaktioner för en total avgift på %s. Är detta okej? (J/Ja/N/Nej): - - - + + + Sweeping %s for a total fee of %s. Is this okay? (Y/Yes/N/No): Sveper upp %s för en total avgift på %s. Är detta okej? (J/Ja/N/Nej): - - Donating - Donerar - - - + This is a watch only wallet Detta är en granskningsplånbok - - usage: show_transfer <txid> - användning: show_transfer <txid> - - - + Double spend seen on the network: this transaction may or may not end up being mined En dubbelspendering upptäcktes på nätverket: denna transaktion kanske aldrig blir verifierad - + Transaction ID not found Transaktions-ID kunde inte hittas - + true sant - + failed to parse refresh type det gick inte att parsa uppdateringstyp - - + + + + + + + + + + + + + + + + + + + + + + + command not supported by HW wallet + + + + + wallet is watch-only and has no seed plånboken är enbart för granskning och har inget startvärde - - + + wallet is non-deterministic and has no seed plånboken är icke-deterministisk och har inget startvärde - - + + Enter optional seed offset passphrase, empty to see raw seed + + + + + Incorrect password + + + + + Current fee is %s %s per %s + + + + + + Send this multisig info to all other participants, then use exchange_multisig_keys <info1> [<info2>...] with others' multisig info + + + + + Multisig wallet has been successfully created. Current wallet type: + + + + + Failed to perform multisig keys exchange: + + + + + Failed to load multisig transaction from MMS + + + + + + Invalid key image + + + + + Invalid txid + + + + + Key image either not spent, or spent with mixin 0 + + + + + Failed to get key image ring: + + + + + File doesn't exist + + + + + Invalid ring specification: + + + + + Invalid key image: + + + + + Invalid ring type, expected relative or abosolute: + + + + + + Error reading line: + + + + + Invalid ring: + + + + + Invalid relative ring: + + + + + Invalid absolute ring: + + + + + Failed to set ring for key image: + + + + + Continuing. + + + + + Missing absolute or relative keyword + + + + + + invalid index: must be a strictly positive unsigned integer + + + + + invalid index: indices wrap + + + + + invalid index: indices should be in strictly ascending order + + + + + failed to set ring + + + + + First line is not an amount + + + + + Invalid output: + + + + + Bad argument: + + + + + should be "add" + + + + + Failed to open file + + + + + Invalid output key, and file doesn't exist + + + + + Failed to mark output spent: + + + + + + Invalid output + + + + + Failed to mark output unspent: + + + + + Spent: + + + + + Not spent: + + + + + Failed to check whether output is spent: + + + + + Failed to save known rings: + + + + + Please confirm the transaction on the device + + + + + wallet is watch-only and cannot transfer plånboken är enbart för granskning och kan inte göra överföringar - + + + WARNING: this is a non default ring size, which may harm your privacy. Default is recommended. + + + + + WARNING: from v8, ring size will be fixed and this setting will be ignored. + + + + + + + priority must be either 0, 1, 2, 3, or 4, or one of: + + + + could not change default priority det gick inte att ändra standardinställning för prioritet - + + invalid argument: must be either 0/never, 1/action, or 2/encrypt/decrypt + + + + + Device name not specified + + + + + Device reconnect failed + + + + + Device reconnect failed: + + + + + Show the incoming transfers, all or filtered by availability and address index. + +Output format: +Amount, Spent("T"|"F"), "locked"|"unlocked", RingCT, Global Index, Transaction Hash, Address Index, [Public Key, Key Image] + + + + + Transfer <amount> to <address>. If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) + + + + + Transfer <amount> to <address> and lock it for <lockblocks> (max. 1000000). If the parameter "index=<N1>[,<N2>,...]" is specified, the wallet uses outputs received by addresses of those indices. If omitted, the wallet randomly chooses address indices to be used. In any case, it tries its best not to combine outputs across multiple addresses. <priority> is the priority of the transaction. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. Multiple payments can be made at once by adding URI_2 or <address_2> <amount_2> etcetera (before the payment ID, if it's included) + + + + + Send all unlocked balance to an address and lock it for <lockblocks> (max. 1000000). If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. <priority> is the priority of the sweep. The higher the priority, the higher the transaction fee. Valid values in priority order (from lowest to highest) are: unimportant, normal, elevated, priority. If omitted, the default value (see the command "set priority") is used. <ring_size> is the number of inputs to include for untraceability. + + + + + Send all unlocked balance to an address. If the parameter "index<N1>[,<N2>,...]" is specified, the wallet sweeps outputs received by those address indices. If omitted, the wallet randomly chooses an address index to be used. If the parameter "outputs=<N>" is specified and N > 0, wallet splits the transaction into N even outputs. + + + + + Sign a transaction from a file. If the parameter "export_raw" is specified, transaction raw hex data suitable for the daemon RPC /sendrawtransaction is exported. + + + + + 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. + + + + + Available options: + seed language + Set the wallet's seed language. + always-confirm-transfers <1|0> + Whether to confirm unsplit txes. + print-ring-members <1|0> + Whether to print detailed information about ring members during confirmation. + store-tx-info <1|0> + Whether to store outgoing tx info (destination address, payment ID, tx secret key) for future reference. + default-ring-size <n> + Set the default ring size (obsolete). + auto-refresh <1|0> + Whether to automatically synchronize new blocks from the daemon. + refresh-type <full|optimize-coinbase|no-coinbase|default> + Set the wallet's refresh behaviour. + priority [0|1|2|3|4] + Set the fee to default/unimportant/normal/elevated/priority. + confirm-missing-payment-id <1|0> + ask-password <0|1|2 (or never|action|decrypt)> + unit <monero|millinero|micronero|nanonero|piconero> + Set the default monero (sub-)unit. + min-outputs-count [n] + Try to keep at least that many outputs of value at least min-outputs-value. + min-outputs-value [n] + Try to keep at least min-outputs-count outputs of at least that value. + merge-destinations <1|0> + Whether to merge multiple payments to the same destination address. + confirm-backlog <1|0> + Whether to warn if there is transaction backlog. + confirm-backlog-threshold [n] + Set a threshold for confirm-backlog to only warn if the transaction backlog is greater than n blocks. + refresh-from-block-height [n] + Set the height before which to ignore blocks. + auto-low-priority <1|0> + Whether to automatically use the low priority fee level when it's safe to do so. + segregate-pre-fork-outputs <1|0> + Set this if you intend to spend outputs on both Monero AND a key reusing fork. + key-reuse-mitigation2 <1|0> + Set this if you are not sure whether you will spend on a key reusing Monero fork later. +subaddress-lookahead <major>:<minor> + Set the lookahead sizes for the subaddress hash table. + Set this if you are not sure whether you will spend on a key reusing Monero fork later. + segregation-height <n> + Set to the height of a key reusing fork you want to use, 0 to use default. + + + + + Set the transaction key (r) for a given <txid> in case the tx was made by some other device or 3rd party wallet. + + + + + Show the incoming/outgoing transfers within an optional height range. + +Output format: +In or Coinbase: Block Number, "block"|"in", Time, Amount, Transaction Hash, Payment ID, Subaddress Index, "-", Note +Out: Block Number, "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Destinations, Input addresses**, "-", Note +Pool: "pool", "in", Time, Amount, Transaction Hash, Payment Id, Subaddress Index, "-", Note, Double Spend Note +Pending or Failed: "failed"|"pending", "out", Time, Amount*, Transaction Hash, Payment ID, Fee, Input addresses**, "-", Note + +* Excluding change and fee. +** Set of address indices used as inputs in this transfer. + + + + + export_transfers [in|out|all|pending|failed|coinbase] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] [output=<filepath>] + + + + + Export to CSV the incoming/outgoing transfers within an optional height range. + + + + + Rescan the blockchain from scratch, losing any information which can not be recovered from the blockchain itself. + + + + + Export a signed set of key images to a <filename>. + + + + + Synchronizes key images with the hw wallet. + + + + + Attempts to reconnect HW wallet. + + + + + Performs extra multisig keys exchange rounds. Needed for arbitrary M/N multisig wallets + + + + + Interface with the MMS (Multisig Messaging System) +<subcommand> is one of: + init, info, signer, list, next, sync, transfer, delete, send, receive, export, note, show, set, help + send_signer_config, start_auto_config, stop_auto_config, auto_config +Get help about a subcommand with: help mms <subcommand>, or mms help <subcommand> + + + + + Initialize and configure the MMS for M/N = number of required signers/number of authorized signers multisig + + + + + Display current MMS configuration + + + + + Set or modify authorized signer info (single-word label, transport address, Monero address), or list all signers + + + + + List all messages + + + + + Evaluate the next possible multisig-related action(s) according to wallet state, and execute or offer for choice +By using 'sync' processing of waiting messages with multisig sync info can be forced regardless of wallet state + + + + + Force generation of multisig sync info regardless of wallet state, to recover from special situations like "stale data" errors + + + + + Initiate transfer with MMS support; arguments identical to normal 'transfer' command arguments, for info see there + + + + + Delete a single message by giving its id, or delete all messages by using 'all' + + + + + Send a single message by giving its id, or send all waiting messages + + + + + Check right away for new messages to receive + + + + + Write the content of a message to a file "mms_message_content" + + + + + Send a one-line message to an authorized signer, identified by its label, or show any waiting unread notes + + + + + Show detailed info about a single message + + + + + Available options: + auto-send <1|0> + Whether to automatically send newly generated messages right away. + + + + + + Send completed signer config to all other authorized signers + + + + + Start auto-config at the auto-config manager's wallet by issuing auto-config tokens and optionally set others' labels + + + + + Delete any auto-config tokens and abort a auto-config process + + + + + Start auto-config by using the token received from the auto-config manager + + + + + Print the ring(s) used to spend a given key image or transaction (if the ring size is > 1) + +Output format: +Key Image, "absolute", list of rings + + + + + Set the ring used for a given key image, so it can be reused in a fork + + + + + Save known rings to the shared rings database + + + + + Mark output(s) as spent so they never get selected as fake outputs in a ring + + + + + Marks an output as unspent so it may get selected as a fake output in a ring + + + + + Checks whether an output is marked as spent + + + + + Returns version information + + + + 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) full (långsammast, inga antaganden); optimize-coinbase (snabb, antar att hela coinbase-transaktionen betalas till en enda adress); no-coinbase (snabbast, antar att ingen coinbase-transaktion tas emot), default (samma som optimize-coinbase) - + + 0, 1, 2, 3, or 4, or one of + + + + + 0|1|2 (or never|action|decrypt) + + + + monero, millinero, micronero, nanonero, piconero monero, millinero, micronero, nanonero, piconero - + + <major>:<minor> + + + + + <device_name[:device_spec]> + + + + + wrong number range, use: %s + + + + Wallet name not valid. Please try again or use Ctrl-C to quit. Plånbokens namn ej giltigt. Försök igen eller använd Ctrl-C för att avsluta. - + Wallet and key files found, loading... Plånbok och nyckelfil hittades, läser in … - + Key file found but not wallet file. Regenerating... Nyckelfilen hittades men inte plånboksfilen. Återskapar … - + Key file not found. Failed to open wallet: Nyckelfilen kunde inte hittas. Det gick inte att öppna plånbok: - + Generating new wallet... Skapar ny plånbok … - + + NOTE: the following %s can be used to recover access to your wallet. Write them down and store them somewhere safe and secure. Please do not store them in your email or on file storage services outside of your immediate control. + + + + + + string + + + + + 25 words + + + + + Can't specify more than one of --testnet and --stagenet + + + + + can't specify more than one of --generate-new-wallet="wallet_name", --wallet-file="wallet_name", --generate-from-view-key="wallet_name", --generate-from-spend-key="wallet_name", --generate-from-keys="wallet_name", --generate-from-multisig-keys="wallet_name", --generate-from-json="jsonfilename" and --generate-from-device="wallet_name" + + + + Electrum-style word list failed verification Det gick inte att verifiera ordlista av Electrum-typ - - - - - - - - - - + + Enter seed offset passphrase, empty if none + + + + + + + + + + + + + No data supplied, cancelled Inga data angivna, avbryter - - - - - - - - - - - - + + + + + + + + + + + + failed to parse address det gick inte att parsa adressen - - + + failed to parse view key secret key det gick inte att parsa hemlig granskningsnyckel - - + + failed to verify view key secret key det gick inte att verifiera hemlig granskningsnyckel - - - + + + view key does not match standard address granskningsnyckel matchar inte standardadress - - - - - + + + + + + account creation failed det gick inte att skapa konto - - - + + + failed to parse spend key secret key det gick inte att parsa spendernyckel hemlig nyckel - - + + failed to verify spend key secret key det gick inte att verifiera spendernyckel hemlig nyckel - - + + spend key does not match standard address spendernyckel matchar inte standardadress - + + No restore height is specified. + + + + + Assumed you are creating a new account, restore will be done from current estimated blockchain height. + + + + + Use --restore-height if you want to restore an already setup account from a specific height + + + + + account creation aborted + + + + + can't specify --subaddress-lookahead and --wallet-file at the same time + + + + failed to open account det gick inte att öppna konto - - - - - + + + + + wallet is null plånbok är null - - + + Failed to initialize ring database: privacy enhancing features will be inactive + + + + + If your display freezes, exit blind with ^C, then run again with --use-english-language-names + + + + + invalid language choice entered. Please try again. ogiltigt språkval har angivits. Försök igen. - + View key: Granskningsnyckel: - + + Generated new wallet on hw device: + + + + + Key file not found. Failed to open wallet + + + + You may want to remove the file "%s" and try again Du kan också prova att bort filen "%s" och försöka igen - + failed to deinitialize wallet det gick inte att avinitiera plånboken - - - + + Watch only wallet saved as: + + + + + Failed to save watch only wallet: + + + + + + this command requires a trusted daemon. Enable with --trusted-daemon detta kommando kräver en betrodd daemon. Aktivera med --trusted-daemon - + + Expected trusted or untrusted, got + + + + + trusted + + + + + untrusted + + + + blockchain can't be saved: blockkedjan kan inte sparas: - - + + NOTE: this transaction uses an encrypted payment ID: consider using subaddresses instead + + + + + WARNING: this transaction uses an unencrypted payment ID: consider using subaddresses instead + + + + + Password needed (%s) - use the refresh command + + + + + Enter password + + + + + Device requires attention + + + + + Enter device PIN + + + + + Failed to read device PIN + + + + + Please enter the device passphrase on the device + + + + + Enter device passphrase + + + + + Failed to read device passphrase + + + + + The first refresh has finished for the HW-based wallet with received money. hw_key_images_sync is needed. + + + + + Do you want to do it now? (Y/Yes/N/No): + + + + + hw_key_images_sync skipped. Run command manually before a transfer. + + + + + daemon is busy. Please try again later. daemonen är upptagen. Försök igen senare. - - + + no connection to daemon. Please make sure daemon is running. ingen anslutning till daemonen. Se till att daemonen körs. - + refresh error: fel vid uppdatering: - + + (Some owned outputs have missing key images - import_key_images needed) + + + + Balance: Saldo: - + + Invalid keyword: + + + + pubkey publik nyckel - + key image nyckelavbildning - - + + + unlocked upplåst - + ringct ringct - + + Heights: + + + + T S - + F F - + locked låst - + RingCT RingCT - + - - - + payment ID has invalid format, expected 16 or 64 character hex string: betalnings-ID har ogiltigt format. En hexadecimal sträng med 16 eller 64 tecken förväntades: - + failed to get spent status det gick inte att hämta spenderstatus - + + failed to find construction data for tx input + + + + the same transaction samma transaktion - + blocks that are temporally very close block som ligger väldigt nära varandra i tiden - - Locked blocks too high, max 1000000 (˜4 yrs) - Låsta block för högt, max 1000000 (˜~4 år) + + (Y/Yes/N/No): + - - + + Choose processing: + + + + + Sign tx + + + + + Send the tx for submission to + + + + + Send the tx for signing to + + + + + Submit tx + + + + + unknown + + + + + Choice: + + + + + Wrong choice + + + + + Id + + + + + I/O + + + + + Authorized Signer + + + + + Message Type + + + + + Height + + + + + R + + + + + Message State + + + + + Since + + + + + ago + + + + + # + + + + + Transport Address + + + + + Auto-Config Token + + + + + Monero Address + + + + + + + <not set> + + + + + Message + + + + + In/out: + + + + + State: + + + + + %s since %s, %s ago + + + + + Sent: Never + + + + + Sent: %s, %s ago + + + + + Authorized signer: + + + + + Content size: + + + + + bytes + + + + + Content: + + + + + (binary data) + + + + + Send these messages now? + + + + + Queued for sending. + + + + + Invalid message id + + + + + usage: mms init <required_signers>/<authorized_signers> <own_label> <own_transport_address> + + + + + The MMS is already initialized. Re-initialize by deleting all signer info and messages? + + + + + Error in the number of required signers and/or authorized signers + + + + + The MMS is not active. + + + + + Invalid signer number + + + + + mms signer [<number> <label> [<transport_address> [<monero_address>]]] + + + + + Invalid Monero address + + + + + Wallet state does not allow changing Monero addresses anymore + + + + + Usage: mms list + + + + + Usage: mms next [sync] + + + + + No next step: + + + + + prepare_multisig + + + + + make_multisig + + + + + exchange_multisig_keys + + + + + + export_multisig_info + + + + + import_multisig_info + + + + + sign_multisig + + + + + submit_multisig + + + + + Send tx + + + + + Process signer config + + + + + Replace current signer config with the one displayed above? + + + + + Process auto config data + + + + + Nothing ready to process + + + + + Usage: mms sync + + + + + Usage: mms delete (<message_id> | all) + + + + + Delete all messages? + + + + + Usage: mms send [<message_id>] + + + + + Usage: mms receive + + + + + Usage: mms export <message_id> + + + + + Message content saved to: + + + + + Failed to to save message content + + + + + Usage: mms note [<label> <text>] + + + + + No signer found with label + + + + + Usage: mms show <message_id> + + + + + Usage: mms set <option_name> [<option_value>] + + + + + Wrong option value + + + + + Auto-send is on + + + + + Auto-send is off + + + + + Unknown option + + + + + Usage: mms help [<subcommand>] + + + + + Usage: mms send_signer_config + + + + + Signer config not yet complete + + + + + Usage: mms start_auto_config [<label> <label> ...] + + + + + There are signers without a label set. Complete labels before auto-config or specify them as parameters here. + + + + + Auto-config is already running. Cancel and restart? + + + + + Usage: mms stop_auto_config + + + + + Delete any auto-config tokens and stop auto-config? + + + + + Usage: mms auto_config <auto_config_token> + + + + + Invalid auto-config token + + + + + Auto-config already running. Cancel and restart? + + + + + The MMS is not active. Activate using the "mms init" command + + + + + Invalid MMS subcommand + + + + + + Error in MMS command: + + + + + Good signature Godkänd signatur - - - + + + Bad signature Felaktig signatur - - usage: integrated_address [payment ID] - användning: integrated_address [betalnings-ID] - - - + Standard address: Standardadress: - + failed to parse payment ID or address det gick inte att parsa betalnings-ID eller adress - - usage: address_book [(add (<address> [pid <long or short payment id>])|<integrated address> [<description possibly with whitespaces>])|(delete <index>)] - användning: address_book [(add (<adress> [pid <långt eller kort betalnings-ID>])|<integrerad adress> [<beskrivning eventuellt med blanktecken>])|(delete <index>)] - - - + failed to parse payment ID det gick inte att parsa betalnings-ID - + failed to parse index det gick inte att parsa index - + Address book is empty. Adressboken är tom. - + Index: Index: - - + + Address: Adress: - + Payment ID: Betalnings-ID: - - + + Description: Beskrivning: - - usage: set_tx_note [txid] free text note - användning: set_tx_note [txid] fritextanteckning - - - - usage: get_tx_note [txid] - användning: get_tx_note [txid] - - - - usage: sign <filename> - användning: sign <filnamn> - - - + wallet is watch-only and cannot sign plånboken är enbart för granskning och kan inte signera - - - - + + + + failed to read file det gick inte att läsa filen - - usage: check_tx_proof <txid> <address> <signature_file> [<message>] - användning: check_tx_proof <txid> <adress> <signaturfil> [<meddelande>] - - - - - + + + failed to load signature file det gick inte att läsa in signaturfil - - usage: get_spend_proof <txid> [<message>] - användning: get_spend_proof <txid> [<meddelande>] - - - + wallet is watch-only and cannot generate the proof plånboken är enbart för granskning och kan inte skapa beviset - - usage: check_spend_proof <txid> <signature_file> [<message>] - användning: check_spend_proof <txid> <signaturfil> [<meddelande>] - - - - usage: get_reserve_proof (all|<amount>) [<message>] - användning: get_reserve_proof (all|<belopp>) [<meddelande>] - - - + The reserve proof can be generated only by a full wallet Beviset på reserv kan endast skapas av en standardplånbok - - usage: check_reserve_proof <address> <signature_file> [<message>] - användning: check_reserve_proof <adress> <signaturfil> [<meddelande>] - - - + Address must not be a subaddress Adressen får inte vara en underadress - + Good signature -- total: %s, spent: %s, unspent: %s Godkänd signatur -- summa: %s, spenderat: %s, ej spenderat: %s - - usage: show_transfers [in|out|all|pending|failed] [index=<N1>[,<N2>,...]] [<min_height> [<max_height>]] - användning: show_transfers [in|out|all|pending|failed] [index=<N1>[, <N2>, …]] [<minhöjd> [<maxhöjd>]] - - - + [Double spend seen on the network: this transaction may or may not end up being mined] [En dubbelspendering upptäcktes på nätverket: denna transaktion kanske aldrig blir verifierad] - - usage: unspent_outputs [index=<N1>[,<N2>,...]] [<min_amount> [<max_amount>]] - användning: unspent_outputs [index=<N1>[, <N2>, …]] [<min_belopp> [<max_belopp>]] - - - + There is no unspent output in the specified address Det finns ingen ej spenderad utgång i den angivna adressen - + (no daemon) (ingen daemon) - + (out of sync) (inte synkroniserad) - + (Untitled account) (Ej namngivet konto) - - - - - - + + + + + + failed to parse index: det gick inte att parsa index: - - + + specify an index between 0 and ange ett index mellan 0 och - - usage: - account - account new <label text with white spaces allowed> - account switch <index> - account label <index> <label text with white spaces allowed> - account tag <tag_name> <account_index_1> [<account_index_2> ...] - account untag <account_index_1> [<account_index_2> ...] - account tag_description <tag_name> <description> - användning: - account - account new <etikettext med blanktecken tillåtna> - account switch <index> - account label <index> <etikettext med blanktecken tillåtna> - account tag <taggnamn> <kontoindex_1> [<kontoindex_2> …] - account untag <kontoindex_1> [<kontoindex_2> …] - account tag_description <taggnamn> <beskrivning> - - - + Grand total: Balance: @@ -3103,463 +4110,386 @@ Totalsumma: Saldo: - + , unlocked balance: , upplåst saldo: - + Untagged accounts: Otaggade konton: - + Tag %s is unregistered. Taggen %s har inte registrerats. - + Accounts with tag: Konton med tagg: - + Tag's description: Taggens beskrivning: - + Account Konto - + %c%8u %6s %21s %21s %21s %c%8u %6s %21s %21s %21s - + ---------------------------------------------------------------------------------- ---------------------------------------------------------------------------------- - + %15s %21s %21s %15s %21s %21s - + Primary address Primär adress - + (used) (används) - + (Untitled address) (Ej namngiven adress) - + <index_min> is already out of bound <index_min> är redan utanför tillåtet intervall - + <index_max> exceeds the bound <index_max> är utanför tillåtet intervall - - usage: address [ new <label text with white spaces allowed> | all | <index_min> [<index_max>] | label <index> <label text with white spaces allowed> ] - användning: address [new <etikettext med blanktecken tillåtna> | all | <index_min> [<index_max>] | label <index> <etikettext med blanktecken tillåtna>] - - - - + + Integrated addresses can only be created for account 0 Integrerade adresser kan bara skapas för konto 0 - + Integrated address: %s, payment ID: %s Integrerad adress: %s, betalnings-ID: %s - + Subaddress: Underadress: - - usage: get_description - användning: get_description - - - + no description found ingen beskrivning hittades - + description found: beskrivning hittades: - + Filename: Filnamn: - + Watch only Endast granskning - + %u/%u multisig%s %u/%u multisig%s - + Normal Normal - + + Type: Typ: - - Testnet: - Testnet: - - - - Yes - Ja - - - - No - Nej - - - + This wallet is multisig and cannot sign Plånboken är multisig och kan inte signera - - usage: verify <filename> <address> <signature> - användning: verify <filnamn> <adress> <signatur> - - - + Bad signature from Felaktig signatur från - + Good signature from Godkänd signatur från - - usage: export_key_images <filename> - användning: export_key_images <filnamn> - - - + wallet is watch-only and cannot export key images plånboken är enbart för granskning och kan inte exportera nyckelavbildningar - - - + + + failed to save file det gick inte att spara fil - + Signed key images exported to Signerade nyckelavbildningar exporterades till - - usage: import_key_images <filename> - användning: import_key_images <filnamn> - - - - usage: export_outputs <filename> - användning: export_outputs <filnamn> - - - + Outputs exported to Utgångar exporterades till - - usage: import_outputs <filename> - användning: import_outputs <filnamn> - - - - - - + + + + + amount is wrong: beloppet är fel: - + + expected number from 0 to förväntades: ett tal från 0 till - + Sweeping Sveper upp - + Money successfully sent, transaction: Pengar skickades, transaktion: - + Change goes to more than one address Växel går till fler än en adress - + %s change to %s %s växel till %s - + no change ingen växel - - - + + + Transaction successfully signed to file Transaktionen signerades till fil - - usage: get_tx_key <txid> - användning: get_tx_key <txid> - - - - - - - - - - - + + + + + + + + + + failed to parse txid det gick inte att parsa txid - + Tx key: Tx-nyckel: - + no tx keys found for this txid inga tx-nycklar kunde hittas för detta txid - - usage: get_tx_proof <txid> <address> [<message>] - användning: get_tx_proof <txid> <adress> [<meddelande>] - - - - - + + + signature file saved to: signaturfilen sparades till: - - - + + + failed to save signature file det gick inte att spara signaturfilen - - usage: check_tx_key <txid> <txkey> <address> - användning: check_tx_key <txid> <txnyckel> <adress> - - - - + + failed to parse tx key det gick inte att parsa txnyckel - - - + + + error: fel: - - + + received mottaget - - + + in txid i txid - - + + received nothing in txid tog emot ingenting i txid - - + + WARNING: this transaction is not yet included in the blockchain! VARNING: denna transaktion är ännu inte inkluderad i blockkedjan! - - + + This transaction has %u confirmations Denna transaktion har %u bekräftelser - - + + WARNING: failed to determine number of confirmations! VARNING: det gick inte att bestämma antal bekräftelser! - + bad min_height parameter: felaktig parameter för min_höjd: - + bad max_height parameter: felaktig parameter för max_höjd: - + in in - - - out - ut - - - - failed - misslyckades - - - - pending - väntande - - - + <min_amount> should be smaller than <max_amount> <min_belopp> måste vara mindre än <max_belopp> - + Amount: Belopp: - + , number of keys: , antal nycklar: - + - + Min block height: Minblockhöjd: - + Max block height: Maxblockhöjd: - + Min amount found: Minbelopp funnet: - + Max amount found: Maxbelopp funnet: - + Total count: Totalt antal: - + Bin size: Storlek för binge: - + Outputs per *: Utgångar per *: - + count ^ @@ -3568,52 +4498,52 @@ Utgångar per *: - + | | - + + + - - +--> block height + + +--> block height - +--> blockhöjd + +--> blockhöjd - + ^ ^ - + ^ ^ - + - + wallet plånbok - - + + Random payment ID: Slumpmässigt betalnings-ID: - + Matching integrated address: Matchande integrerad adress: @@ -3630,11 +4560,6 @@ Utgångar per *: Give threshold and participants at once as M/N Ange tröskelvärde och deltagare på en gång som M/N - - - How many participants wil share parts of the multisig wallet - Hur många deltagare kommer att dela delar av multisig-plånboken - How many signers are required to sign a valid transaction @@ -3646,19 +4571,34 @@ Utgångar per *: Skapa multisig-plånböcker för testnet - + Generating %u %u/%u multisig wallets Skapar %u %u/%u multisig-plånböcker - + Error verifying multisig extra info Ett fel uppstod när extra multisig-info verifierades - - Error finalizing multisig - Ett fel uppstod vid slutförande av multisig + + How many participants will share parts of the multisig wallet + + + + + Create stagenet multisig wallets + + + + + Create an address file for new wallets + + + + + Failed to verify multisig info + @@ -3671,133 +4611,495 @@ Utgångar per *: Ett fel uppstod när multisig-plånböcker skapades: - + This program generates a set of multisig wallets - use this simpler scheme only if all the participants trust each other Programmet skapar en uppsättning multisig-plånböcker - använd endast detta enklare system om alla deltagare litar på varandra - + + Error: Can't specify more than one of --testnet and --stagenet + + + + Error: expected N/M, but got: Fel: förväntade N/M, men fick: - - + + Error: either --scheme or both of --threshold and --participants may be given Fel: antingen --scheme eller både --threshold och --participants får anges - + Error: expected N > 1 and N <= M, but got N==%u and M==%d Fel: förväntade N > 1 och N <= M, men fick N=%u och M=%d - + Error: --filename-base is required Fel: --filename-base måste anges + + + mms::message_store - - Error: unsupported scheme: only N/N and N-1/N are supported - Fel: systemet stöds inte: bara N/N och N-1/N stöds + + Use PyBitmessage instance at URL <arg> + + + + + Specify <arg> as username:password for PyBitmessage API + + + + + Auto-config cannot proceed because auto config data from other signers is not complete + + + + + The signer config is not complete. + + + + + Wallet can't go multisig because key sets from other signers are missing or not complete. + + + + + Wallet can't start another key exchange round because key sets from other signers are missing or not complete. + + + + + Syncing not done because multisig sync data from other signers are missing or not complete. + + + + + There are waiting messages, but nothing is ready to process under normal circumstances + + + + + +Use "mms next sync" if you want to force processing of the waiting sync data + + + + + +Use "mms note" to display the waiting notes + + + + + There are no messages waiting to be processed. + + + + + key set + + + + + additional key set + + + + + multisig sync data + + + + + partially signed tx + + + + + fully signed tx + + + + + note + + + + + signer config + + + + + auto-config data + + + + + unknown message type + + + + + in + in + + + + out + ut + + + + unknown message direction + + + + + ready to send + + + + + sent + + + + + waiting + + + + + processed + + + + + cancelled + + + + + unknown message state + sw - + Generate new wallet and save it to <arg> Skapa ny plånbok och spara den till <arg> - + + Generate new wallet from device and save it to <arg> + + + + Generate incoming-only wallet from view key Skapa granskningsplånbok från granskningsnyckel - + Generate deterministic wallet from spend key Skapa deterministisk plånbok från spendernyckel - + Generate wallet from private keys Skapa plånbok från privata nycklar - + Generate a master wallet from multisig wallet keys Skapa en huvudplånbok från multisig-plånboksnycklar - + Language for mnemonic Språk för minnesbaserat startvärde - + Specify Electrum seed for wallet recovery/creation Ange Electrum-startvärde för att återställa/skapa plånbok - + Recover wallet using Electrum-style mnemonic seed Återställ plånbok genom att använda minnesbaserat startvärde (Electrum-typ) - + Recover multisig wallet using Electrum-style mnemonic seed Återställ multisig-plånbok genom att använda minnesbaserat startvärde (Electrum-typ) - + Generate non-deterministic view and spend keys Skapa icke-deterministisk granskningsnyckel och spendernyckel - - Enable commands which rely on a trusted daemon - Aktivera kommandon som kräver en betrodd daemon + + invalid argument: must be either 0/1, true/false, y/n, yes/no + - + + DNSSEC validation passed + + + + + WARNING: DNSSEC validation was unsuccessful, this address may not be correct! + + + + + For URL: + + + + + Monero Address = + + + + + Is this OK? (Y/n) + + + + + you have cancelled the transfer request + + + + + failed to parse index: + det gick inte att parsa index: + + + + invalid format for subaddress lookahead; must be <major>:<minor> + + + + + no connection to daemon. Please make sure daemon is running. + ingen anslutning till daemonen. Se till att daemonen körs. + + + + RPC error: + RPC-fel: + + + + failed to get random outputs to mix: + + + + + + Not enough money in unlocked balance + + + + + Failed to find a way to create transactions. This is usually due to dust which is so small it cannot pay for itself in fees, or trying to send more money than the unlocked balance, or not leaving enough for fees + + + + + not enough outputs for specified ring size + inte tillräckligt med utgångar för angiven ringstorlek + + + + output amount + utgångens belopp + + + + found outputs to use + hittade utgångar att använda + + + + Please use sweep_unmixable. + + + + + transaction was not constructed + transaktionen konstruerades inte + + + + transaction %s was rejected by daemon with status: + transaktionen %s avvisades av daemonen med status: + + + + Reason: + + + + + one of destinations is zero + ett av målen är noll + + + + failed to find a suitable way to split transactions + det gick inte att hitta ett lämpligt sätt att dela upp transaktioner + + + + unknown transfer error: + okänt överföringsfel: + + + + Multisig error: + Multisig-fel: + + + + internal error: + internt fel: + + + + unexpected error: + oväntat fel: + + + + There was an error, which could mean the node may be trying to get you to retry creating a transaction, and zero in on which outputs you own. Or it could be a bona fide error. It may be prudent to disconnect from this node, and not try to send a transaction immediately. Alternatively, connect to another node so the original node cannot correlate information. + + + + + File %s likely stores wallet private keys! Use a different file name. + + + + + File %s already exists. Are you sure to overwrite it? (Y/Yes/N/No): + + + + + seconds + + + + + minutes + + + + + hours + + + + + days + + + + + months + + + + + a long time + + + + + This is the command line monero wallet. It needs to connect to a monero +daemon to work correctly. +WARNING: Do not reuse your Monero keys on another fork, UNLESS this fork has key reuse mitigations built in. Doing so will harm your privacy. + + + + + Unknown command: + Okänt kommando: + + + Allow communicating with a daemon that uses a different RPC version Tillåt kommunikation med en daemon som använder en annan version av RPC - + Restore from specific blockchain height Återställ från angiven blockkedjehöjd - + The newly created transaction will not be relayed to the monero network Den nyss skapade transaktionen kommer inte att skickas vidare till monero-nätverket - + + Create an address file for new wallets + + + + + Display English language names + + + + + failed to read wallet password + det gick inte att läsa lösenord för plånboken + + + + Enter a new password for the wallet + + + + + Wallet password + + + + + daemon is busy. Please try again later. daemonen är upptagen. Försök igen senare. - + possibly lost connection to daemon anslutning till daemonen kan ha förlorats - + Error: Fel: - - This is the command line monero wallet. It needs to connect to a monero -daemon to work correctly. - Detta är kommandoradsplånboken för Monero. Den måste ansluta till en Monero- -daemon för att fungera korrekt. - - - + Failed to initialize wallet Det gick inte att initiera plånbok @@ -3805,300 +5107,360 @@ daemon för att fungera korrekt. tools::wallet2 - + Use daemon instance at <host>:<port> Använd daemonen på <värddator>:<port> - + Use daemon instance at host <arg> instead of localhost Använd daemonen på värddatorn <arg> istället för localhost - + Wallet password file Lösenordsfil för plånboken - + Use daemon instance at port <arg> instead of 18081 Använd daemonen på port <arg> istället för 18081 - + For testnet. Daemon must also be launched with --testnet flag För testnet. Daemonen måste också startas med flaggan --testnet - - Restricts to view-only commands - Begränsar till granskningskommandon - - - + can't specify daemon host or port more than once det går inte ange värd eller port för daemonen mer än en gång - + can't specify more than one of --password and --password-file det går inte att ange fler än en av --password och --password-file - + the password file specified could not be read det gick inte att läsa angiven lösenordsfil - + Failed to load file Det gick inte att läsa in fil - + Wallet password (escape/quote as needed) Lösenord för plånboken (använd escape-sekvenser eller citattecken efter behov) - + + Enable commands which rely on a trusted daemon + Aktivera kommandon som kräver en betrodd daemon + + + + Disable commands which rely on a trusted daemon + + + + Specify username[:password] for daemon RPC client Ange användarnamn[:lösenord] för RPC-klient till daemonen + + + For stagenet. Daemon must also be launched with --stagenet flag + + + + + Set shared ring database path + + + + + Number of rounds for the key derivation function + + + HW device to use + + + + + HW device wallet derivation path (e.g., SLIP-10) + + + + + --trusted-daemon and --untrusted-daemon are both seen, assuming untrusted + + + + + Daemon is local, assuming trusted + Daemonen är lokal, utgår från att den är betrodd + + + no password specified; use --prompt-for-password to prompt for a password inget lösenord har angivits; använd --prompt-for-password för att fråga efter lösenord - + + Enter a new password for the wallet + + + + + Wallet password + + + + Failed to parse JSON Det gick inte att parsa JSON - + Version %u too new, we can only grok up to %u Version %u är för ny, vi förstår bara upp till %u - + failed to parse view key secret key det gick inte att parsa hemlig granskningsnyckel - - - + + + failed to verify view key secret key det gick inte att verifiera hemlig granskningsnyckel - + failed to parse spend key secret key det gick inte att parsa spendernyckel hemlig nyckel - - - + + + failed to verify spend key secret key det gick inte att verifiera spendernyckel hemlig nyckel - + Electrum-style word list failed verification Det gick inte att verifiera ordlista av Electrum-typ - - At least one of Electrum-style word list and private view key and private spend key must be specified - Åtminstone en av ordlista av Electrum-typ och privat granskningsnyckel och privat spendernyckel måste anges + + At least one of either an Electrum-style word list, private view key, or private spend key must be specified + - + Both Electrum-style word list and private key(s) specified Både ordlista av Electrum-typ och privat nyckel har angivits - + invalid address ogiltig adress - + view key does not match standard address granskningsnyckel matchar inte standardadress - + spend key does not match standard address spendernyckel matchar inte standardadress - + Cannot generate deprecated wallets from JSON Det går inte att skapa inaktuella plånböcker från JSON - + failed to parse address: det gick inte att parsa adressen: - + Address must be specified in order to create watch-only wallet Adress måste anges för att kunna skapa granskningsplånbok - + failed to generate new wallet: det gick inte att skapa ny plånbok: - - - - - - - - + + Password is needed to compute key image for incoming monero + + + + + Invalid password: password is needed to compute key image for incoming monero + + + + + + Primary account Primärt konto - + No funds received in this tx. Inga pengar togs emot i denna tx. - + failed to read file det gick inte att läsa filen + + + Set subaddress lookahead sizes to <major>:<minor> + + tools::wallet_rpc_server - - Daemon is local, assuming trusted - Daemonen är lokal, utgår från att den är betrodd - - - + Failed to create directory Det gick inte att skapa mapp - + Failed to create directory %s: %s Det gick inte att skapa mapp %s: %s - + Cannot specify -- Det går inte att ange -- - + and -- och -- - + Failed to create file Det gick inte att skapa fil - + . Check permissions or remove file . Kontrollera behörigheter eller ta bort filen - + Error writing to file Ett fel uppstod vid skrivning till fil - + RPC username/password is stored in file Användarnamn/lösenord för RPC har sparats i fil - + Tag %s is unregistered. Taggen %s har inte registrerats. - + Transaction not possible. Available only %s, transaction amount %s = %s + %s (fee) Transaktion är inte möjlig. Endast tillgängligt %s, transaktionsbelopp %s = %s + %s (avgift) - + This is the RPC monero wallet. It needs to connect to a monero daemon to work correctly. Detta är RPC-plånboken för monero. Den måste ansluta till en Monero- daemon för att fungera korrekt. - + Can't specify more than one of --wallet-file and --generate-from-json Det går inte att ange fler än en av --wallet-file och --generate-from-json - + + Can't specify more than one of --testnet and --stagenet + + + + Must specify --wallet-file or --generate-from-json or --wallet-dir Måste ange --wallet-file eller --generate-from-json eller --wallet-dir - + Loading wallet... Läser in plånbok … - - + + Saving wallet... Sparar plånbok … - - + + Successfully saved Plånboken sparades - + Successfully loaded Plånboken lästes in - + Wallet initialization failed: Det gick inte att initiera plånbok: - + Failed to initialize wallet RPC server Det gick inte att initiera RPC-servern för plånbok - + Starting wallet RPC server Startar RPC-server för plånboken - + Failed to run wallet: Det gick inte att köra plånboken: - + Stopped wallet RPC server Stoppade RPC-server för plånboken - + Failed to save wallet: Det gick inte spara plånboken: @@ -4106,9 +5468,9 @@ daemon för att fungera korrekt. wallet_args - - - + + + Wallet options Alternativ för plånbok @@ -4123,49 +5485,59 @@ daemon för att fungera korrekt. Använd plånbok <arg> - + Max number of threads to use for a parallel job Max antal trådar att använda för ett parallellt jobb - + Specify log file Ange loggfil - + Config file Konfigurationsfil - + General options Allmänna alternativ - + This is the command line monero wallet. It needs to connect to a monero daemon to work correctly. Detta är kommandoradsplånboken för Monero. Den måste ansluta till en Monero- daemon för att fungera korrekt. - + Can't find config file Det gick inte att hitta konfigurationsfilen - + Logging to: Loggar till: - + Logging to %s Loggar till %s - + + WARNING: You may not have a high enough lockable memory limit + + + + + see ulimit -l + + + + Usage: Användning: From 9adc9b4a09e92c4fca7f724fe73030e0d40cf739 Mon Sep 17 00:00:00 2001 From: erciccione Date: Fri, 11 Jan 2019 15:19:28 +0100 Subject: [PATCH 08/17] utils: 'update-translations.sh' now removes obsolete strings --- utils/translations/update-translations.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/utils/translations/update-translations.sh b/utils/translations/update-translations.sh index 778aa5176..3f093be93 100755 --- a/utils/translations/update-translations.sh +++ b/utils/translations/update-translations.sh @@ -12,5 +12,5 @@ then fi echo "using $lupdate" -"$lupdate" `find src -name \*.cpp` -ts translations/*.ts +"$lupdate" `find src -name \*.cpp` -ts translations/*.ts -no-obsolete From 31f9c9a3c9c4de40649e11560d8e119c1b6416ef Mon Sep 17 00:00:00 2001 From: moneromooo-monero Date: Fri, 11 Jan 2019 01:36:59 +0000 Subject: [PATCH 09/17] mnemonics: compare canonical words (lowercase) --- src/mnemonics/electrum-words.cpp | 43 +++++++------- src/mnemonics/language_base.h | 96 ++++++++++++++++++++++++++++++-- 2 files changed, 115 insertions(+), 24 deletions(-) diff --git a/src/mnemonics/electrum-words.cpp b/src/mnemonics/electrum-words.cpp index 6d75b8950..48c9ab1ba 100644 --- a/src/mnemonics/electrum-words.cpp +++ b/src/mnemonics/electrum-words.cpp @@ -76,8 +76,8 @@ namespace crypto namespace { uint32_t create_checksum_index(const std::vector &word_list, - uint32_t unique_prefix_length); - bool checksum_test(std::vector seed, uint32_t unique_prefix_length); + const Language::Base *language); + bool checksum_test(std::vector seed, const Language::Base *language); /*! * \brief Finds the word list that contains the seed words and puts the indices @@ -116,8 +116,8 @@ namespace for (std::vector::iterator it1 = language_instances.begin(); it1 != language_instances.end(); it1++) { - const std::unordered_map &word_map = (*it1)->get_word_map(); - const std::unordered_map &trimmed_word_map = (*it1)->get_trimmed_word_map(); + const std::unordered_map &word_map = (*it1)->get_word_map(); + const std::unordered_map &trimmed_word_map = (*it1)->get_trimmed_word_map(); // To iterate through seed words bool full_match = true; @@ -151,7 +151,7 @@ namespace // if we were using prefix only, and we have a checksum, check it now // to avoid false positives due to prefix set being too common if (has_checksum) - if (!checksum_test(seed, (*it1)->get_unique_prefix_length())) + if (!checksum_test(seed, *it1)) { fallback = *it1; full_match = false; @@ -190,20 +190,20 @@ namespace * \return Checksum index */ uint32_t create_checksum_index(const std::vector &word_list, - uint32_t unique_prefix_length) + const Language::Base *language) { - epee::wipeable_string trimmed_words = ""; + epee::wipeable_string trimmed_words = "", word; + const auto &word_map = language->get_word_map(); + const auto &trimmed_word_map = language->get_trimmed_word_map(); + const uint32_t unique_prefix_length = language->get_unique_prefix_length(); for (std::vector::const_iterator it = word_list.begin(); it != word_list.end(); it++) { - if (it->length() > unique_prefix_length) - { - trimmed_words += Language::utf8prefix(*it, unique_prefix_length); - } - else - { - trimmed_words += *it; - } + word = Language::utf8prefix(*it, unique_prefix_length); + auto it2 = trimmed_word_map.find(word); + if (it2 == trimmed_word_map.end()) + throw std::runtime_error("Word \"" + std::string(word.data(), word.size()) + "\" not found in trimmed word map in " + language->get_english_language_name()); + trimmed_words += it2->first; } boost::crc_32_type result; result.process_bytes(trimmed_words.data(), trimmed_words.length()); @@ -216,7 +216,7 @@ namespace * \param unique_prefix_length the prefix length of each word to use for checksum * \return True if the test passed false if not. */ - bool checksum_test(std::vector seed, uint32_t unique_prefix_length) + bool checksum_test(std::vector seed, const Language::Base *language) { if (seed.empty()) return false; @@ -224,13 +224,16 @@ namespace epee::wipeable_string last_word = seed.back(); seed.pop_back(); - epee::wipeable_string checksum = seed[create_checksum_index(seed, unique_prefix_length)]; + const uint32_t unique_prefix_length = language->get_unique_prefix_length(); + + auto idx = create_checksum_index(seed, language); + epee::wipeable_string checksum = seed[idx]; epee::wipeable_string trimmed_checksum = checksum.length() > unique_prefix_length ? Language::utf8prefix(checksum, unique_prefix_length) : checksum; epee::wipeable_string trimmed_last_word = last_word.length() > unique_prefix_length ? Language::utf8prefix(last_word, unique_prefix_length) : last_word; - bool ret = trimmed_checksum == trimmed_last_word; + bool ret = Language::WordEqual()(trimmed_checksum, trimmed_last_word); MINFO("Checksum is " << (ret ? "valid" : "invalid")); return ret; } @@ -301,7 +304,7 @@ namespace crypto if (has_checksum) { - if (!checksum_test(seed, language->get_unique_prefix_length())) + if (!checksum_test(seed, language)) { // Checksum fail MERROR("Invalid seed: invalid checksum"); @@ -424,7 +427,7 @@ namespace crypto memwipe(w, sizeof(w)); } - words += words_store[create_checksum_index(words_store, language->get_unique_prefix_length())]; + words += words_store[create_checksum_index(words_store, language)]; return true; } diff --git a/src/mnemonics/language_base.h b/src/mnemonics/language_base.h index 89a4d2e7b..653314b04 100644 --- a/src/mnemonics/language_base.h +++ b/src/mnemonics/language_base.h @@ -38,7 +38,9 @@ #include #include #include +#include #include "misc_log_ex.h" +#include "fnv1.h" /*! * \namespace Language @@ -71,6 +73,92 @@ namespace Language return prefix; } + template + inline T utf8canonical(const T &s) + { + T sc = ""; + size_t avail = s.size(); + const char *ptr = s.data(); + wint_t cp = 0; + int bytes = 1; + char wbuf[8], *wptr; + while (avail--) + { + if ((*ptr & 0x80) == 0) + { + cp = *ptr++; + bytes = 1; + } + else if ((*ptr & 0xe0) == 0xc0) + { + if (avail < 1) + throw std::runtime_error("Invalid UTF-8"); + cp = (*ptr++ & 0x1f) << 6; + cp |= *ptr++ & 0x3f; + --avail; + bytes = 2; + } + else if ((*ptr & 0xf0) == 0xe0) + { + if (avail < 2) + throw std::runtime_error("Invalid UTF-8"); + cp = (*ptr++ & 0xf) << 12; + cp |= (*ptr++ & 0x3f) << 6; + cp |= *ptr++ & 0x3f; + avail -= 2; + bytes = 3; + } + else if ((*ptr & 0xf8) == 0xf0) + { + if (avail < 3) + throw std::runtime_error("Invalid UTF-8"); + cp = (*ptr++ & 0x7) << 18; + cp |= (*ptr++ & 0x3f) << 12; + cp |= (*ptr++ & 0x3f) << 6; + cp |= *ptr++ & 0x3f; + avail -= 3; + bytes = 4; + } + else + throw std::runtime_error("Invalid UTF-8"); + + cp = std::towlower(cp); + wptr = wbuf; + switch (bytes) + { + case 1: *wptr++ = cp; break; + case 2: *wptr++ = 0xc0 | (cp >> 6); *wptr++ = 0x80 | (cp & 0x3f); break; + case 3: *wptr++ = 0xe0 | (cp >> 12); *wptr++ = 0x80 | ((cp >> 6) & 0x3f); *wptr++ = 0x80 | (cp & 0x3f); break; + case 4: *wptr++ = 0xf0 | (cp >> 18); *wptr += 0x80 | ((cp >> 12) & 0x3f); *wptr++ = 0x80 | ((cp >> 6) & 0x3f); *wptr++ = 0x80 | (cp & 0x3f); break; + default: throw std::runtime_error("Invalid UTF-8"); + } + *wptr = 0; + sc += T(wbuf, bytes); + cp = 0; + bytes = 1; + } + return sc; + } + + struct WordHash + { + std::size_t operator()(const epee::wipeable_string &s) const + { + const epee::wipeable_string sc = utf8canonical(s); + return epee::fnv::FNV1a(sc.data(), sc.size()); + } + }; + + struct WordEqual + { + bool operator()(const epee::wipeable_string &s0, const epee::wipeable_string &s1) const + { + const epee::wipeable_string s0c = utf8canonical(s0); + const epee::wipeable_string s1c = utf8canonical(s1); + return s0c == s1c; + } + }; + /*! * \class Base * \brief A base language class which all languages have to inherit from for @@ -87,8 +175,8 @@ namespace Language NWORDS = 1626 }; std::vector word_list; /*!< A pointer to the array of words */ - std::unordered_map word_map; /*!< hash table to find word's index */ - std::unordered_map trimmed_word_map; /*!< hash table to find word's trimmed index */ + std::unordered_map word_map; /*!< hash table to find word's index */ + std::unordered_map trimmed_word_map; /*!< hash table to find word's trimmed index */ std::string language_name; /*!< Name of language */ std::string english_language_name; /*!< Name of language */ uint32_t unique_prefix_length; /*!< Number of unique starting characters to trim the wordlist to when matching */ @@ -159,7 +247,7 @@ namespace Language * \brief Returns a pointer to the word map. * \return A pointer to the word map. */ - const std::unordered_map& get_word_map() const + const std::unordered_map& get_word_map() const { return word_map; } @@ -167,7 +255,7 @@ namespace Language * \brief Returns a pointer to the trimmed word map. * \return A pointer to the trimmed word map. */ - const std::unordered_map& get_trimmed_word_map() const + const std::unordered_map& get_trimmed_word_map() const { return trimmed_word_map; } From 3ebc47896768f41fbca073c71bbbbe6fd78f5978 Mon Sep 17 00:00:00 2001 From: Paul Shapiro Date: Fri, 11 Jan 2019 13:46:20 -0600 Subject: [PATCH 10/17] added two tests for partial word and case tolerance in mnemonics --- tests/unit_tests/mnemonics.cpp | 36 ++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) diff --git a/tests/unit_tests/mnemonics.cpp b/tests/unit_tests/mnemonics.cpp index 920db95ec..16634e7a1 100644 --- a/tests/unit_tests/mnemonics.cpp +++ b/tests/unit_tests/mnemonics.cpp @@ -51,6 +51,7 @@ #include "mnemonics/english_old.h" #include "mnemonics/language_base.h" #include "mnemonics/singleton.h" +#include namespace { @@ -221,3 +222,38 @@ TEST(mnemonics, utf8prefix) ASSERT_TRUE(Language::utf8prefix(epee::wipeable_string("æon"), 3) == "æon"); ASSERT_TRUE(Language::utf8prefix(epee::wipeable_string("æon"), 4) == "æon"); } + +TEST(mnemonics, case_tolerance) +{ + bool res; + // + crypto::secret_key key_1; + std::string language_name_1; + const std::string seed_1 = "Neubau umarmen Abart umarmen Turban feilen Brett Bargeld Episode Milchkuh Substanz Jahr Armband Maibaum Tand Grünalge Tabak erziehen Federboa Lobrede Tenor Leuchter Curry Diskurs Tenor"; + res = crypto::ElectrumWords::words_to_bytes(seed_1, key_1, language_name_1); + ASSERT_EQ(true, res); + ASSERT_STREQ(language_name_1.c_str(), "Deutsch"); + // + crypto::secret_key key_2; + std::string language_name_2; + // neubau is capitalized in the word list, but the language detection code should be able to detect it as Deutsch + std::string seed_2 = "neubau umarmen Abart umarmen Turban feilen Brett Bargeld Episode Milchkuh Substanz Jahr Armband Maibaum Tand Grünalge Tabak erziehen Federboa Lobrede Tenor Leuchter Curry Diskurs tenor"; + boost::algorithm::to_lower(seed_2); + res = crypto::ElectrumWords::words_to_bytes(seed_2, key_2, language_name_2); + ASSERT_EQ(true, res); + ASSERT_STREQ(language_name_2.c_str(), "Deutsch"); + // + ASSERT_TRUE(key_1 == key_2); +} + +TEST(mnemonics, partial_word_tolerance) +{ + bool res; + // + crypto::secret_key key_1; + std::string language_name_1; + const std::string seed_1 = "crim bam scamp gna limi woma wron tuit birth mundane donuts square cohesive dolphin titans narrate fue saved wrap aloof magic mirr toget upda wra"; + res = crypto::ElectrumWords::words_to_bytes(seed_1, key_1, language_name_1); + ASSERT_EQ(true, res); + ASSERT_STREQ(language_name_1.c_str(), "English"); +} \ No newline at end of file From b254539efb65c6cb647668c6e8b285d519d80f86 Mon Sep 17 00:00:00 2001 From: Jethro Grassie Date: Sat, 12 Jan 2019 01:50:59 -0500 Subject: [PATCH 11/17] readline: don't dereference possible NULL pointer --- contrib/epee/src/readline_buffer.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/contrib/epee/src/readline_buffer.cpp b/contrib/epee/src/readline_buffer.cpp index c5949da0a..39369c43f 100644 --- a/contrib/epee/src/readline_buffer.cpp +++ b/contrib/epee/src/readline_buffer.cpp @@ -114,7 +114,7 @@ int rdln::readline_buffer::sync() int end = 0, point = 0; #endif - if (rl_end || *rl_prompt) + if (rl_end || (rl_prompt && *rl_prompt)) { #if RL_READLINE_VERSION >= 0x0700 rl_clear_visible_line(); @@ -137,7 +137,7 @@ int rdln::readline_buffer::sync() while ( this->snextc() != EOF ); #if RL_READLINE_VERSION < 0x0700 - if (end || *rl_prompt) + if (end || (rl_prompt && *rl_prompt)) { rl_restore_prompt(); rl_line_buffer = line; From 38b33944b514cdbab7f0dbde89a0f5ac77cd2947 Mon Sep 17 00:00:00 2001 From: moneromooo-monero Date: Sun, 13 Jan 2019 14:44:48 +0000 Subject: [PATCH 12/17] wallet2: fix incorrect patch for determining fork rules Half of the patch was correct, but half was introducing another bug, where a wallet asking for a fork that the daemon does not know about yet would decide to use those rules. --- src/wallet/wallet2.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/wallet/wallet2.cpp b/src/wallet/wallet2.cpp index 500b8039f..065dbf88e 100644 --- a/src/wallet/wallet2.cpp +++ b/src/wallet/wallet2.cpp @@ -9601,7 +9601,7 @@ bool wallet2::use_fork_rules(uint8_t version, int64_t early_blocks) const result = m_node_rpc_proxy.get_earliest_height(version, earliest_height); throw_on_rpc_response_error(result, "get_hard_fork_info"); - bool close_enough = height >= earliest_height - early_blocks; // start using the rules that many blocks beforehand + bool close_enough = height >= earliest_height - early_blocks && earliest_height != std::numeric_limits::max(); // start using the rules that many blocks beforehand if (close_enough) LOG_PRINT_L2("Using v" << (unsigned)version << " rules"); else From 103ee1f2cc7114390d55ee24fad96cf33b01940f Mon Sep 17 00:00:00 2001 From: moneromooo-monero Date: Sun, 13 Jan 2019 14:47:01 +0000 Subject: [PATCH 13/17] wallet2: fix duplicate tx notifications for pool txes --- src/wallet/wallet2.cpp | 13 ++++++++++--- 1 file changed, 10 insertions(+), 3 deletions(-) diff --git a/src/wallet/wallet2.cpp b/src/wallet/wallet2.cpp index 065dbf88e..c7d5c1699 100644 --- a/src/wallet/wallet2.cpp +++ b/src/wallet/wallet2.cpp @@ -628,7 +628,7 @@ std::string strjoin(const std::vector &V, const char *sep) return ss.str(); } -static void emplace_or_replace(std::unordered_multimap &container, +static bool emplace_or_replace(std::unordered_multimap &container, const crypto::hash &key, const tools::wallet2::pool_payment_details &pd) { auto range = container.equal_range(key); @@ -637,10 +637,11 @@ static void emplace_or_replace(std::unordered_multimapsecond.m_pd.m_tx_hash == pd.m_pd.m_tx_hash && i->second.m_pd.m_subaddr_index == pd.m_pd.m_subaddr_index) { i->second = pd; - return; + return false; } } container.emplace(key, pd); + return true; } void drop_from_short_history(std::list &short_chain_history, size_t N) @@ -1979,6 +1980,7 @@ void wallet2::process_new_transaction(const crypto::hash &txid, const cryptonote return; } + bool all_same = true; for (const auto& i : tx_money_got_in_outs) { payment_details payment; @@ -1991,7 +1993,8 @@ void wallet2::process_new_transaction(const crypto::hash &txid, const cryptonote payment.m_coinbase = miner_tx; payment.m_subaddr_index = i.first; if (pool) { - emplace_or_replace(m_unconfirmed_payments, payment_id, pool_payment_details{payment, double_spend_seen}); + if (emplace_or_replace(m_unconfirmed_payments, payment_id, pool_payment_details{payment, double_spend_seen})) + all_same = false; if (0 != m_callback) m_callback->on_unconfirmed_money_received(height, txid, tx, payment.m_amount, payment.m_subaddr_index); } @@ -1999,6 +2002,10 @@ void wallet2::process_new_transaction(const crypto::hash &txid, const cryptonote m_payments.emplace(payment_id, payment); LOG_PRINT_L2("Payment found in " << (pool ? "pool" : "block") << ": " << payment_id << " / " << payment.m_tx_hash << " / " << payment.m_amount); } + + // if it's a pool tx and we already had it, don't notify again + if (pool && all_same) + notify = false; } if (notify) From 5a71ea66ef5927a4ecc2b7d5780ade1934505bf0 Mon Sep 17 00:00:00 2001 From: italocoin Date: Tue, 15 Jan 2019 07:35:45 -0500 Subject: [PATCH 14/17] bump sodium to 1.0.16 --- contrib/depends/packages/sodium-darwin.mk | 4 ++-- contrib/depends/packages/sodium.mk | 4 ++-- contrib/depends/patches/sodium/fix-whitespace.patch | 4 ++-- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/contrib/depends/packages/sodium-darwin.mk b/contrib/depends/packages/sodium-darwin.mk index d8e3de352..8b6ee3f1d 100644 --- a/contrib/depends/packages/sodium-darwin.mk +++ b/contrib/depends/packages/sodium-darwin.mk @@ -1,8 +1,8 @@ package=sodium-darwin -$(package)_version=1.0.15 +$(package)_version=1.0.16 $(package)_download_path=https://download.libsodium.org/libsodium/releases/ $(package)_file_name=libsodium-$($(package)_version).tar.gz -$(package)_sha256_hash=fb6a9e879a2f674592e4328c5d9f79f082405ee4bb05cb6e679b90afe9e178f4 +$(package)_sha256_hash=eeadc7e1e1bcef09680fb4837d448fbdf57224978f865ac1c16745868fbd0533 define $(package)_set_vars $(package)_build_opts_darwin=OS=Darwin LIBTOOL="$($(package)_libtool)" diff --git a/contrib/depends/packages/sodium.mk b/contrib/depends/packages/sodium.mk index 35f444fd5..06aa8f874 100644 --- a/contrib/depends/packages/sodium.mk +++ b/contrib/depends/packages/sodium.mk @@ -1,8 +1,8 @@ package=sodium -$(package)_version=1.0.15 +$(package)_version=1.0.16 $(package)_download_path=https://download.libsodium.org/libsodium/releases/ $(package)_file_name=libsodium-$($(package)_version).tar.gz -$(package)_sha256_hash=fb6a9e879a2f674592e4328c5d9f79f082405ee4bb05cb6e679b90afe9e178f4 +$(package)_sha256_hash=eeadc7e1e1bcef09680fb4837d448fbdf57224978f865ac1c16745868fbd0533 $(package)_patches=fix-whitespace.patch define $(package)_set_vars diff --git a/contrib/depends/patches/sodium/fix-whitespace.patch b/contrib/depends/patches/sodium/fix-whitespace.patch index c11838611..efbfe4e83 100644 --- a/contrib/depends/patches/sodium/fix-whitespace.patch +++ b/contrib/depends/patches/sodium/fix-whitespace.patch @@ -5,8 +5,8 @@ index b29f769..ca008ae 100755 @@ -591,7 +591,7 @@ MAKEFLAGS= PACKAGE_NAME='libsodium' PACKAGE_TARNAME='libsodium' - PACKAGE_VERSION='1.0.15' --PACKAGE_STRING='libsodium 1.0.15' + PACKAGE_VERSION='1.0.16' +-PACKAGE_STRING='libsodium 1.0.16' +PACKAGE_STRING='libsodium' PACKAGE_BUGREPORT='https://github.com/jedisct1/libsodium/issues' PACKAGE_URL='https://github.com/jedisct1/libsodium' From e51164f259c2a8187e8b33c9e422e0affc85cb0f Mon Sep 17 00:00:00 2001 From: Howard Chu Date: Thu, 17 Jan 2019 19:25:31 +0000 Subject: [PATCH 15/17] Resync to upstream mdb.master --- external/db_drivers/liblmdb/.gitignore | 1 + external/db_drivers/liblmdb/COPYRIGHT | 2 +- external/db_drivers/liblmdb/Doxyfile | 2 +- external/db_drivers/liblmdb/Makefile | 5 +- external/db_drivers/liblmdb/intro.doc | 2 +- external/db_drivers/liblmdb/lmdb.h | 63 +- external/db_drivers/liblmdb/mdb.c | 1679 +++++++++++--------- external/db_drivers/liblmdb/mdb_copy.1 | 5 +- external/db_drivers/liblmdb/mdb_copy.c | 2 +- external/db_drivers/liblmdb/mdb_drop.1 | 2 +- external/db_drivers/liblmdb/mdb_drop.c | 2 +- external/db_drivers/liblmdb/mdb_dump.1 | 4 +- external/db_drivers/liblmdb/mdb_dump.c | 19 +- external/db_drivers/liblmdb/mdb_load.1 | 4 +- external/db_drivers/liblmdb/mdb_load.c | 51 +- external/db_drivers/liblmdb/mdb_stat.1 | 4 +- external/db_drivers/liblmdb/mdb_stat.c | 46 +- external/db_drivers/liblmdb/midl.c | 3 +- external/db_drivers/liblmdb/midl.h | 12 +- external/db_drivers/liblmdb/mtest.c | 2 +- external/db_drivers/liblmdb/mtest2.c | 2 +- external/db_drivers/liblmdb/mtest3.c | 2 +- external/db_drivers/liblmdb/mtest4.c | 2 +- external/db_drivers/liblmdb/mtest5.c | 2 +- external/db_drivers/liblmdb/mtest6.c | 2 +- external/db_drivers/liblmdb/sample-bdb.txt | 2 +- external/db_drivers/liblmdb/sample-mdb.txt | 2 +- 27 files changed, 1081 insertions(+), 843 deletions(-) diff --git a/external/db_drivers/liblmdb/.gitignore b/external/db_drivers/liblmdb/.gitignore index d5102a87c..80b6d8114 100644 --- a/external/db_drivers/liblmdb/.gitignore +++ b/external/db_drivers/liblmdb/.gitignore @@ -5,6 +5,7 @@ mdb_copy mdb_stat mdb_dump mdb_load +mdb_drop *.lo *.[ao] *.so diff --git a/external/db_drivers/liblmdb/COPYRIGHT b/external/db_drivers/liblmdb/COPYRIGHT index 722d1a515..f076556eb 100644 --- a/external/db_drivers/liblmdb/COPYRIGHT +++ b/external/db_drivers/liblmdb/COPYRIGHT @@ -1,4 +1,4 @@ -Copyright 2011-2015 Howard Chu, Symas Corp. +Copyright 2011-2019 Howard Chu, Symas Corp. All rights reserved. Redistribution and use in source and binary forms, with or without diff --git a/external/db_drivers/liblmdb/Doxyfile b/external/db_drivers/liblmdb/Doxyfile index 5047c0bb1..5ca2cfe8f 100644 --- a/external/db_drivers/liblmdb/Doxyfile +++ b/external/db_drivers/liblmdb/Doxyfile @@ -253,7 +253,7 @@ IDL_PROPERTY_SUPPORT = YES # member in the group (if any) for the other members of the group. By default # all members of a group must be documented explicitly. -DISTRIBUTE_GROUP_DOC = NO +DISTRIBUTE_GROUP_DOC = YES # Set the SUBGROUPING tag to YES (the default) to allow class member groups of # the same type (for instance a group of public functions) to be put as a diff --git a/external/db_drivers/liblmdb/Makefile b/external/db_drivers/liblmdb/Makefile index 186168038..942d0dbe4 100644 --- a/external/db_drivers/liblmdb/Makefile +++ b/external/db_drivers/liblmdb/Makefile @@ -26,6 +26,7 @@ OPT = -O2 -g CFLAGS = $(THREADS) $(OPT) $(W) $(XCFLAGS) LDLIBS = SOLIBS = +SOEXT = .so prefix = /usr/local exec_prefix = $(prefix) bindir = $(exec_prefix)/bin @@ -37,7 +38,7 @@ mandir = $(datarootdir)/man ######################################################################## IHDRS = lmdb.h -ILIBS = liblmdb.a liblmdb.so +ILIBS = liblmdb.a liblmdb$(SOEXT) IPROGS = mdb_stat mdb_copy mdb_dump mdb_load mdb_drop IDOCS = mdb_stat.1 mdb_copy.1 mdb_dump.1 mdb_load.1 mdb_drop.1 PROGS = $(IPROGS) mtest mtest2 mtest3 mtest4 mtest5 @@ -63,7 +64,7 @@ test: all liblmdb.a: mdb.o midl.o $(AR) rs $@ mdb.o midl.o -liblmdb.so: mdb.lo midl.lo +liblmdb$(SOEXT): mdb.lo midl.lo # $(CC) $(LDFLAGS) -pthread -shared -Wl,-Bsymbolic -o $@ mdb.o midl.o $(SOLIBS) $(CC) $(LDFLAGS) -pthread -shared -o $@ mdb.lo midl.lo $(SOLIBS) diff --git a/external/db_drivers/liblmdb/intro.doc b/external/db_drivers/liblmdb/intro.doc index 870c7bb8e..64dfcaad8 100644 --- a/external/db_drivers/liblmdb/intro.doc +++ b/external/db_drivers/liblmdb/intro.doc @@ -1,5 +1,5 @@ /* - * Copyright 2015 Howard Chu, Symas Corp. + * Copyright 2015-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without diff --git a/external/db_drivers/liblmdb/lmdb.h b/external/db_drivers/liblmdb/lmdb.h index 0bca3eb74..1f4736ce2 100644 --- a/external/db_drivers/liblmdb/lmdb.h +++ b/external/db_drivers/liblmdb/lmdb.h @@ -97,11 +97,12 @@ * transactions. Each transaction belongs to one thread. See below. * The #MDB_NOTLS flag changes this for read-only transactions. * - * - Use an MDB_env* in the process which opened it, without fork()ing. + * - Use an MDB_env* in the process which opened it, not after fork(). * * - Do not have open an LMDB database twice in the same process at * the same time. Not even from a plain open() call - close()ing it - * breaks flock() advisory locking. + * breaks fcntl() advisory locking. (It is OK to reopen it after + * fork() - exec*(), since the lockfile has FD_CLOEXEC set.) * * - Avoid long-lived transactions. Read transactions prevent * reuse of pages freed by newer write transactions, thus the @@ -135,7 +136,7 @@ * * @author Howard Chu, Symas Corporation. * - * @copyright Copyright 2011-2016 Howard Chu, Symas Corp. All rights reserved. + * @copyright Copyright 2011-2019 Howard Chu, Symas Corp. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted only as authorized by the OpenLDAP @@ -167,6 +168,7 @@ #include #include +#include #ifdef __cplusplus extern "C" { @@ -179,11 +181,30 @@ typedef int mdb_mode_t; typedef mode_t mdb_mode_t; #endif -#ifdef MDB_VL32 -typedef uint64_t mdb_size_t; -#define mdb_env_create mdb_env_create_vl32 /**< Prevent mixing with non-VL32 builds */ +#ifdef _WIN32 +# define MDB_FMT_Z "I" #else +# define MDB_FMT_Z "z" /**< printf/scanf format modifier for size_t */ +#endif + +#ifndef MDB_VL32 +/** Unsigned type used for mapsize, entry counts and page/transaction IDs. + * + * It is normally size_t, hence the name. Defining MDB_VL32 makes it + * uint64_t, but do not try this unless you know what you are doing. + */ typedef size_t mdb_size_t; +# define MDB_SIZE_MAX SIZE_MAX /**< max #mdb_size_t */ +/** #mdb_size_t printf formats, \b t = one of [diouxX] without quotes */ +# define MDB_PRIy(t) MDB_FMT_Z #t +/** #mdb_size_t scanf formats, \b t = one of [dioux] without quotes */ +# define MDB_SCNy(t) MDB_FMT_Z #t +#else +typedef uint64_t mdb_size_t; +# define MDB_SIZE_MAX UINT64_MAX +# define MDB_PRIy(t) PRI##t##64 +# define MDB_SCNy(t) SCN##t##64 +# define mdb_env_create mdb_env_create_vl32 /**< Prevent mixing with non-VL32 builds */ #endif /** An abstraction for a file handle. @@ -322,7 +343,8 @@ typedef void (MDB_rel_func)(MDB_val *item, void *oldptr, void *newptr, void *rel #define MDB_REVERSEKEY 0x02 /** use sorted duplicates */ #define MDB_DUPSORT 0x04 - /** numeric keys in native byte order: either unsigned int or size_t. + /** numeric keys in native byte order, either unsigned int or #mdb_size_t. + * (lmdb expects 32-bit int <= size_t <= 32/64-bit mdb_size_t.) * The keys must all be of the same size. */ #define MDB_INTEGERKEY 0x08 /** with #MDB_DUPSORT, sorted dup items have fixed size */ @@ -380,7 +402,7 @@ typedef enum MDB_cursor_op { MDB_GET_BOTH, /**< Position at key/data pair. Only for #MDB_DUPSORT */ MDB_GET_BOTH_RANGE, /**< position at key, nearest data. Only for #MDB_DUPSORT */ MDB_GET_CURRENT, /**< Return key/data at current cursor position */ - MDB_GET_MULTIPLE, /**< Return key and up to a page of duplicate data items + MDB_GET_MULTIPLE, /**< Return up to a page of duplicate data items from current cursor position. Move cursor to prepare for #MDB_NEXT_MULTIPLE. Only for #MDB_DUPFIXED */ MDB_LAST, /**< Position at last key/data item */ @@ -389,7 +411,7 @@ typedef enum MDB_cursor_op { MDB_NEXT, /**< Position at next data item */ MDB_NEXT_DUP, /**< Position at next data item of current key. Only for #MDB_DUPSORT */ - MDB_NEXT_MULTIPLE, /**< Return key and up to a page of duplicate data items + MDB_NEXT_MULTIPLE, /**< Return up to a page of duplicate data items from next cursor position. Move cursor to prepare for #MDB_NEXT_MULTIPLE. Only for #MDB_DUPFIXED */ MDB_NEXT_NODUP, /**< Position at first data item of next key */ @@ -400,7 +422,7 @@ typedef enum MDB_cursor_op { MDB_SET, /**< Position at specified key */ MDB_SET_KEY, /**< Position at specified key, return key + data */ MDB_SET_RANGE, /**< Position at first key greater than or equal to specified key. */ - MDB_PREV_MULTIPLE /**< Position at previous page and return key and up to + MDB_PREV_MULTIPLE /**< Position at previous page and return up to a page of duplicate data items. Only for #MDB_DUPFIXED */ } MDB_cursor_op; @@ -458,8 +480,10 @@ typedef enum MDB_cursor_op { #define MDB_BAD_VALSIZE (-30781) /** The specified DBI was changed unexpectedly */ #define MDB_BAD_DBI (-30780) + /** Unexpected problem - txn should abort */ +#define MDB_PROBLEM (-30779) /** The last defined error code */ -#define MDB_LAST_ERRCODE MDB_BAD_DBI +#define MDB_LAST_ERRCODE MDB_PROBLEM /** @} */ /** @brief Statistics for a database in the environment */ @@ -696,6 +720,7 @@ int mdb_env_copyfd(MDB_env *env, mdb_filehandle_t fd); *
  • #MDB_CP_COMPACT - Perform compaction while copying: omit free * pages and sequentially renumber all pages in output. This option * consumes more CPU and runs more slowly than the default. + * Currently it fails if the environment has suffered a page leak. * * @return A non-zero error value on failure and 0 on success. */ @@ -810,6 +835,10 @@ int mdb_env_get_flags(MDB_env *env, unsigned int *flags); int mdb_env_get_path(MDB_env *env, const char **path); /** @brief Return the filedescriptor for the given environment. + * + * This function may be called after fork(), so the descriptor can be + * closed before exec*(). Other LMDB file descriptors have FD_CLOEXEC. + * (Until LMDB 0.9.18, only the lockfile had that.) * * @param[in] env An environment handle returned by #mdb_env_create() * @param[out] fd Address of a mdb_filehandle_t to contain the descriptor. @@ -1112,14 +1141,16 @@ int mdb_txn_renew(MDB_txn *txn); * keys must be unique and may have only a single data item. *
  • #MDB_INTEGERKEY * Keys are binary integers in native byte order, either unsigned int - * or size_t, and will be sorted as such. + * or #mdb_size_t, and will be sorted as such. + * (lmdb expects 32-bit int <= size_t <= 32/64-bit mdb_size_t.) * The keys must all be of the same size. *
  • #MDB_DUPFIXED * This flag may only be used in combination with #MDB_DUPSORT. This option * tells the library that the data items for this database are all the same * size, which allows further optimizations in storage and retrieval. When - * all data items are the same size, the #MDB_GET_MULTIPLE and #MDB_NEXT_MULTIPLE - * cursor operations may be used to retrieve multiple items at once. + * all data items are the same size, the #MDB_GET_MULTIPLE, #MDB_NEXT_MULTIPLE + * and #MDB_PREV_MULTIPLE cursor operations may be used to retrieve multiple + * items at once. *
  • #MDB_INTEGERDUP * This option specifies that duplicate data items are binary integers, * similar to #MDB_INTEGERKEY keys. @@ -1524,6 +1555,10 @@ int mdb_cursor_put(MDB_cursor *cursor, MDB_val *key, MDB_val *data, /** @brief Delete current key/data pair * * This function deletes the key/data pair to which the cursor refers. + * This does not invalidate the cursor, so operations such as MDB_NEXT + * can still be used on it. + * Both MDB_NEXT and MDB_GET_CURRENT will return the same record after + * this operation. * @param[in] cursor A cursor handle returned by #mdb_cursor_open() * @param[in] flags Options for this operation. This parameter * must be set to 0 or one of the values described here. diff --git a/external/db_drivers/liblmdb/mdb.c b/external/db_drivers/liblmdb/mdb.c index 8e2b1eca1..3b2745f95 100644 --- a/external/db_drivers/liblmdb/mdb.c +++ b/external/db_drivers/liblmdb/mdb.c @@ -5,7 +5,7 @@ * BerkeleyDB API, but much simplified. */ /* - * Copyright 2011-2016 Howard Chu, Symas Corp. + * Copyright 2011-2019 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -41,6 +41,7 @@ #ifdef _WIN32 #include #include +#include /* get wcscpy() */ /* We use native NT APIs to setup the memory map, so that we can * let the DB file grow incrementally instead of always preallocating @@ -51,7 +52,7 @@ * NTDLL.DLL at runtime, to avoid buildtime dependencies on any * NTDLL import libraries. */ -typedef NTSTATUS WINAPI (NtCreateSectionFunc) +typedef NTSTATUS (WINAPI NtCreateSectionFunc) (OUT PHANDLE sh, IN ACCESS_MASK acc, IN void * oa OPTIONAL, IN PLARGE_INTEGER ms OPTIONAL, @@ -64,7 +65,7 @@ typedef enum _SECTION_INHERIT { ViewUnmap = 2 } SECTION_INHERIT; -typedef NTSTATUS WINAPI (NtMapViewOfSectionFunc) +typedef NTSTATUS (WINAPI NtMapViewOfSectionFunc) (IN PHANDLE sh, IN HANDLE ph, IN OUT PVOID *addr, IN ULONG_PTR zbits, IN SIZE_T cs, IN OUT PLARGE_INTEGER off OPTIONAL, @@ -73,7 +74,7 @@ typedef NTSTATUS WINAPI (NtMapViewOfSectionFunc) static NtMapViewOfSectionFunc *NtMapViewOfSection; -typedef NTSTATUS WINAPI (NtCloseFunc)(HANDLE h); +typedef NTSTATUS (WINAPI NtCloseFunc)(HANDLE h); static NtCloseFunc *NtClose; @@ -147,6 +148,10 @@ typedef SSIZE_T ssize_t; /* Most platforms have posix_memalign, older may only have memalign */ #define HAVE_MEMALIGN 1 #include +/* On Solaris, we need the POSIX sigwait function */ +#if defined (__sun) +# define _POSIX_PTHREAD_SEMANTICS 1 +#endif #endif #if !(defined(BYTE_ORDER) || defined(__BYTE_ORDER)) @@ -154,7 +159,7 @@ typedef SSIZE_T ssize_t; #include /* defines BYTE_ORDER on HPUX and Solaris */ #endif -#if defined(__APPLE__) || defined (BSD) +#if defined(__APPLE__) || defined (BSD) || defined(__FreeBSD_kernel__) # if !(defined(MDB_USE_POSIX_MUTEX) || defined(MDB_USE_POSIX_SEM)) # define MDB_USE_SYSV_SEM 1 # endif @@ -165,6 +170,7 @@ typedef SSIZE_T ssize_t; #ifndef _WIN32 #include +#include #ifdef MDB_USE_POSIX_SEM # define MDB_USE_HASH 1 #include @@ -234,7 +240,7 @@ union semun { #if (BYTE_ORDER == LITTLE_ENDIAN) == (BYTE_ORDER == BIG_ENDIAN) # error "Unknown or unsupported endianness (BYTE_ORDER)" -#elif (-6 & 5) || CHAR_BIT != 8 || UINT_MAX < 0xffffffff || ULONG_MAX % 0xFFFF +#elif (-6 & 5) || CHAR_BIT!=8 || UINT_MAX!=0xffffffff || MDB_SIZE_MAX%UINT_MAX # error "Two's complement, reasonably sized integer types, please" #endif @@ -309,6 +315,10 @@ union semun { # define MDB_USE_ROBUST 0 # else # define MDB_USE_ROBUST 1 +# endif +#endif /* !MDB_USE_ROBUST */ + +#if defined(MDB_USE_POSIX_MUTEX) && (MDB_USE_ROBUST) /* glibc < 2.12 only provided _np API */ # if (defined(__GLIBC__) && GLIBC_VER < 0x02000c) || \ (defined(PTHREAD_MUTEX_ROBUST_NP) && !defined(PTHREAD_MUTEX_ROBUST)) @@ -316,10 +326,9 @@ union semun { # define pthread_mutexattr_setrobust(attr, flag) pthread_mutexattr_setrobust_np(attr, flag) # define pthread_mutex_consistent(mutex) pthread_mutex_consistent_np(mutex) # endif -# endif -#endif /* MDB_USE_ROBUST */ +#endif /* MDB_USE_POSIX_MUTEX && MDB_USE_ROBUST */ -#if defined(MDB_OWNERDEAD) && MDB_USE_ROBUST +#if defined(MDB_OWNERDEAD) && (MDB_USE_ROBUST) #define MDB_ROBUST_SUPPORTED 1 #endif @@ -342,8 +351,10 @@ typedef HANDLE mdb_mutex_t, mdb_mutexref_t; #define pthread_mutex_lock(x) WaitForSingleObject(*x, INFINITE) #define pthread_cond_signal(x) SetEvent(*x) #define pthread_cond_wait(cond,mutex) do{SignalObjectAndWait(*mutex, *cond, INFINITE, FALSE); WaitForSingleObject(*mutex, INFINITE);}while(0) -#define THREAD_CREATE(thr,start,arg) thr=CreateThread(NULL,0,start,arg,0,NULL) -#define THREAD_FINISH(thr) WaitForSingleObject(thr, INFINITE) +#define THREAD_CREATE(thr,start,arg) \ + (((thr) = CreateThread(NULL, 0, start, arg, 0, NULL)) ? 0 : ErrCode()) +#define THREAD_FINISH(thr) \ + (WaitForSingleObject(thr, INFINITE) ? ErrCode() : 0) #define LOCK_MUTEX0(mutex) WaitForSingleObject(mutex, INFINITE) #define UNLOCK_MUTEX(mutex) ReleaseMutex(mutex) #define mdb_mutex_consistent(mutex) 0 @@ -359,12 +370,10 @@ typedef HANDLE mdb_mutex_t, mdb_mutexref_t; #else #define MDB_PROCESS_QUERY_LIMITED_INFORMATION 0x1000 #endif -#define Z "I" #else #define THREAD_RET void * #define THREAD_CREATE(thr,start,arg) pthread_create(&thr,NULL,start,arg) #define THREAD_FINISH(thr) pthread_join(thr,NULL) -#define Z "z" /**< printf format modifier for size_t */ /** For MDB_LOCK_FORMAT: True if readers take a pid lock in the lockfile */ #define MDB_PIDLOCK 1 @@ -418,15 +427,15 @@ mdb_sem_wait(mdb_mutexref_t sem) #define mdb_mutex_consistent(mutex) 0 #else /* MDB_USE_POSIX_MUTEX: */ - /** Shared mutex/semaphore as it is stored (mdb_mutex_t), and as - * local variables keep it (mdb_mutexref_t). + /** Shared mutex/semaphore as the original is stored. * - * An mdb_mutex_t can be assigned to an mdb_mutexref_t. They can - * be the same, or an array[size 1] and a pointer. - * @{ + * Not for copies. Instead it can be assigned to an #mdb_mutexref_t. + * When mdb_mutexref_t is a pointer and mdb_mutex_t is not, then it + * is array[size 1] so it can be assigned to the pointer. */ -typedef pthread_mutex_t mdb_mutex_t[1], *mdb_mutexref_t; - /* @} */ +typedef pthread_mutex_t mdb_mutex_t[1]; + /** Reference to an #mdb_mutex_t */ +typedef pthread_mutex_t *mdb_mutexref_t; /** Lock the reader or writer mutex. * Returns 0 or a code to give #mdb_mutex_failed(), as in #LOCK_MUTEX(). */ @@ -462,28 +471,23 @@ typedef pthread_mutex_t mdb_mutex_t[1], *mdb_mutexref_t; #define GET_PAGESIZE(x) ((x) = sysconf(_SC_PAGE_SIZE)) #endif -#ifdef MDB_VL32 -#ifdef _WIN32 -#define Y "I64" -#else -#define Y "ll" -#endif -#else -#define Y Z -#endif +#define Z MDB_FMT_Z /**< printf/scanf format modifier for size_t */ +#define Yu MDB_PRIy(u) /**< printf format for #mdb_size_t */ +#define Yd MDB_PRIy(d) /**< printf format for 'signed #mdb_size_t' */ -#if defined(_WIN32) || defined(MDB_USE_POSIX_SEM) -#define MNAME_LEN 32 -#elif defined(MDB_USE_SYSV_SEM) +#ifdef MDB_USE_SYSV_SEM #define MNAME_LEN (sizeof(int)) #else #define MNAME_LEN (sizeof(pthread_mutex_t)) #endif -#ifdef MDB_USE_SYSV_SEM -#define SYSV_SEM_FLAG 1 /**< SysV sems in lockfile format */ -#else -#define SYSV_SEM_FLAG 0 +/** Initial part of #MDB_env.me_mutexname[]. + * Changes to this code must be reflected in #MDB_LOCK_FORMAT. + */ +#ifdef _WIN32 +#define MUTEXNAME_PREFIX "Global\\MDB" +#elif defined MDB_USE_POSIX_SEM +#define MUTEXNAME_PREFIX "/MDB" #endif /** @} */ @@ -627,7 +631,11 @@ static txnid_t mdb_debug_start; /** The version number for a database's datafile format. */ #define MDB_DATA_VERSION ((MDB_DEVEL) ? 999 : 1) /** The version number for a database's lockfile format. */ -#define MDB_LOCK_VERSION ((MDB_DEVEL) ? 999 : 1) +#define MDB_LOCK_VERSION ((MDB_DEVEL) ? 999 : 2) + /** Number of bits representing #MDB_LOCK_VERSION in #MDB_LOCK_FORMAT. + * The remaining bits must leave room for #MDB_lock_desc. + */ +#define MDB_LOCK_VERSION_BITS 12 /** @brief The max size of a key we can write, or 0 for computed max. * @@ -693,12 +701,27 @@ static txnid_t mdb_debug_start; /** Round \b n up to an even number. */ #define EVEN(n) (((n) + 1U) & -2) /* sign-extending -2 to match n+1U */ + /** Least significant 1-bit of \b n. n must be of an unsigned type. */ +#define LOW_BIT(n) ((n) & (-(n))) + + /** (log2(\b p2) % \b n), for p2 = power of 2 and 0 < n < 8. */ +#define LOG2_MOD(p2, n) (7 - 86 / ((p2) % ((1U<<(n))-1) + 11)) + /* Explanation: Let p2 = 2**(n*y + x), x> (CACHELINE>64), 5)) + + 6 * (sizeof(MDB_PID_T)/4 % 3) /* legacy(2) to word(4/8)? */ + + 18 * (sizeof(pthread_t)/4 % 5) /* can be struct{id, active data} */ + + 90 * (sizeof(MDB_txbody) / CACHELINE % 3) + + 270 * (MDB_LOCK_TYPE % 120) + /* The above is < 270*120 < 2**15 */ + + ((sizeof(txnid_t) == 8) << 15) /* 32bit/64bit */ + + ((sizeof(MDB_reader) > CACHELINE) << 16) + /* Not really needed - implied by MDB_LOCK_TYPE != (_WIN32 locking) */ + + (((MDB_PIDLOCK) != 0) << 17) + /* 18 bits total: Must be <= (32 - MDB_LOCK_VERSION_BITS). */ +}; /** @} */ -/** Common header for all page types. - * Overflow records occupy a number of contiguous pages with no - * headers on any page after the first. +/** Common header for all page types. The page type depends on #mp_flags. + * + * #P_BRANCH and #P_LEAF pages have unsorted '#MDB_node's at the end, with + * sorted #mp_ptrs[] entries referring to them. Exception: #P_LEAF2 pages + * omit mp_ptrs and pack sorted #MDB_DUPFIXED values after the page header. + * + * #P_OVERFLOW records occupy one or more contiguous pages where only the + * first has a page header. They hold the real data of #F_BIGDATA nodes. + * + * #P_SUBP sub-pages are small leaf "pages" with duplicate data. + * A node with flag #F_DUPDATA but not #F_SUBDATA contains a sub-page. + * (Duplicate data can also go in sub-databases, which use normal pages.) + * + * #P_META pages contain #MDB_meta, the start point of an LMDB snapshot. + * + * Each non-metapage up to #MDB_meta.%mm_last_pg is reachable exactly once + * in the snapshot: Either used by a database or listed in a freeDB record. */ typedef struct MDB_page { #define mp_pgno mp_p.p_pgno @@ -891,7 +971,7 @@ typedef struct MDB_page { pgno_t p_pgno; /**< page number */ struct MDB_page *p_next; /**< for in-memory list of freed pages */ } mp_p; - uint16_t mp_pad; + uint16_t mp_pad; /**< key size if this is a LEAF2 page */ /** @defgroup mdb_page Page Flags * @ingroup internal * Flags for the page headers. @@ -958,25 +1038,34 @@ typedef struct MDB_page { /** The number of overflow pages needed to store the given size. */ #define OVPAGES(size, psize) ((PAGEHDRSZ-1 + (size)) / (psize) + 1) - /** Link in #MDB_txn.%mt_loose_pgs list */ + /** Link in #MDB_txn.%mt_loose_pgs list. + * Kept outside the page header, which is needed when reusing the page. + */ #define NEXT_LOOSE_PAGE(p) (*(MDB_page **)((p) + 2)) /** Header for a single key/data pair within a page. * Used in pages of type #P_BRANCH and #P_LEAF without #P_LEAF2. * We guarantee 2-byte alignment for 'MDB_node's. + * + * #mn_lo and #mn_hi are used for data size on leaf nodes, and for child + * pgno on branch nodes. On 64 bit platforms, #mn_flags is also used + * for pgno. (Branch nodes have no flags). Lo and hi are in host byte + * order in case some accesses can be optimized to 32-bit word access. + * + * Leaf node flags describe node contents. #F_BIGDATA says the node's + * data part is the page number of an overflow page with actual data. + * #F_DUPDATA and #F_SUBDATA can be combined giving duplicate data in + * a sub-page/sub-database, and named databases (just #F_SUBDATA). */ typedef struct MDB_node { - /** lo and hi are used for data size on leaf nodes and for - * child pgno on branch nodes. On 64 bit platforms, flags - * is also used for pgno. (Branch nodes have no flags). - * They are in host byte order in case that lets some - * accesses be optimized into a 32-bit word access. - */ + /** part of data size or pgno + * @{ */ #if BYTE_ORDER == LITTLE_ENDIAN - unsigned short mn_lo, mn_hi; /**< part of data size or pgno */ + unsigned short mn_lo, mn_hi; #else unsigned short mn_hi, mn_lo; #endif + /** @} */ /** @defgroup mdb_node Node Flags * @ingroup internal * Flags for node headers. @@ -1041,7 +1130,7 @@ typedef struct MDB_node { #ifdef MISALIGNED_OK #define COPY_PGNO(dst,src) dst = src #else -#if SIZE_MAX > 4294967295UL +#if MDB_SIZE_MAX > 0xffffffffU #define COPY_PGNO(dst,src) do { \ unsigned short *s, *d; \ s = (unsigned short *)&(src); \ @@ -1086,9 +1175,9 @@ typedef struct MDB_db { pgno_t md_root; /**< the root page of this tree */ } MDB_db; - /** mdb_dbi_open flags */ #define MDB_VALID 0x8000 /**< DB handle is valid, for me_dbflags */ #define PERSISTENT_FLAGS (0xffff & ~(MDB_VALID)) + /** #mdb_dbi_open() flags */ #define VALID_FLAGS (MDB_REVERSEKEY|MDB_DUPSORT|MDB_INTEGERKEY|MDB_DUPFIXED|\ MDB_INTEGERDUP|MDB_REVERSEDUP|MDB_CREATE) @@ -1121,13 +1210,16 @@ typedef struct MDB_meta { #else void *mm_address; /**< address for fixed mapping */ #endif - pgno_t mm_mapsize; /**< size of mmap region */ + mdb_size_t mm_mapsize; /**< size of mmap region */ MDB_db mm_dbs[CORE_DBS]; /**< first is free space, 2nd is main db */ /** The size of pages used in this DB */ #define mm_psize mm_dbs[FREE_DBI].md_pad /** Any persistent environment flags. @ref mdb_env */ #define mm_flags mm_dbs[FREE_DBI].md_flags - pgno_t mm_last_pg; /**< last used page in file */ + /** Last used page in the datafile. + * Actually the file may be shorter if the freeDB lists the final pages. + */ + pgno_t mm_last_pg; volatile txnid_t mm_txnid; /**< txnid that committed this page */ } MDB_meta; @@ -1180,7 +1272,7 @@ struct MDB_txn { * in this transaction, linked through #NEXT_LOOSE_PAGE(page). */ MDB_page *mt_loose_pgs; - /* #Number of loose pages (#mt_loose_pgs) */ + /** Number of loose pages (#mt_loose_pgs) */ int mt_loose_count; /** The sorted list of dirty pages we temporarily wrote to disk * because the dirty list was full. page numbers in here are @@ -1203,11 +1295,12 @@ struct MDB_txn { * @ingroup internal * @{ */ -#define DB_DIRTY 0x01 /**< DB was modified or is DUPSORT data */ +#define DB_DIRTY 0x01 /**< DB was written in this txn */ #define DB_STALE 0x02 /**< Named-DB record is older than txnID */ #define DB_NEW 0x04 /**< Named-DB handle opened in this txn */ #define DB_VALID 0x08 /**< DB handle is valid, see also #MDB_VALID */ #define DB_USRVALID 0x10 /**< As #DB_VALID, but not set for #FREE_DBI */ +#define DB_DUPDATA 0x20 /**< DB is #MDB_DUPSORT data */ /** @} */ /** In write txns, array of cursors for each DB */ MDB_cursor **mt_cursors; @@ -1317,6 +1410,11 @@ struct MDB_cursor { indx_t mc_ki[CURSOR_STACK]; /**< stack of page indices */ #ifdef MDB_VL32 MDB_page *mc_ovpg; /**< a referenced overflow page */ +# define MC_OVPG(mc) ((mc)->mc_ovpg) +# define MC_SET_OVPG(mc, pg) ((mc)->mc_ovpg = (pg)) +#else +# define MC_OVPG(mc) ((MDB_page *)0) +# define MC_SET_OVPG(mc, pg) ((void)0) #endif }; @@ -1336,6 +1434,23 @@ typedef struct MDB_xcursor { unsigned char mx_dbflag; } MDB_xcursor; + /** Check if there is an inited xcursor */ +#define XCURSOR_INITED(mc) \ + ((mc)->mc_xcursor && ((mc)->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED)) + + /** Update the xcursor's sub-page pointer, if any, in \b mc. Needed + * when the node which contains the sub-page may have moved. Called + * with leaf page \b mp = mc->mc_pg[\b top]. + */ +#define XCURSOR_REFRESH(mc, top, mp) do { \ + MDB_page *xr_pg = (mp); \ + MDB_node *xr_node; \ + if (!XCURSOR_INITED(mc) || (mc)->mc_ki[top] >= NUMKEYS(xr_pg)) break; \ + xr_node = NODEPTR(xr_pg, (mc)->mc_ki[top]); \ + if ((xr_node->mn_flags & (F_DUPDATA|F_SUBDATA)) == F_DUPDATA) \ + (mc)->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(xr_node); \ +} while (0) + /** State of FreeDB old pages, stored in the MDB_env */ typedef struct MDB_pgstate { pgno_t *mf_pghead; /**< Reclaimed freeDB pages, or NULL before use */ @@ -1346,7 +1461,7 @@ typedef struct MDB_pgstate { struct MDB_env { HANDLE me_fd; /**< The main data file */ HANDLE me_lfd; /**< The lock file */ - HANDLE me_mfd; /**< just for writing the meta pages */ + HANDLE me_mfd; /**< For writing and syncing the meta pages */ #if defined(MDB_VL32) && defined(_WIN32) HANDLE me_fmh; /**< File Mapping handle */ #endif @@ -1407,6 +1522,10 @@ struct MDB_env { #else mdb_mutex_t me_rmutex; mdb_mutex_t me_wmutex; +# if defined(_WIN32) || defined(MDB_USE_POSIX_SEM) + /** Half-initialized name of mutexes, to be completed by #MUTEXNAME() */ + char me_mutexname[sizeof(MUTEXNAME_PREFIX) + 11]; +# endif #endif #ifdef MDB_VL32 MDB_ID3L me_rpages; /**< like #mt_rpages, but global to env */ @@ -1522,19 +1641,25 @@ static int mdb_reader_check0(MDB_env *env, int rlocked, int *dead); static MDB_cmp_func mdb_cmp_memn, mdb_cmp_memnr, mdb_cmp_int, mdb_cmp_cint, mdb_cmp_long; /** @endcond */ -/** Compare two items pointing at size_t's of unknown alignment. */ +/** Compare two items pointing at '#mdb_size_t's of unknown alignment. */ #ifdef MISALIGNED_OK # define mdb_cmp_clong mdb_cmp_long #else # define mdb_cmp_clong mdb_cmp_cint #endif +/** True if we need #mdb_cmp_clong() instead of \b cmp for #MDB_INTEGERDUP */ +#define NEED_CMP_CLONG(cmp, ksize) \ + (UINT_MAX < MDB_SIZE_MAX && \ + (cmp) == mdb_cmp_int && (ksize) == sizeof(mdb_size_t)) + #ifdef _WIN32 static SECURITY_DESCRIPTOR mdb_null_sd; static SECURITY_ATTRIBUTES mdb_all_sa; static int mdb_sec_inited; -static int utf8_to_utf16(const char *src, int srcsize, wchar_t **dst, int *dstsize); +struct MDB_name; +static int utf8_to_utf16(const char *src, struct MDB_name *dst, int xtra); #endif /** Return the library version info. */ @@ -1569,6 +1694,7 @@ static char *const mdb_errstr[] = { "MDB_BAD_TXN: Transaction must abort, has a child, or is invalid", "MDB_BAD_VALSIZE: Unsupported size of key/DB name/data, or wrong DUPFIXED size", "MDB_BAD_DBI: The specified DBI handle was closed/changed unexpectedly", + "MDB_PROBLEM: Unexpected problem - txn should abort", }; char * @@ -1641,11 +1767,7 @@ mdb_assert_fail(MDB_env *env, const char *expr_txt, if (env->me_assert_func) env->me_assert_func(env, buf); fprintf(stderr, "%s\n", buf); -#ifdef NDEBUG - _exit(); -#else abort(); -#endif } #else # define mdb_assert0(env, expr, expr_txt) ((void) 0) @@ -1717,20 +1839,20 @@ mdb_page_list(MDB_page *mp) case P_LEAF|P_LEAF2: type = "LEAF2 page"; break; case P_LEAF|P_LEAF2|P_SUBP: type = "LEAF2 sub-page"; break; case P_OVERFLOW: - fprintf(stderr, "Overflow page %"Y"u pages %u%s\n", + fprintf(stderr, "Overflow page %"Yu" pages %u%s\n", pgno, mp->mp_pages, state); return; case P_META: - fprintf(stderr, "Meta-page %"Y"u txnid %"Y"u\n", + fprintf(stderr, "Meta-page %"Yu" txnid %"Yu"\n", pgno, ((MDB_meta *)METADATA(mp))->mm_txnid); return; default: - fprintf(stderr, "Bad page %"Y"u flags 0x%u\n", pgno, mp->mp_flags); + fprintf(stderr, "Bad page %"Yu" flags 0x%X\n", pgno, mp->mp_flags); return; } nkeys = NUMKEYS(mp); - fprintf(stderr, "%s %"Y"u numkeys %d%s\n", type, pgno, nkeys, state); + fprintf(stderr, "%s %"Yu" numkeys %d%s\n", type, pgno, nkeys, state); for (i=0; imn_data; nsize = NODESIZE + key.mv_size; if (IS_BRANCH(mp)) { - fprintf(stderr, "key %d: page %"Y"u, %s\n", i, NODEPGNO(node), + fprintf(stderr, "key %d: page %"Yu", %s\n", i, NODEPGNO(node), DKEY(&key)); total += nsize; } else { @@ -1780,7 +1902,7 @@ mdb_cursor_chk(MDB_cursor *mc) } if (mc->mc_ki[i] >= NUMKEYS(mc->mc_pg[i])) printf("ack!\n"); - if (mc->mc_xcursor && (mc->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED)) { + if (XCURSOR_INITED(mc)) { node = NODEPTR(mc->mc_pg[mc->mc_top], mc->mc_ki[mc->mc_top]); if (((node->mn_flags & (F_DUPDATA|F_SUBDATA)) == F_DUPDATA) && mc->mc_xcursor->mx_cursor.mc_pg[0] != NODEDATA(node)) { @@ -1841,7 +1963,7 @@ static void mdb_audit(MDB_txn *txn) } } if (freecount + count + NUM_METAS != txn->mt_next_pgno) { - fprintf(stderr, "audit: %"Y"u freecount: %"Y"u count: %"Y"u total: %"Y"u next_pgno: %"Y"u\n", + fprintf(stderr, "audit: %"Yu" freecount: %"Yu" count: %"Yu" total: %"Yu" next_pgno: %"Yu"\n", txn->mt_txnid, freecount, count+NUM_METAS, freecount+count+NUM_METAS, txn->mt_next_pgno); } @@ -1858,15 +1980,14 @@ int mdb_dcmp(MDB_txn *txn, MDB_dbi dbi, const MDB_val *a, const MDB_val *b) { MDB_cmp_func *dcmp = txn->mt_dbxs[dbi].md_dcmp; -#if UINT_MAX < SIZE_MAX || defined(MDB_VL32) - if (dcmp == mdb_cmp_int && a->mv_size == sizeof(mdb_size_t)) + if (NEED_CMP_CLONG(dcmp, a->mv_size)) dcmp = mdb_cmp_clong; -#endif return dcmp(a, b); } /** Allocate memory for a page. * Re-use old malloc'd pages first for singletons, otherwise just malloc. + * Set #MDB_TXN_ERROR on failure. */ static MDB_page * mdb_page_malloc(MDB_txn *txn, unsigned num) @@ -1978,8 +2099,14 @@ mdb_cursor_unref(MDB_cursor *mc) mc->mc_pg[0] = NULL; mc->mc_flags &= ~C_INITIALIZED; } +#define MDB_CURSOR_UNREF(mc, force) \ + (((force) || ((mc)->mc_flags & C_INITIALIZED)) \ + ? mdb_cursor_unref(mc) \ + : (void)0) + #else #define MDB_PAGE_UNREF(txn, mp) +#define MDB_CURSOR_UNREF(mc, force) ((void)0) #endif /* MDB_VL32 */ /** Loosen or free a single page. @@ -2011,7 +2138,7 @@ mdb_page_loose(MDB_cursor *mc, MDB_page *mp) if (mp != dl[x].mptr) { /* bad cursor? */ mc->mc_flags &= ~(C_INITIALIZED|C_EOF); txn->mt_flags |= MDB_TXN_ERROR; - return MDB_CORRUPTED; + return MDB_PROBLEM; } /* ok, it's ours */ loose = 1; @@ -2023,8 +2150,7 @@ mdb_page_loose(MDB_cursor *mc, MDB_page *mp) } } if (loose) { - DPRINTF(("loosen db %d page %"Y"u", DDBI(mc), - mp->mp_pgno)); + DPRINTF(("loosen db %d page %"Yu, DDBI(mc), mp->mp_pgno)); NEXT_LOOSE_PAGE(mp) = txn->mt_loose_pgs; txn->mt_loose_pgs = mp; txn->mt_loose_count++; @@ -2057,13 +2183,9 @@ mdb_pages_xkeep(MDB_cursor *mc, unsigned pflags, int all) unsigned i, j; int rc = MDB_SUCCESS, level; - /* Mark pages seen by cursors */ - if (mc->mc_flags & C_UNTRACK) - mc = NULL; /* will find mc in mt_cursors */ - for (i = txn->mt_numdbs;; mc = txn->mt_cursors[--i]) { - for (; mc; mc=mc->mc_next) { - if (!(mc->mc_flags & C_INITIALIZED)) - continue; + /* Mark pages seen by cursors: First m0, then tracked cursors */ + for (i = txn->mt_numdbs;; ) { + if (mc->mc_flags & C_INITIALIZED) { for (m3 = mc;; m3 = &mx->mx_cursor) { mp = NULL; for (j=0; jmc_snum; j++) { @@ -2082,10 +2204,13 @@ mdb_pages_xkeep(MDB_cursor *mc, unsigned pflags, int all) break; } } - if (i == 0) - break; + mc = mc->mc_next; + for (; !mc || mc == m0; mc = txn->mt_cursors[--i]) + if (i == 0) + goto mark_done; } +mark_done: if (all) { /* Mark dirty root pages */ for (i=0; imt_numdbs; i++) { @@ -2275,7 +2400,7 @@ mdb_page_dirty(MDB_txn *txn, MDB_page *mp) } /** Allocate page numbers and memory for writing. Maintain me_pglast, - * me_pghead and mt_next_pgno. + * me_pghead and mt_next_pgno. Set #MDB_TXN_ERROR on failure. * * If there are free pages available from older transactions, they * are re-used first. Otherwise allocate a new page at mt_next_pgno. @@ -2321,8 +2446,7 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp) np = txn->mt_loose_pgs; txn->mt_loose_pgs = NEXT_LOOSE_PAGE(np); txn->mt_loose_count--; - DPRINTF(("db %d use loose page %"Y"u", DDBI(mc), - np->mp_pgno)); + DPRINTF(("db %d use loose page %"Yu, DDBI(mc), np->mp_pgno)); *mp = np; return MDB_SUCCESS; } @@ -2408,7 +2532,7 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp) np = m2.mc_pg[m2.mc_top]; leaf = NODEPTR(np, m2.mc_ki[m2.mc_top]); if ((rc = mdb_node_read(&m2, leaf, &data)) != MDB_SUCCESS) - return rc; + goto fail; idl = (MDB_ID *) data.mv_data; i = idl[0]; @@ -2424,10 +2548,10 @@ mdb_page_alloc(MDB_cursor *mc, int num, MDB_page **mp) } env->me_pglast = last; #if (MDB_DEBUG) > 1 - DPRINTF(("IDL read txn %"Y"u root %"Y"u num %u", + DPRINTF(("IDL read txn %"Yu" root %"Yu" num %u", last, txn->mt_dbs[FREE_DBI].md_root, i)); for (j = i; j; j--) - DPRINTF(("IDL %"Y"u", idl[j])); + DPRINTF(("IDL %"Yu, idl[j])); #endif /* Merge in descending sorted order */ mdb_midl_xmerge(mop, idl); @@ -2572,6 +2696,7 @@ mdb_page_unspill(MDB_txn *txn, MDB_page *mp, MDB_page **ret) } /** Touch a page: make it dirty and re-insert into tree with updated pgno. + * Set #MDB_TXN_ERROR on failure. * @param[in] mc cursor pointing to the page to be touched * @return 0 on success, non-zero on failure. */ @@ -2597,7 +2722,7 @@ mdb_page_touch(MDB_cursor *mc) (rc = mdb_page_alloc(mc, 1, &np))) goto fail; pgno = np->mp_pgno; - DPRINTF(("touched db %d page %"Y"u -> %"Y"u", DDBI(mc), + DPRINTF(("touched db %d page %"Yu" -> %"Yu, DDBI(mc), mp->mp_pgno, pgno)); mdb_cassert(mc, mp->mp_pgno != pgno); mdb_midl_xappend(txn->mt_free_pgs, mp->mp_pgno); @@ -2621,7 +2746,7 @@ mdb_page_touch(MDB_cursor *mc) if (mp != dl[x].mptr) { /* bad cursor? */ mc->mc_flags &= ~(C_INITIALIZED|C_EOF); txn->mt_flags |= MDB_TXN_ERROR; - return MDB_CORRUPTED; + return MDB_PROBLEM; } return 0; } @@ -2660,14 +2785,8 @@ done: if (m2 == mc) continue; if (m2->mc_pg[mc->mc_top] == mp) { m2->mc_pg[mc->mc_top] = np; - if ((mc->mc_db->md_flags & MDB_DUPSORT) && - IS_LEAF(np) && - (m2->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED)) - { - MDB_node *leaf = NODEPTR(np, m2->mc_ki[mc->mc_top]); - if ((leaf->mn_flags & (F_DUPDATA|F_SUBDATA)) == F_DUPDATA) - m2->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(leaf); - } + if (IS_LEAF(np)) + XCURSOR_REFRESH(m2, mc->mc_top, np); } } } @@ -2998,7 +3117,7 @@ mdb_txn_renew(MDB_txn *txn) rc = mdb_txn_renew0(txn); if (rc == MDB_SUCCESS) { - DPRINTF(("renew txn %"Y"u%c %p on mdbenv %p, root page %"Y"u", + DPRINTF(("renew txn %"Yu"%c %p on mdbenv %p, root page %"Yu, txn->mt_txnid, (txn->mt_flags & MDB_TXN_RDONLY) ? 'r' : 'w', (void *)txn, (void *)txn->mt_env, txn->mt_dbs[MAIN_DBI].md_root)); } @@ -3116,7 +3235,7 @@ renew: } else { txn->mt_flags |= flags; /* could not change txn=me_txn0 earlier */ *ret = txn; - DPRINTF(("begin txn %"Y"u%c %p on mdbenv %p, root page %"Y"u", + DPRINTF(("begin txn %"Yu"%c %p on mdbenv %p, root page %"Yu, txn->mt_txnid, (flags & MDB_RDONLY) ? 'r' : 'w', (void *) txn, (void *) env, txn->mt_dbs[MAIN_DBI].md_root)); } @@ -3183,7 +3302,7 @@ mdb_txn_end(MDB_txn *txn, unsigned mode) /* Export or close DBI handles opened in this txn */ mdb_dbis_update(txn, mode & MDB_END_UPDATE); - DPRINTF(("%s txn %"Y"u%c %p on mdbenv %p, root page %"Y"u", + DPRINTF(("%s txn %"Yu"%c %p on mdbenv %p, root page %"Yu, names[mode & MDB_END_OPMASK], txn->mt_txnid, (txn->mt_flags & MDB_TXN_RDONLY) ? 'r' : 'w', (void *) txn, (void *)env, txn->mt_dbs[MAIN_DBI].md_root)); @@ -3325,10 +3444,41 @@ mdb_freelist_save(MDB_txn *txn) * we may be unable to return them to me_pghead. */ MDB_page *mp = txn->mt_loose_pgs; + MDB_ID2 *dl = txn->mt_u.dirty_list; + unsigned x; if ((rc = mdb_midl_need(&txn->mt_free_pgs, txn->mt_loose_count)) != 0) return rc; - for (; mp; mp = NEXT_LOOSE_PAGE(mp)) + for (; mp; mp = NEXT_LOOSE_PAGE(mp)) { mdb_midl_xappend(txn->mt_free_pgs, mp->mp_pgno); + /* must also remove from dirty list */ + if (txn->mt_flags & MDB_TXN_WRITEMAP) { + for (x=1; x<=dl[0].mid; x++) + if (dl[x].mid == mp->mp_pgno) + break; + mdb_tassert(txn, x <= dl[0].mid); + } else { + x = mdb_mid2l_search(dl, mp->mp_pgno); + mdb_tassert(txn, dl[x].mid == mp->mp_pgno); + } + dl[x].mptr = NULL; + mdb_dpage_free(env, mp); + } + { + /* squash freed slots out of the dirty list */ + unsigned y; + for (y=1; dl[y].mptr && y <= dl[0].mid; y++); + if (y <= dl[0].mid) { + for(x=y, y++;;) { + while (!dl[y].mptr && y <= dl[0].mid) y++; + if (y > dl[0].mid) break; + dl[x++] = dl[y++]; + } + dl[0].mid = x-1; + } else { + /* all slots freed */ + dl[0].mid = 0; + } + } txn->mt_loose_pgs = NULL; txn->mt_loose_count = 0; } @@ -3384,10 +3534,10 @@ mdb_freelist_save(MDB_txn *txn) #if (MDB_DEBUG) > 1 { unsigned int i = free_pgs[0]; - DPRINTF(("IDL write txn %"Y"u root %"Y"u num %u", + DPRINTF(("IDL write txn %"Yu" root %"Yu" num %u", txn->mt_txnid, txn->mt_dbs[FREE_DBI].md_root, i)); for (; i; i--) - DPRINTF(("IDL %"Y"u", free_pgs[i])); + DPRINTF(("IDL %"Yu, free_pgs[i])); } #endif continue; @@ -3555,7 +3705,7 @@ mdb_page_flush(MDB_txn *txn, int keep) * the write offset, to at least save the overhead of a Seek * system call. */ - DPRINTF(("committing page %"Z"u", pgno)); + DPRINTF(("committing page %"Yu, pgno)); memset(&ov, 0, sizeof(ov)); ov.Offset = pos & 0xffffffff; ov.OffsetHigh = pos >> 16 >> 16; @@ -3606,7 +3756,7 @@ retry_seek: wpos = pos; wsize = 0; } - DPRINTF(("committing page %"Y"u", pgno)); + DPRINTF(("committing page %"Yu, pgno)); next_pos = pos + size; iov[n].iov_len = size; iov[n].iov_base = (char *)dp; @@ -3821,7 +3971,7 @@ mdb_txn_commit(MDB_txn *txn) !(txn->mt_flags & (MDB_TXN_DIRTY|MDB_TXN_SPILLS))) goto done; - DPRINTF(("committing txn %"Y"u %p on mdbenv %p, root page %"Y"u", + DPRINTF(("committing txn %"Yu" %p on mdbenv %p, root page %"Yu, txn->mt_txnid, (void*)txn, (void*)env, txn->mt_dbs[MAIN_DBI].md_root)); /* Update DB root pointers */ @@ -3929,7 +4079,7 @@ mdb_env_read_header(MDB_env *env, int prev, MDB_meta *meta) p = (MDB_page *)&pbuf; if (!F_ISSET(p->mp_flags, P_META)) { - DPRINTF(("page %"Y"u not a meta page", p->mp_pgno)); + DPRINTF(("page %"Yu" not a meta page", p->mp_pgno)); return MDB_INVALID; } @@ -4041,7 +4191,7 @@ mdb_env_write_meta(MDB_txn *txn) #endif toggle = txn->mt_txnid & 1; - DPRINTF(("writing meta page %d for root page %"Y"u", + DPRINTF(("writing meta page %d for root page %"Yu, toggle, txn->mt_dbs[MAIN_DBI].md_root)); env = txn->mt_env; @@ -4093,7 +4243,10 @@ mdb_env_write_meta(MDB_txn *txn) len = sizeof(MDB_meta) - off; off += (char *)mp - env->me_map; - /* Write to the SYNC fd */ + /* Write to the SYNC fd unless MDB_NOSYNC/MDB_NOMETASYNC. + * (me_mfd goes to the same file as me_fd, but writing to it + * also syncs to disk. Avoids a separate fdatasync() call.) + */ mfd = (flags & (MDB_NOSYNC|MDB_NOMETASYNC)) ? env->me_fd : env->me_mfd; #ifdef _WIN32 { @@ -4382,6 +4535,189 @@ mdb_fsize(HANDLE fd, mdb_size_t *size) return MDB_SUCCESS; } + +#ifdef _WIN32 +typedef wchar_t mdb_nchar_t; +# define MDB_NAME(str) L##str +# define mdb_name_cpy wcscpy +#else +/** Character type for file names: char on Unix, wchar_t on Windows */ +typedef char mdb_nchar_t; +# define MDB_NAME(str) str /**< #mdb_nchar_t[] string literal */ +# define mdb_name_cpy strcpy /**< Copy name (#mdb_nchar_t string) */ +#endif + +/** Filename - string of #mdb_nchar_t[] */ +typedef struct MDB_name { + int mn_len; /**< Length */ + int mn_alloced; /**< True if #mn_val was malloced */ + mdb_nchar_t *mn_val; /**< Contents */ +} MDB_name; + +/** Filename suffixes [datafile,lockfile][without,with MDB_NOSUBDIR] */ +static const mdb_nchar_t *const mdb_suffixes[2][2] = { + { MDB_NAME("/data.mdb"), MDB_NAME("") }, + { MDB_NAME("/lock.mdb"), MDB_NAME("-lock") } +}; + +#define MDB_SUFFLEN 9 /**< Max string length in #mdb_suffixes[] */ + +/** Set up filename + scratch area for filename suffix, for opening files. + * It should be freed with #mdb_fname_destroy(). + * On Windows, paths are converted from char *UTF-8 to wchar_t *UTF-16. + * + * @param[in] path Pathname for #mdb_env_open(). + * @param[in] envflags Whether a subdir and/or lockfile will be used. + * @param[out] fname Resulting filename, with room for a suffix if necessary. + */ +static int ESECT +mdb_fname_init(const char *path, unsigned envflags, MDB_name *fname) +{ + int no_suffix = F_ISSET(envflags, MDB_NOSUBDIR|MDB_NOLOCK); + fname->mn_alloced = 0; +#ifdef _WIN32 + return utf8_to_utf16(path, fname, no_suffix ? 0 : MDB_SUFFLEN); +#else + fname->mn_len = strlen(path); + if (no_suffix) + fname->mn_val = (char *) path; + else if ((fname->mn_val = malloc(fname->mn_len + MDB_SUFFLEN+1)) != NULL) { + fname->mn_alloced = 1; + strcpy(fname->mn_val, path); + } + else + return ENOMEM; + return MDB_SUCCESS; +#endif +} + +/** Destroy \b fname from #mdb_fname_init() */ +#define mdb_fname_destroy(fname) \ + do { if ((fname).mn_alloced) free((fname).mn_val); } while (0) + +#ifdef O_CLOEXEC /* POSIX.1-2008: Set FD_CLOEXEC atomically at open() */ +# define MDB_CLOEXEC O_CLOEXEC +#else +# define MDB_CLOEXEC 0 +#endif + +/** File type, access mode etc. for #mdb_fopen() */ +enum mdb_fopen_type { +#ifdef _WIN32 + MDB_O_RDONLY, MDB_O_RDWR, MDB_O_META, MDB_O_COPY, MDB_O_LOCKS +#else + /* A comment in mdb_fopen() explains some O_* flag choices. */ + MDB_O_RDONLY= O_RDONLY, /**< for RDONLY me_fd */ + MDB_O_RDWR = O_RDWR |O_CREAT, /**< for me_fd */ + MDB_O_META = O_WRONLY|MDB_DSYNC |MDB_CLOEXEC, /**< for me_mfd */ + MDB_O_COPY = O_WRONLY|O_CREAT|O_EXCL|MDB_CLOEXEC, /**< for #mdb_env_copy() */ + /** Bitmask for open() flags in enum #mdb_fopen_type. The other bits + * distinguish otherwise-equal MDB_O_* constants from each other. + */ + MDB_O_MASK = MDB_O_RDWR|MDB_CLOEXEC | MDB_O_RDONLY|MDB_O_META|MDB_O_COPY, + MDB_O_LOCKS = MDB_O_RDWR|MDB_CLOEXEC | ((MDB_O_MASK+1) & ~MDB_O_MASK) /**< for me_lfd */ +#endif +}; + +/** Open an LMDB file. + * @param[in] env The LMDB environment. + * @param[in,out] fname Path from from #mdb_fname_init(). A suffix is + * appended if necessary to create the filename, without changing mn_len. + * @param[in] which Determines file type, access mode, etc. + * @param[in] mode The Unix permissions for the file, if we create it. + * @param[out] res Resulting file handle. + * @return 0 on success, non-zero on failure. + */ +static int ESECT +mdb_fopen(const MDB_env *env, MDB_name *fname, + enum mdb_fopen_type which, mdb_mode_t mode, + HANDLE *res) +{ + int rc = MDB_SUCCESS; + HANDLE fd; +#ifdef _WIN32 + DWORD acc, share, disp, attrs; +#else + int flags; +#endif + + if (fname->mn_alloced) /* modifiable copy */ + mdb_name_cpy(fname->mn_val + fname->mn_len, + mdb_suffixes[which==MDB_O_LOCKS][F_ISSET(env->me_flags, MDB_NOSUBDIR)]); + + /* The directory must already exist. Usually the file need not. + * MDB_O_META requires the file because we already created it using + * MDB_O_RDWR. MDB_O_COPY must not overwrite an existing file. + * + * With MDB_O_COPY we do not want the OS to cache the writes, since + * the source data is already in the OS cache. + * + * The lockfile needs FD_CLOEXEC (close file descriptor on exec*()) + * to avoid the flock() issues noted under Caveats in lmdb.h. + * Also set it for other filehandles which the user cannot get at + * and close himself, which he may need after fork(). I.e. all but + * me_fd, which programs do use via mdb_env_get_fd(). + */ + +#ifdef _WIN32 + acc = GENERIC_READ|GENERIC_WRITE; + share = FILE_SHARE_READ|FILE_SHARE_WRITE; + disp = OPEN_ALWAYS; + attrs = FILE_ATTRIBUTE_NORMAL; + switch (which) { + case MDB_O_RDONLY: /* read-only datafile */ + acc = GENERIC_READ; + disp = OPEN_EXISTING; + break; + case MDB_O_META: /* for writing metapages */ + acc = GENERIC_WRITE; + disp = OPEN_EXISTING; + attrs = FILE_ATTRIBUTE_NORMAL|FILE_FLAG_WRITE_THROUGH; + break; + case MDB_O_COPY: /* mdb_env_copy() & co */ + acc = GENERIC_WRITE; + share = 0; + disp = CREATE_NEW; + attrs = FILE_FLAG_NO_BUFFERING|FILE_FLAG_WRITE_THROUGH; + break; + default: break; /* silence gcc -Wswitch (not all enum values handled) */ + } + fd = CreateFileW(fname->mn_val, acc, share, NULL, disp, attrs, NULL); +#else + fd = open(fname->mn_val, which & MDB_O_MASK, mode); +#endif + + if (fd == INVALID_HANDLE_VALUE) + rc = ErrCode(); +#ifndef _WIN32 + else { + if (which != MDB_O_RDONLY && which != MDB_O_RDWR) { + /* Set CLOEXEC if we could not pass it to open() */ + if (!MDB_CLOEXEC && (flags = fcntl(fd, F_GETFD)) != -1) + (void) fcntl(fd, F_SETFD, flags | FD_CLOEXEC); + } + if (which == MDB_O_COPY && env->me_psize >= env->me_os_psize) { + /* This may require buffer alignment. There is no portable + * way to ask how much, so we require OS pagesize alignment. + */ +# ifdef F_NOCACHE /* __APPLE__ */ + (void) fcntl(fd, F_NOCACHE, 1); +# elif defined O_DIRECT + /* open(...O_DIRECT...) would break on filesystems without + * O_DIRECT support (ITS#7682). Try to set it here instead. + */ + if ((flags = fcntl(fd, F_GETFL)) != -1) + (void) fcntl(fd, F_SETFL, flags | O_DIRECT); +# endif + } + } +#endif /* !_WIN32 */ + + *res = fd; + return rc; +} + + #ifdef BROKEN_FDATASYNC #include #include @@ -4407,16 +4743,16 @@ mdb_env_open2(MDB_env *env, int prev) if (!NtCreateSection) { HMODULE h = GetModuleHandle("NTDLL.DLL"); if (!h) - return MDB_PANIC; + return MDB_PROBLEM; NtClose = (NtCloseFunc *)GetProcAddress(h, "NtClose"); if (!NtClose) - return MDB_PANIC; + return MDB_PROBLEM; NtMapViewOfSection = (NtMapViewOfSectionFunc *)GetProcAddress(h, "NtMapViewOfSection"); if (!NtMapViewOfSection) - return MDB_PANIC; + return MDB_PROBLEM; NtCreateSection = (NtCreateSectionFunc *)GetProcAddress(h, "NtCreateSection"); if (!NtCreateSection) - return MDB_PANIC; + return MDB_PROBLEM; } #endif /* _WIN32 */ @@ -4554,13 +4890,13 @@ mdb_env_open2(MDB_env *env, int prev) DPRINTF(("opened database version %u, pagesize %u", meta->mm_version, env->me_psize)); - DPRINTF(("using meta page %d", (int) (meta->mm_txnid & 1))); - DPRINTF(("depth: %u", db->md_depth)); - DPRINTF(("entries: %"Y"u", db->md_entries)); - DPRINTF(("branch pages: %"Y"u", db->md_branch_pages)); - DPRINTF(("leaf pages: %"Y"u", db->md_leaf_pages)); - DPRINTF(("overflow pages: %"Y"u", db->md_overflow_pages)); - DPRINTF(("root: %"Y"u", db->md_root)); + DPRINTF(("using meta page %d", (int) (meta->mm_txnid & 1))); + DPRINTF(("depth: %u", db->md_depth)); + DPRINTF(("entries: %"Yu, db->md_entries)); + DPRINTF(("branch pages: %"Yu, db->md_branch_pages)); + DPRINTF(("leaf pages: %"Yu, db->md_leaf_pages)); + DPRINTF(("overflow pages: %"Yu, db->md_overflow_pages)); + DPRINTF(("root: %"Yu, db->md_root)); } #endif @@ -4577,7 +4913,11 @@ mdb_env_reader_dest(void *ptr) { MDB_reader *reader = ptr; - reader->mr_pid = 0; +#ifndef _WIN32 + if (reader->mr_pid == getpid()) /* catch pthread_exit() in child process */ +#endif + /* We omit the mutex, so do this atomically (i.e. skip mr_txnid) */ + reader->mr_pid = 0; } #ifdef _WIN32 @@ -4749,32 +5089,21 @@ mdb_env_excl_lock(MDB_env *env, int *excl) * Share and Enjoy! :-) */ -typedef unsigned long long mdb_hash_t; -#define MDB_HASH_INIT ((mdb_hash_t)0xcbf29ce484222325ULL) - /** perform a 64 bit Fowler/Noll/Vo FNV-1a hash on a buffer * @param[in] val value to hash - * @param[in] hval initial value for hash + * @param[in] len length of value * @return 64 bit hash - * - * NOTE: To use the recommended 64 bit FNV-1a hash, use MDB_HASH_INIT as the - * hval arg on the first call. */ static mdb_hash_t -mdb_hash_val(MDB_val *val, mdb_hash_t hval) +mdb_hash(const void *val, size_t len) { - unsigned char *s = (unsigned char *)val->mv_data; /* unsigned string */ - unsigned char *end = s + val->mv_size; + const unsigned char *s = (const unsigned char *) val, *end = s + len; + mdb_hash_t hval = 0xcbf29ce484222325ULL; /* - * FNV-1a hash each octet of the string + * FNV-1a hash each octet of the buffer */ while (s < end) { - /* xor the bottom with the current octet */ - hval ^= (mdb_hash_t)*s++; - - /* multiply by the 64 bit FNV magic prime mod 2^64 */ - hval += (hval << 1) + (hval << 4) + (hval << 5) + - (hval << 7) + (hval << 8) + (hval << 40); + hval = (hval ^ *s++) * 0x100000001b3ULL; } /* return our new hash value */ return hval; @@ -4791,47 +5120,49 @@ mdb_hash_val(MDB_val *val, mdb_hash_t hval) static const char mdb_a85[]= "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz!#$%&()*+-;<=>?@^_`{|}~"; static void ESECT -mdb_pack85(unsigned long l, char *out) +mdb_pack85(unsigned long long l, char *out) { int i; - for (i=0; i<5; i++) { + for (i=0; i<10 && l; i++) { *out++ = mdb_a85[l % 85]; l /= 85; } + *out = '\0'; } +/** Init #MDB_env.me_mutexname[] except the char which #MUTEXNAME() will set. + * Changes to this code must be reflected in #MDB_LOCK_FORMAT. + */ static void ESECT -mdb_hash_enc(MDB_val *val, char *encbuf) +mdb_env_mname_init(MDB_env *env) { - mdb_hash_t h = mdb_hash_val(val, MDB_HASH_INIT); - - mdb_pack85(h, encbuf); - mdb_pack85(h>>32, encbuf+5); - encbuf[10] = '\0'; + char *nm = env->me_mutexname; + strcpy(nm, MUTEXNAME_PREFIX); + mdb_pack85(env->me_txns->mti_mutexid, nm + sizeof(MUTEXNAME_PREFIX)); } + +/** Return env->me_mutexname after filling in ch ('r'/'w') for convenience */ +#define MUTEXNAME(env, ch) ( \ + (void) ((env)->me_mutexname[sizeof(MUTEXNAME_PREFIX)-1] = (ch)), \ + (env)->me_mutexname) + #endif /** Open and/or initialize the lock region for the environment. * @param[in] env The LMDB environment. - * @param[in] lpath The pathname of the file used for the lock region. + * @param[in] fname Filename + scratch area, from #mdb_fname_init(). * @param[in] mode The Unix permissions for the file, if we create it. * @param[in,out] excl In -1, out lock type: -1 none, 0 shared, 1 exclusive * @return 0 on success, non-zero on failure. */ static int ESECT -mdb_env_setup_locks(MDB_env *env, char *lpath, int mode, int *excl) +mdb_env_setup_locks(MDB_env *env, MDB_name *fname, int mode, int *excl) { #ifdef _WIN32 # define MDB_ERRCODE_ROFS ERROR_WRITE_PROTECT #else # define MDB_ERRCODE_ROFS EROFS -#ifdef O_CLOEXEC /* Linux: Open file and set FD_CLOEXEC atomically */ -# define MDB_CLOEXEC O_CLOEXEC -#else - int fdflags; -# define MDB_CLOEXEC 0 -#endif #endif #ifdef MDB_USE_SYSV_SEM int semid; @@ -4840,30 +5171,14 @@ mdb_env_setup_locks(MDB_env *env, char *lpath, int mode, int *excl) int rc; off_t size, rsize; -#ifdef _WIN32 - wchar_t *wlpath; - rc = utf8_to_utf16(lpath, -1, &wlpath, NULL); - if (rc) - return rc; - env->me_lfd = CreateFileW(wlpath, GENERIC_READ|GENERIC_WRITE, - FILE_SHARE_READ|FILE_SHARE_WRITE, NULL, OPEN_ALWAYS, - FILE_ATTRIBUTE_NORMAL, NULL); - free(wlpath); -#else - env->me_lfd = open(lpath, O_RDWR|O_CREAT|MDB_CLOEXEC, mode); -#endif - if (env->me_lfd == INVALID_HANDLE_VALUE) { - rc = ErrCode(); + rc = mdb_fopen(env, fname, MDB_O_LOCKS, mode, &env->me_lfd); + if (rc) { + /* Omit lockfile if read-only env on read-only filesystem */ if (rc == MDB_ERRCODE_ROFS && (env->me_flags & MDB_RDONLY)) { return MDB_SUCCESS; } - goto fail_errno; + goto fail; } -#if ! ((MDB_CLOEXEC) || defined(_WIN32)) - /* Lose record locks when exec*() */ - if ((fdflags = fcntl(env->me_lfd, F_GETFD) | FD_CLOEXEC) >= 0) - fcntl(env->me_lfd, F_SETFD, fdflags); -#endif if (!(env->me_flags & MDB_NOTLS)) { rc = pthread_key_create(&env->me_txkey, mdb_env_reader_dest); @@ -4929,8 +5244,6 @@ mdb_env_setup_locks(MDB_env *env, char *lpath, int mode, int *excl) DWORD nhigh; DWORD nlow; } idbuf; - MDB_val val; - char encbuf[11]; if (!mdb_sec_inited) { InitializeSecurityDescriptor(&mdb_null_sd, @@ -4945,14 +5258,11 @@ mdb_env_setup_locks(MDB_env *env, char *lpath, int mode, int *excl) idbuf.volume = stbuf.dwVolumeSerialNumber; idbuf.nhigh = stbuf.nFileIndexHigh; idbuf.nlow = stbuf.nFileIndexLow; - val.mv_data = &idbuf; - val.mv_size = sizeof(idbuf); - mdb_hash_enc(&val, encbuf); - sprintf(env->me_txns->mti_rmname, "Global\\MDBr%s", encbuf); - sprintf(env->me_txns->mti_wmname, "Global\\MDBw%s", encbuf); - env->me_rmutex = CreateMutexA(&mdb_all_sa, FALSE, env->me_txns->mti_rmname); + env->me_txns->mti_mutexid = mdb_hash(&idbuf, sizeof(idbuf)); + mdb_env_mname_init(env); + env->me_rmutex = CreateMutexA(&mdb_all_sa, FALSE, MUTEXNAME(env, 'r')); if (!env->me_rmutex) goto fail_errno; - env->me_wmutex = CreateMutexA(&mdb_all_sa, FALSE, env->me_txns->mti_wmname); + env->me_wmutex = CreateMutexA(&mdb_all_sa, FALSE, MUTEXNAME(env, 'w')); if (!env->me_wmutex) goto fail_errno; #elif defined(MDB_USE_POSIX_SEM) struct stat stbuf; @@ -4960,37 +5270,35 @@ mdb_env_setup_locks(MDB_env *env, char *lpath, int mode, int *excl) dev_t dev; ino_t ino; } idbuf; - MDB_val val; - char encbuf[11]; #if defined(__NetBSD__) #define MDB_SHORT_SEMNAMES 1 /* limited to 14 chars */ #endif if (fstat(env->me_lfd, &stbuf)) goto fail_errno; + memset(&idbuf, 0, sizeof(idbuf)); idbuf.dev = stbuf.st_dev; idbuf.ino = stbuf.st_ino; - val.mv_data = &idbuf; - val.mv_size = sizeof(idbuf); - mdb_hash_enc(&val, encbuf); + env->me_txns->mti_mutexid = mdb_hash(&idbuf, sizeof(idbuf)) #ifdef MDB_SHORT_SEMNAMES - encbuf[9] = '\0'; /* drop name from 15 chars to 14 chars */ + /* Max 9 base85-digits. We truncate here instead of in + * mdb_env_mname_init() to keep the latter portable. + */ + % ((mdb_hash_t)85*85*85*85*85*85*85*85*85) #endif - sprintf(env->me_txns->mti_rmname, "/MDBr%s", encbuf); - sprintf(env->me_txns->mti_wmname, "/MDBw%s", encbuf); + ; + mdb_env_mname_init(env); /* Clean up after a previous run, if needed: Try to * remove both semaphores before doing anything else. */ - sem_unlink(env->me_txns->mti_rmname); - sem_unlink(env->me_txns->mti_wmname); - env->me_rmutex = sem_open(env->me_txns->mti_rmname, - O_CREAT|O_EXCL, mode, 1); + sem_unlink(MUTEXNAME(env, 'r')); + sem_unlink(MUTEXNAME(env, 'w')); + env->me_rmutex = sem_open(MUTEXNAME(env, 'r'), O_CREAT|O_EXCL, mode, 1); if (env->me_rmutex == SEM_FAILED) goto fail_errno; - env->me_wmutex = sem_open(env->me_txns->mti_wmname, - O_CREAT|O_EXCL, mode, 1); + env->me_wmutex = sem_open(MUTEXNAME(env, 'w'), O_CREAT|O_EXCL, mode, 1); if (env->me_wmutex == SEM_FAILED) goto fail_errno; #elif defined(MDB_USE_SYSV_SEM) unsigned short vals[2] = {1, 1}; - key_t key = ftok(lpath, 'M'); + key_t key = ftok(fname->mn_val, 'M'); /* fname is lockfile path now */ if (key == -1) goto fail_errno; semid = semget(key, 2, (mode & 0777) | IPC_CREAT); @@ -5000,6 +5308,8 @@ mdb_env_setup_locks(MDB_env *env, char *lpath, int mode, int *excl) if (semctl(semid, 0, SETALL, semu) < 0) goto fail_errno; env->me_txns->mti_semid = semid; + env->me_txns->mti_rlocked = 0; + env->me_txns->mti_wlocked = 0; #else /* MDB_USE_POSIX_MUTEX: */ pthread_mutexattr_t mattr; @@ -5010,15 +5320,17 @@ mdb_env_setup_locks(MDB_env *env, char *lpath, int mode, int *excl) memset(env->me_txns->mti_rmutex, 0, sizeof(*env->me_txns->mti_rmutex)); memset(env->me_txns->mti_wmutex, 0, sizeof(*env->me_txns->mti_wmutex)); - if ((rc = pthread_mutexattr_init(&mattr)) - || (rc = pthread_mutexattr_setpshared(&mattr, PTHREAD_PROCESS_SHARED)) -#ifdef MDB_ROBUST_SUPPORTED - || (rc = pthread_mutexattr_setrobust(&mattr, PTHREAD_MUTEX_ROBUST)) -#endif - || (rc = pthread_mutex_init(env->me_txns->mti_rmutex, &mattr)) - || (rc = pthread_mutex_init(env->me_txns->mti_wmutex, &mattr))) + if ((rc = pthread_mutexattr_init(&mattr)) != 0) goto fail; + rc = pthread_mutexattr_setpshared(&mattr, PTHREAD_PROCESS_SHARED); +#ifdef MDB_ROBUST_SUPPORTED + if (!rc) rc = pthread_mutexattr_setrobust(&mattr, PTHREAD_MUTEX_ROBUST); +#endif + if (!rc) rc = pthread_mutex_init(env->me_txns->mti_rmutex, &mattr); + if (!rc) rc = pthread_mutex_init(env->me_txns->mti_wmutex, &mattr); pthread_mutexattr_destroy(&mattr); + if (rc) + goto fail; #endif /* _WIN32 || ... */ env->me_txns->mti_magic = MDB_MAGIC; @@ -5046,14 +5358,16 @@ mdb_env_setup_locks(MDB_env *env, char *lpath, int mode, int *excl) goto fail; } #ifdef _WIN32 - env->me_rmutex = OpenMutexA(SYNCHRONIZE, FALSE, env->me_txns->mti_rmname); + mdb_env_mname_init(env); + env->me_rmutex = OpenMutexA(SYNCHRONIZE, FALSE, MUTEXNAME(env, 'r')); if (!env->me_rmutex) goto fail_errno; - env->me_wmutex = OpenMutexA(SYNCHRONIZE, FALSE, env->me_txns->mti_wmname); + env->me_wmutex = OpenMutexA(SYNCHRONIZE, FALSE, MUTEXNAME(env, 'w')); if (!env->me_wmutex) goto fail_errno; #elif defined(MDB_USE_POSIX_SEM) - env->me_rmutex = sem_open(env->me_txns->mti_rmname, 0); + mdb_env_mname_init(env); + env->me_rmutex = sem_open(MUTEXNAME(env, 'r'), 0); if (env->me_rmutex == SEM_FAILED) goto fail_errno; - env->me_wmutex = sem_open(env->me_txns->mti_wmname, 0); + env->me_wmutex = sem_open(MUTEXNAME(env, 'w'), 0); if (env->me_wmutex == SEM_FAILED) goto fail_errno; #elif defined(MDB_USE_SYSV_SEM) semid = env->me_txns->mti_semid; @@ -5073,13 +5387,6 @@ mdb_env_setup_locks(MDB_env *env, char *lpath, int mode, int *excl) env->me_wmutex->semnum = 1; env->me_rmutex->locked = &env->me_txns->mti_rlocked; env->me_wmutex->locked = &env->me_txns->mti_wlocked; -#endif -#ifdef MDB_VL32 -#ifdef _WIN32 - env->me_rpmutex = CreateMutex(NULL, FALSE, NULL); -#else - pthread_mutex_init(&env->me_rpmutex, NULL); -#endif #endif return MDB_SUCCESS; @@ -5090,12 +5397,6 @@ fail: return rc; } - /** The name of the lock file in the DB environment */ -#define LOCKNAME "/lock.mdb" - /** The name of the data file in the DB environment */ -#define DATANAME "/data.mdb" - /** The suffix of the lock file when no subdir is used */ -#define LOCKSUFF "-lock" /** Only a subset of the @ref mdb_env flags can be changed * at runtime. Changing other flags requires closing the * environment and re-opening it with the new flags. @@ -5111,11 +5412,8 @@ fail: int ESECT mdb_env_open(MDB_env *env, const char *path, unsigned int flags, mdb_mode_t mode) { - int oflags, rc, len, excl = -1; - char *lpath, *dpath; -#ifdef _WIN32 - wchar_t *wpath; -#endif + int rc, excl = -1; + MDB_name fname; if (env->me_fd!=INVALID_HANDLE_VALUE || (flags & ~(CHANGEABLE|CHANGELESS))) return EINVAL; @@ -5130,28 +5428,27 @@ mdb_env_open(MDB_env *env, const char *path, unsigned int flags, mdb_mode_t mode return EINVAL; } #endif - - len = strlen(path); - if (flags & MDB_NOSUBDIR) { - rc = len + sizeof(LOCKSUFF) + len + 1; - } else { - rc = len + sizeof(LOCKNAME) + len + sizeof(DATANAME); - } - lpath = malloc(rc); - if (!lpath) - return ENOMEM; - if (flags & MDB_NOSUBDIR) { - dpath = lpath + len + sizeof(LOCKSUFF); - sprintf(lpath, "%s" LOCKSUFF, path); - strcpy(dpath, path); - } else { - dpath = lpath + len + sizeof(LOCKNAME); - sprintf(lpath, "%s" LOCKNAME, path); - sprintf(dpath, "%s" DATANAME, path); - } - - rc = MDB_SUCCESS; flags |= env->me_flags; + + rc = mdb_fname_init(path, flags, &fname); + if (rc) + return rc; + +#ifdef MDB_VL32 +#ifdef _WIN32 + env->me_rpmutex = CreateMutex(NULL, FALSE, NULL); + if (!env->me_rpmutex) { + rc = ErrCode(); + goto leave; + } +#else + rc = pthread_mutex_init(&env->me_rpmutex, NULL); + if (rc) + goto leave; +#endif +#endif + flags |= MDB_ENV_ACTIVE; /* tell mdb_env_close0() to clean up */ + if (flags & MDB_RDONLY) { /* silently ignore WRITEMAP when we're only getting read access */ flags &= ~MDB_WRITEMAP; @@ -5160,8 +5457,13 @@ mdb_env_open(MDB_env *env, const char *path, unsigned int flags, mdb_mode_t mode (env->me_dirty_list = calloc(MDB_IDL_UM_SIZE, sizeof(MDB_ID2))))) rc = ENOMEM; } + + env->me_flags = flags; + if (rc) + goto leave; + #ifdef MDB_VL32 - if (!rc) { + { env->me_rpages = malloc(MDB_ERPAGE_SIZE * sizeof(MDB_ID3)); if (!env->me_rpages) { rc = ENOMEM; @@ -5171,9 +5473,6 @@ mdb_env_open(MDB_env *env, const char *path, unsigned int flags, mdb_mode_t mode env->me_rpcheck = MDB_ERPAGE_SIZE/2; } #endif - env->me_flags = flags |= MDB_ENV_ACTIVE; - if (rc) - goto leave; env->me_path = strdup(path); env->me_dbxs = calloc(env->me_maxdbs, sizeof(MDB_dbx)); @@ -5187,41 +5486,7 @@ mdb_env_open(MDB_env *env, const char *path, unsigned int flags, mdb_mode_t mode /* For RDONLY, get lockfile after we know datafile exists */ if (!(flags & (MDB_RDONLY|MDB_NOLOCK))) { - rc = mdb_env_setup_locks(env, lpath, mode, &excl); - if (rc) - goto leave; - } - -#ifdef _WIN32 - if (F_ISSET(flags, MDB_RDONLY)) { - oflags = GENERIC_READ; - len = OPEN_EXISTING; - } else { - oflags = GENERIC_READ|GENERIC_WRITE; - len = OPEN_ALWAYS; - } - mode = FILE_ATTRIBUTE_NORMAL; - rc = utf8_to_utf16(dpath, -1, &wpath, NULL); - if (rc) - goto leave; - env->me_fd = CreateFileW(wpath, oflags, FILE_SHARE_READ|FILE_SHARE_WRITE, - NULL, len, mode, NULL); - free(wpath); -#else - if (F_ISSET(flags, MDB_RDONLY)) - oflags = O_RDONLY; - else - oflags = O_RDWR | O_CREAT; - - env->me_fd = open(dpath, oflags, mode); -#endif - if (env->me_fd == INVALID_HANDLE_VALUE) { - rc = ErrCode(); - goto leave; - } - - if ((flags & (MDB_RDONLY|MDB_NOLOCK)) == MDB_RDONLY) { - rc = mdb_env_setup_locks(env, lpath, mode, &excl); + rc = mdb_env_setup_locks(env, &fname, mode, &excl); if (rc) goto leave; if ((flags & MDB_PREVSNAPSHOT) && !excl) { @@ -5230,30 +5495,26 @@ mdb_env_open(MDB_env *env, const char *path, unsigned int flags, mdb_mode_t mode } } + rc = mdb_fopen(env, &fname, + (flags & MDB_RDONLY) ? MDB_O_RDONLY : MDB_O_RDWR, + mode, &env->me_fd); + if (rc) + goto leave; + + if ((flags & (MDB_RDONLY|MDB_NOLOCK)) == MDB_RDONLY) { + rc = mdb_env_setup_locks(env, &fname, mode, &excl); + if (rc) + goto leave; + } + if ((rc = mdb_env_open2(env, flags & MDB_PREVSNAPSHOT)) == MDB_SUCCESS) { - if (flags & (MDB_RDONLY|MDB_WRITEMAP)) { - env->me_mfd = env->me_fd; - } else { + if (!(flags & (MDB_RDONLY|MDB_WRITEMAP))) { /* Synchronous fd for meta writes. Needed even with * MDB_NOSYNC/MDB_NOMETASYNC, in case these get reset. */ -#ifdef _WIN32 - len = OPEN_EXISTING; - rc = utf8_to_utf16(dpath, -1, &wpath, NULL); + rc = mdb_fopen(env, &fname, MDB_O_META, mode, &env->me_mfd); if (rc) goto leave; - env->me_mfd = CreateFileW(wpath, oflags, - FILE_SHARE_READ|FILE_SHARE_WRITE, NULL, len, - mode | FILE_FLAG_WRITE_THROUGH, NULL); - free(wpath); -#else - oflags &= ~O_CREAT; - env->me_mfd = open(dpath, oflags | MDB_DSYNC, mode); -#endif - if (env->me_mfd == INVALID_HANDLE_VALUE) { - rc = ErrCode(); - goto leave; - } } DPRINTF(("opened dbenv %p", (void *) env)); if (excl > 0 && !(flags & MDB_PREVSNAPSHOT)) { @@ -5296,7 +5557,7 @@ leave: if (rc) { mdb_env_close0(env, excl); } - free(lpath); + mdb_fname_destroy(fname); return rc; } @@ -5324,11 +5585,13 @@ mdb_env_close0(MDB_env *env, int excl) #ifdef MDB_VL32 if (env->me_txn0 && env->me_txn0->mt_rpages) free(env->me_txn0->mt_rpages); - { unsigned int x; - for (x=1; x<=env->me_rpages[0].mid; x++) - munmap(env->me_rpages[x].mptr, env->me_rpages[x].mcnt * env->me_psize); + if (env->me_rpages) { + MDB_ID3L el = env->me_rpages; + unsigned int x; + for (x=1; x<=el[0].mid; x++) + munmap(el[x].mptr, el[x].mcnt * env->me_psize); + free(el); } - free(env->me_rpages); #endif free(env->me_txn0); mdb_midl_free(env->me_free_pgs); @@ -5353,12 +5616,12 @@ mdb_env_close0(MDB_env *env, int excl) munmap(env->me_map, env->me_mapsize); #endif } - if (env->me_mfd != env->me_fd && env->me_mfd != INVALID_HANDLE_VALUE) + if (env->me_mfd != INVALID_HANDLE_VALUE) (void) close(env->me_mfd); if (env->me_fd != INVALID_HANDLE_VALUE) (void) close(env->me_fd); if (env->me_txns) { - MDB_PID_T pid = env->me_pid; + MDB_PID_T pid = getpid(); /* Clearing readers is done in this function because * me_txkey with its destructor must be disabled first. * @@ -5388,8 +5651,8 @@ mdb_env_close0(MDB_env *env, int excl) if (excl == 0) mdb_env_excl_lock(env, &excl); if (excl > 0) { - sem_unlink(env->me_txns->mti_rmname); - sem_unlink(env->me_txns->mti_wmname); + sem_unlink(MUTEXNAME(env, 'r')); + sem_unlink(MUTEXNAME(env, 'w')); } } #elif defined(MDB_USE_SYSV_SEM) @@ -5447,7 +5710,7 @@ mdb_env_close(MDB_env *env) free(env); } -/** Compare two items pointing at aligned mdb_size_t's */ +/** Compare two items pointing at aligned #mdb_size_t's */ static int mdb_cmp_long(const MDB_val *a, const MDB_val *b) { @@ -5458,7 +5721,7 @@ mdb_cmp_long(const MDB_val *a, const MDB_val *b) /** Compare two items pointing at aligned unsigned int's. * * This is also set as #MDB_INTEGERDUP|#MDB_DUPFIXED's #MDB_dbx.%md_dcmp, - * but #mdb_cmp_clong() is called instead if the data type is mdb_size_t. + * but #mdb_cmp_clong() is called instead if the data type is #mdb_size_t. */ static int mdb_cmp_int(const MDB_val *a, const MDB_val *b) @@ -5563,7 +5826,7 @@ mdb_node_search(MDB_cursor *mc, MDB_val *key, int *exactp) nkeys = NUMKEYS(mp); - DPRINTF(("searching %u keys in %s %spage %"Y"u", + DPRINTF(("searching %u keys in %s %spage %"Yu, nkeys, IS_LEAF(mp) ? "leaf" : "branch", IS_SUBP(mp) ? "sub-" : "", mdb_dbg_pgno(mp))); @@ -5611,7 +5874,7 @@ mdb_node_search(MDB_cursor *mc, MDB_val *key, int *exactp) DPRINTF(("found leaf index %u [%s], rc = %i", i, DKEY(&nodekey), rc)); else - DPRINTF(("found branch index %u [%s -> %"Y"u], rc = %i", + DPRINTF(("found branch index %u [%s -> %"Yu"], rc = %i", i, DKEY(&nodekey), NODEPGNO(node), rc)); #endif if (rc == 0) @@ -5659,7 +5922,7 @@ static void mdb_cursor_pop(MDB_cursor *mc) { if (mc->mc_snum) { - DPRINTF(("popping page %"Y"u off db %d cursor %p", + DPRINTF(("popping page %"Yu" off db %d cursor %p", mc->mc_pg[mc->mc_top]->mp_pgno, DDBI(mc), (void *) mc)); mc->mc_snum--; @@ -5671,11 +5934,13 @@ mdb_cursor_pop(MDB_cursor *mc) } } -/** Push a page onto the top of the cursor's stack. */ +/** Push a page onto the top of the cursor's stack. + * Set #MDB_TXN_ERROR on failure. + */ static int mdb_cursor_push(MDB_cursor *mc, MDB_page *mp) { - DPRINTF(("pushing page %"Y"u on db %d cursor %p", mp->mp_pgno, + DPRINTF(("pushing page %"Yu" on db %d cursor %p", mp->mp_pgno, DDBI(mc), (void *) mc)); if (mc->mc_snum >= CURSOR_STACK) { @@ -5979,6 +6244,7 @@ ok: #endif /** Find the address of the page corresponding to a given page number. + * Set #MDB_TXN_ERROR on failure. * @param[in] mc the cursor accessing the page. * @param[in] pgno the page number for the page to retrieve. * @param[out] ret address of a pointer where the page's address will be stored. @@ -5989,9 +6255,6 @@ static int mdb_page_get(MDB_cursor *mc, pgno_t pgno, MDB_page **ret, int *lvl) { MDB_txn *txn = mc->mc_txn; -#ifndef MDB_VL32 - MDB_env *env = txn->mt_env; -#endif MDB_page *p = NULL; int level; @@ -6010,14 +6273,7 @@ mdb_page_get(MDB_cursor *mc, pgno_t pgno, MDB_page **ret, int *lvl) MDB_ID pn = pgno << 1; x = mdb_midl_search(tx2->mt_spill_pgs, pn); if (x <= tx2->mt_spill_pgs[0] && tx2->mt_spill_pgs[x] == pn) { -#ifdef MDB_VL32 - int rc = mdb_rpage_get(txn, pgno, &p); - if (rc) - return rc; -#else - p = (MDB_page *)(env->me_map + env->me_psize * pgno); -#endif - goto done; + goto mapped; } } if (dl[0].mid) { @@ -6031,23 +6287,28 @@ mdb_page_get(MDB_cursor *mc, pgno_t pgno, MDB_page **ret, int *lvl) } while ((tx2 = tx2->mt_parent) != NULL); } - if (pgno < txn->mt_next_pgno) { - level = 0; -#ifdef MDB_VL32 - { - int rc = mdb_rpage_get(txn, pgno, &p); - if (rc) - return rc; - } -#else - p = (MDB_page *)(env->me_map + env->me_psize * pgno); -#endif - } else { - DPRINTF(("page %"Y"u not found", pgno)); + if (pgno >= txn->mt_next_pgno) { + DPRINTF(("page %"Yu" not found", pgno)); txn->mt_flags |= MDB_TXN_ERROR; return MDB_PAGE_NOTFOUND; } + level = 0; + +mapped: + { +#ifdef MDB_VL32 + int rc = mdb_rpage_get(txn, pgno, &p); + if (rc) { + txn->mt_flags |= MDB_TXN_ERROR; + return rc; + } +#else + MDB_env *env = txn->mt_env; + p = (MDB_page *)(env->me_map + env->me_psize * pgno); +#endif + } + done: *ret = p; if (lvl) @@ -6069,18 +6330,27 @@ mdb_page_search_root(MDB_cursor *mc, MDB_val *key, int flags) MDB_node *node; indx_t i; - DPRINTF(("branch page %"Y"u has %u keys", mp->mp_pgno, NUMKEYS(mp))); + DPRINTF(("branch page %"Yu" has %u keys", mp->mp_pgno, NUMKEYS(mp))); /* Don't assert on branch pages in the FreeDB. We can get here * while in the process of rebalancing a FreeDB branch page; we must * let that proceed. ITS#8336 */ mdb_cassert(mc, !mc->mc_dbi || NUMKEYS(mp) > 1); - DPRINTF(("found index 0 to page %"Y"u", NODEPGNO(NODEPTR(mp, 0)))); + DPRINTF(("found index 0 to page %"Yu, NODEPGNO(NODEPTR(mp, 0)))); if (flags & (MDB_PS_FIRST|MDB_PS_LAST)) { i = 0; - if (flags & MDB_PS_LAST) + if (flags & MDB_PS_LAST) { i = NUMKEYS(mp) - 1; + /* if already init'd, see if we're already in right place */ + if (mc->mc_flags & C_INITIALIZED) { + if (mc->mc_ki[mc->mc_top] == i) { + mc->mc_top = mc->mc_snum++; + mp = mc->mc_pg[mc->mc_top]; + goto ready; + } + } + } } else { int exact; node = mdb_node_search(mc, key, &exact); @@ -6106,6 +6376,7 @@ mdb_page_search_root(MDB_cursor *mc, MDB_val *key, int flags) if ((rc = mdb_cursor_push(mc, mp))) return rc; +ready: if (flags & MDB_PS_MODIFY) { if ((rc = mdb_page_touch(mc)) != 0) return rc; @@ -6120,7 +6391,7 @@ mdb_page_search_root(MDB_cursor *mc, MDB_val *key, int flags) return MDB_CORRUPTED; } - DPRINTF(("found leaf page %"Y"u for key [%s]", mp->mp_pgno, + DPRINTF(("found leaf page %"Yu" for key [%s]", mp->mp_pgno, key ? DKEY(key) : "null")); mc->mc_flags |= C_INITIALIZED; mc->mc_flags &= ~C_EOF; @@ -6235,7 +6506,7 @@ mdb_page_search(MDB_cursor *mc, MDB_val *key, int flags) mc->mc_snum = 1; mc->mc_top = 0; - DPRINTF(("db %d root page %"Y"u has flags 0x%X", + DPRINTF(("db %d root page %"Yu" has flags 0x%X", DDBI(mc), root, mc->mc_pg[0]->mp_flags)); if (flags & MDB_PS_MODIFY) { @@ -6260,7 +6531,7 @@ mdb_ovpage_free(MDB_cursor *mc, MDB_page *mp) MDB_ID pn = pg << 1; int rc; - DPRINTF(("free ov page %"Y"u (%d)", pg, ovpages)); + DPRINTF(("free ov page %"Yu" (%d)", pg, ovpages)); /* If the page is dirty or on the spill list we just acquired it, * so we should give it back to our current free list, if any. * Otherwise put it onto the list of pages we freed in this txn. @@ -6301,7 +6572,7 @@ mdb_ovpage_free(MDB_cursor *mc, MDB_page *mp) j = ++(dl[0].mid); dl[j] = ix; /* Unsorted. OK when MDB_TXN_ERROR. */ txn->mt_flags |= MDB_TXN_ERROR; - return MDB_CORRUPTED; + return MDB_PROBLEM; } } txn->mt_dirty_room++; @@ -6342,12 +6613,10 @@ mdb_node_read(MDB_cursor *mc, MDB_node *leaf, MDB_val *data) pgno_t pgno; int rc; -#ifdef MDB_VL32 - if (mc->mc_ovpg) { - MDB_PAGE_UNREF(mc->mc_txn, mc->mc_ovpg); - mc->mc_ovpg = 0; + if (MC_OVPG(mc)) { + MDB_PAGE_UNREF(mc->mc_txn, MC_OVPG(mc)); + MC_SET_OVPG(mc, NULL); } -#endif if (!F_ISSET(leaf->mn_flags, F_BIGDATA)) { data->mv_size = NODEDSZ(leaf); data->mv_data = NODEDATA(leaf); @@ -6359,13 +6628,11 @@ mdb_node_read(MDB_cursor *mc, MDB_node *leaf, MDB_val *data) data->mv_size = NODEDSZ(leaf); memcpy(&pgno, NODEDATA(leaf), sizeof(pgno)); if ((rc = mdb_page_get(mc, pgno, &omp, NULL)) != 0) { - DPRINTF(("read overflow page %"Y"u failed", pgno)); + DPRINTF(("read overflow page %"Yu" failed", pgno)); return rc; } data->mv_data = METADATA(omp); -#ifdef MDB_VL32 - mc->mc_ovpg = omp; -#endif + MC_SET_OVPG(mc, omp); return MDB_SUCCESS; } @@ -6389,14 +6656,10 @@ mdb_get(MDB_txn *txn, MDB_dbi dbi, mdb_cursor_init(&mc, txn, dbi, &mx); rc = mdb_cursor_set(&mc, key, data, MDB_SET, &exact); -#ifdef MDB_VL32 - { - /* unref all the pages - caller must copy the data - * before doing anything else - */ - mdb_cursor_unref(&mc); - } -#endif + /* unref all the pages when MDB_VL32 - caller must copy the data + * before doing anything else + */ + MDB_CURSOR_UNREF(&mc, 1); return rc; } @@ -6426,7 +6689,7 @@ mdb_cursor_sibling(MDB_cursor *mc, int move_right) op = mc->mc_pg[mc->mc_top]; #endif mdb_cursor_pop(mc); - DPRINTF(("parent page is page %"Y"u, index %u", + DPRINTF(("parent page is page %"Yu", index %u", mc->mc_pg[mc->mc_top]->mp_pgno, mc->mc_ki[mc->mc_top])); if (move_right ? (mc->mc_ki[mc->mc_top] + 1u >= NUMKEYS(mc->mc_pg[mc->mc_top])) @@ -6473,14 +6736,20 @@ mdb_cursor_next(MDB_cursor *mc, MDB_val *key, MDB_val *data, MDB_cursor_op op) MDB_node *leaf; int rc; - if (mc->mc_flags & C_EOF) { + if ((mc->mc_flags & C_DEL && op == MDB_NEXT_DUP)) return MDB_NOTFOUND; - } - mdb_cassert(mc, mc->mc_flags & C_INITIALIZED); + if (!(mc->mc_flags & C_INITIALIZED)) + return mdb_cursor_first(mc, key, data); mp = mc->mc_pg[mc->mc_top]; + if (mc->mc_flags & C_EOF) { + if (mc->mc_ki[mc->mc_top] >= NUMKEYS(mp)-1) + return MDB_NOTFOUND; + mc->mc_flags ^= C_EOF; + } + if (mc->mc_db->md_flags & MDB_DUPSORT) { leaf = NODEPTR(mp, mc->mc_ki[mc->mc_top]); if (F_ISSET(leaf->mn_flags, F_DUPDATA)) { @@ -6492,13 +6761,9 @@ mdb_cursor_next(MDB_cursor *mc, MDB_val *key, MDB_val *data, MDB_cursor_op op) return rc; } } -#ifdef MDB_VL32 else { - if (mc->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED) { - mdb_cursor_unref(&mc->mc_xcursor->mx_cursor); - } + MDB_CURSOR_UNREF(&mc->mc_xcursor->mx_cursor, 0); } -#endif } else { mc->mc_xcursor->mx_cursor.mc_flags &= ~(C_INITIALIZED|C_EOF); if (op == MDB_NEXT_DUP) @@ -6506,7 +6771,7 @@ mdb_cursor_next(MDB_cursor *mc, MDB_val *key, MDB_val *data, MDB_cursor_op op) } } - DPRINTF(("cursor_next: top page is %"Y"u in cursor %p", + DPRINTF(("cursor_next: top page is %"Yu" in cursor %p", mdb_dbg_pgno(mp), (void *) mc)); if (mc->mc_flags & C_DEL) { mc->mc_flags ^= C_DEL; @@ -6520,12 +6785,12 @@ mdb_cursor_next(MDB_cursor *mc, MDB_val *key, MDB_val *data, MDB_cursor_op op) return rc; } mp = mc->mc_pg[mc->mc_top]; - DPRINTF(("next page is %"Y"u, key index %u", mp->mp_pgno, mc->mc_ki[mc->mc_top])); + DPRINTF(("next page is %"Yu", key index %u", mp->mp_pgno, mc->mc_ki[mc->mc_top])); } else mc->mc_ki[mc->mc_top]++; skip: - DPRINTF(("==> cursor points to page %"Y"u with %u keys, key index %u", + DPRINTF(("==> cursor points to page %"Yu" with %u keys, key index %u", mdb_dbg_pgno(mp), NUMKEYS(mp), mc->mc_ki[mc->mc_top])); if (IS_LEAF2(mp)) { @@ -6563,7 +6828,12 @@ mdb_cursor_prev(MDB_cursor *mc, MDB_val *key, MDB_val *data, MDB_cursor_op op) MDB_node *leaf; int rc; - mdb_cassert(mc, mc->mc_flags & C_INITIALIZED); + if (!(mc->mc_flags & C_INITIALIZED)) { + rc = mdb_cursor_last(mc, key, data); + if (rc) + return rc; + mc->mc_ki[mc->mc_top]++; + } mp = mc->mc_pg[mc->mc_top]; @@ -6580,13 +6850,9 @@ mdb_cursor_prev(MDB_cursor *mc, MDB_val *key, MDB_val *data, MDB_cursor_op op) return rc; } } -#ifdef MDB_VL32 else { - if (mc->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED) { - mdb_cursor_unref(&mc->mc_xcursor->mx_cursor); - } + MDB_CURSOR_UNREF(&mc->mc_xcursor->mx_cursor, 0); } -#endif } else { mc->mc_xcursor->mx_cursor.mc_flags &= ~(C_INITIALIZED|C_EOF); if (op == MDB_PREV_DUP) @@ -6594,7 +6860,7 @@ mdb_cursor_prev(MDB_cursor *mc, MDB_val *key, MDB_val *data, MDB_cursor_op op) } } - DPRINTF(("cursor_prev: top page is %"Y"u in cursor %p", + DPRINTF(("cursor_prev: top page is %"Yu" in cursor %p", mdb_dbg_pgno(mp), (void *) mc)); mc->mc_flags &= ~(C_EOF|C_DEL); @@ -6606,13 +6872,11 @@ mdb_cursor_prev(MDB_cursor *mc, MDB_val *key, MDB_val *data, MDB_cursor_op op) } mp = mc->mc_pg[mc->mc_top]; mc->mc_ki[mc->mc_top] = NUMKEYS(mp) - 1; - DPRINTF(("prev page is %"Y"u, key index %u", mp->mp_pgno, mc->mc_ki[mc->mc_top])); + DPRINTF(("prev page is %"Yu", key index %u", mp->mp_pgno, mc->mc_ki[mc->mc_top])); } else mc->mc_ki[mc->mc_top]--; - mc->mc_flags &= ~C_EOF; - - DPRINTF(("==> cursor points to page %"Y"u with %u keys, key index %u", + DPRINTF(("==> cursor points to page %"Yu" with %u keys, key index %u", mdb_dbg_pgno(mp), NUMKEYS(mp), mc->mc_ki[mc->mc_top])); if (IS_LEAF2(mp)) { @@ -6656,11 +6920,7 @@ mdb_cursor_set(MDB_cursor *mc, MDB_val *key, MDB_val *data, return MDB_BAD_VALSIZE; if (mc->mc_xcursor) { -#ifdef MDB_VL32 - if (mc->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED) { - mdb_cursor_unref(&mc->mc_xcursor->mx_cursor); - } -#endif + MDB_CURSOR_UNREF(&mc->mc_xcursor->mx_cursor, 0); mc->mc_xcursor->mx_cursor.mc_flags &= ~(C_INITIALIZED|C_EOF); } @@ -6728,6 +6988,7 @@ mdb_cursor_set(MDB_cursor *mc, MDB_val *key, MDB_val *data, } } rc = 0; + mc->mc_flags &= ~C_EOF; goto set2; } } @@ -6819,10 +7080,8 @@ set1: if ((rc = mdb_node_read(mc, leaf, &olddata)) != MDB_SUCCESS) return rc; dcmp = mc->mc_dbx->md_dcmp; -#if UINT_MAX < SIZE_MAX || defined(MDB_VL32) - if (dcmp == mdb_cmp_int && olddata.mv_size == sizeof(mdb_size_t)) + if (NEED_CMP_CLONG(dcmp, olddata.mv_size)) dcmp = mdb_cmp_clong; -#endif rc = dcmp(data, &olddata); if (rc) { if (op == MDB_GET_BOTH || rc > 0) @@ -6855,11 +7114,7 @@ mdb_cursor_first(MDB_cursor *mc, MDB_val *key, MDB_val *data) MDB_node *leaf; if (mc->mc_xcursor) { -#ifdef MDB_VL32 - if (mc->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED) { - mdb_cursor_unref(&mc->mc_xcursor->mx_cursor); - } -#endif + MDB_CURSOR_UNREF(&mc->mc_xcursor->mx_cursor, 0); mc->mc_xcursor->mx_cursor.mc_flags &= ~(C_INITIALIZED|C_EOF); } @@ -6905,24 +7160,17 @@ mdb_cursor_last(MDB_cursor *mc, MDB_val *key, MDB_val *data) MDB_node *leaf; if (mc->mc_xcursor) { -#ifdef MDB_VL32 - if (mc->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED) { - mdb_cursor_unref(&mc->mc_xcursor->mx_cursor); - } -#endif + MDB_CURSOR_UNREF(&mc->mc_xcursor->mx_cursor, 0); mc->mc_xcursor->mx_cursor.mc_flags &= ~(C_INITIALIZED|C_EOF); } - if (!(mc->mc_flags & C_EOF)) { - - if (!(mc->mc_flags & C_INITIALIZED) || mc->mc_top) { - rc = mdb_page_search(mc, NULL, MDB_PS_LAST); - if (rc != MDB_SUCCESS) - return rc; - } - mdb_cassert(mc, IS_LEAF(mc->mc_pg[mc->mc_top])); - + if (!(mc->mc_flags & C_INITIALIZED) || mc->mc_top) { + rc = mdb_page_search(mc, NULL, MDB_PS_LAST); + if (rc != MDB_SUCCESS) + return rc; } + mdb_cassert(mc, IS_LEAF(mc->mc_pg[mc->mc_top])); + mc->mc_ki[mc->mc_top] = NUMKEYS(mc->mc_pg[mc->mc_top]) - 1; mc->mc_flags |= C_INITIALIZED|C_EOF; leaf = NODEPTR(mc->mc_pg[mc->mc_top], mc->mc_ki[mc->mc_top]); @@ -7036,10 +7284,7 @@ mdb_cursor_get(MDB_cursor *mc, MDB_val *key, MDB_val *data, rc = MDB_INCOMPATIBLE; break; } - if (!(mc->mc_flags & C_INITIALIZED)) - rc = mdb_cursor_first(mc, key, data); - else - rc = mdb_cursor_next(mc, key, data, MDB_NEXT_DUP); + rc = mdb_cursor_next(mc, key, data, MDB_NEXT_DUP); if (rc == MDB_SUCCESS) { if (mc->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED) { MDB_cursor *mx; @@ -7081,21 +7326,11 @@ fetchm: case MDB_NEXT: case MDB_NEXT_DUP: case MDB_NEXT_NODUP: - if (!(mc->mc_flags & C_INITIALIZED)) - rc = mdb_cursor_first(mc, key, data); - else - rc = mdb_cursor_next(mc, key, data, op); + rc = mdb_cursor_next(mc, key, data, op); break; case MDB_PREV: case MDB_PREV_DUP: case MDB_PREV_NODUP: - if (!(mc->mc_flags & C_INITIALIZED)) { - rc = mdb_cursor_last(mc, key, data); - if (rc) - break; - mc->mc_flags |= C_INITIALIZED; - mc->mc_ki[mc->mc_top]++; - } rc = mdb_cursor_prev(mc, key, data, op); break; case MDB_FIRST: @@ -7112,6 +7347,11 @@ fetchm: rc = MDB_INCOMPATIBLE; break; } + if (mc->mc_ki[mc->mc_top] >= NUMKEYS(mc->mc_pg[mc->mc_top])) { + mc->mc_ki[mc->mc_top] = NUMKEYS(mc->mc_pg[mc->mc_top]); + rc = MDB_NOTFOUND; + break; + } { MDB_node *leaf = NODEPTR(mc->mc_pg[mc->mc_top], mc->mc_ki[mc->mc_top]); if (!F_ISSET(leaf->mn_flags, F_DUPDATA)) { @@ -7153,7 +7393,8 @@ mdb_cursor_touch(MDB_cursor *mc) { int rc = MDB_SUCCESS; - if (mc->mc_dbi >= CORE_DBS && !(*mc->mc_dbflag & DB_DIRTY)) { + if (mc->mc_dbi >= CORE_DBS && !(*mc->mc_dbflag & (DB_DIRTY|DB_DUPDATA))) { + /* Touch DB record of named DB */ MDB_cursor mc2; MDB_xcursor mcx; if (TXN_DBI_CHANGED(mc->mc_txn, mc->mc_dbi)) @@ -7378,10 +7619,8 @@ more: if (flags == MDB_CURRENT) goto current; dcmp = mc->mc_dbx->md_dcmp; -#if UINT_MAX < SIZE_MAX || defined(MDB_VL32) - if (dcmp == mdb_cmp_int && olddata.mv_size == sizeof(mdb_size_t)) + if (NEED_CMP_CLONG(dcmp, olddata.mv_size)) dcmp = mdb_cmp_clong; -#endif /* does data match? */ if (!dcmp(data, &olddata)) { if (flags & (MDB_NODUPDATA|MDB_APPENDDUP)) @@ -7477,8 +7716,9 @@ prep_subDB: } else { memcpy((char *)mp + mp->mp_upper + PAGEBASE, (char *)fp + fp->mp_upper + PAGEBASE, olddata.mv_size - fp->mp_upper - PAGEBASE); + memcpy((char *)(&mp->mp_ptrs), (char *)(&fp->mp_ptrs), NUMKEYS(fp) * sizeof(mp->mp_ptrs[0])); for (i=0; imp_ptrs[i] = fp->mp_ptrs[i] + offset; + mp->mp_ptrs[i] += offset; } } @@ -7532,8 +7772,13 @@ current: /* Note - this page is already counted in parent's dirty_room */ rc2 = mdb_mid2l_insert(mc->mc_txn->mt_u.dirty_list, &id2); mdb_cassert(mc, rc2 == 0); + /* Currently we make the page look as with put() in the + * parent txn, in case the user peeks at MDB_RESERVEd + * or unused parts. Some users treat ovpages specially. + */ if (!(flags & MDB_RESERVE)) { - /* Copy end of page, adjusting alignment so + /* Skip the part where LMDB will put *data. + * Copy end of page, adjusting alignment so * compiler may copy words instead of bytes. */ off = (PAGEHDRSZ + data->mv_size) & -sizeof(size_t); @@ -7602,11 +7847,7 @@ new_sub: if (m3->mc_ki[i] >= mc->mc_ki[i] && insert_key) { m3->mc_ki[i]++; } - if (m3->mc_xcursor && (m3->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED)) { - MDB_node *n2 = NODEPTR(mp, m3->mc_ki[i]); - if ((n2->mn_flags & (F_SUBDATA|F_DUPDATA)) == F_DUPDATA) - m3->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(n2); - } + XCURSOR_REFRESH(m3, i, mp); } } } @@ -7648,7 +7889,6 @@ put_sub: MDB_xcursor *mx = mc->mc_xcursor; unsigned i = mc->mc_top; MDB_page *mp = mc->mc_pg[i]; - int nkeys = NUMKEYS(mp); for (m2 = mc->mc_txn->mt_cursors[mc->mc_dbi]; m2; m2=m2->mc_next) { if (m2 == mc || m2->mc_snum < mc->mc_snum) continue; @@ -7656,10 +7896,8 @@ put_sub: if (m2->mc_pg[i] == mp) { if (m2->mc_ki[i] == mc->mc_ki[i]) { mdb_xcursor_init2(m2, mx, new_dupdata); - } else if (!insert_key && m2->mc_ki[i] < nkeys) { - MDB_node *n2 = NODEPTR(mp, m2->mc_ki[i]); - if ((n2->mn_flags & (F_SUBDATA|F_DUPDATA)) == F_DUPDATA) - m2->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(n2); + } else if (!insert_key) { + XCURSOR_REFRESH(m2, i, mp); } } } @@ -7701,7 +7939,7 @@ put_sub: return rc; bad_sub: if (rc == MDB_KEYEXIST) /* should not happen, we deleted that item */ - rc = MDB_CORRUPTED; + rc = MDB_PROBLEM; } mc->mc_txn->mt_flags |= MDB_TXN_ERROR; return rc; @@ -7764,13 +8002,7 @@ mdb_cursor_del(MDB_cursor *mc, unsigned int flags) if (m2 == mc || m2->mc_snum < mc->mc_snum) continue; if (!(m2->mc_flags & C_INITIALIZED)) continue; if (m2->mc_pg[mc->mc_top] == mp) { - if (m2->mc_ki[mc->mc_top] == mc->mc_ki[mc->mc_top]) { - m2->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(leaf); - } else { - MDB_node *n2 = NODEPTR(mp, m2->mc_ki[mc->mc_top]); - if (!(n2->mn_flags & F_SUBDATA)) - m2->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(n2); - } + XCURSOR_REFRESH(m2, mc->mc_top, mp); } } } @@ -7815,6 +8047,7 @@ fail: } /** Allocate and initialize new pages for a database. + * Set #MDB_TXN_ERROR on failure. * @param[in] mc a cursor on the database being added to. * @param[in] flags flags defining what type of page is being allocated. * @param[in] num the number of pages to allocate. This is usually 1, @@ -7830,7 +8063,7 @@ mdb_page_new(MDB_cursor *mc, uint32_t flags, int num, MDB_page **mp) if ((rc = mdb_page_alloc(mc, num, &np))) return rc; - DPRINTF(("allocated new mpage %"Y"u, page size %u", + DPRINTF(("allocated new mpage %"Yu", page size %u", np->mp_pgno, mc->mc_txn->mt_env->me_psize)); np->mp_flags = flags | P_DIRTY; np->mp_lower = (PAGEHDRSZ-PAGEBASE); @@ -7900,6 +8133,7 @@ mdb_branch_size(MDB_env *env, MDB_val *key) } /** Add a node to the page pointed to by the cursor. + * Set #MDB_TXN_ERROR on failure. * @param[in] mc The cursor for this operation. * @param[in] indx The index on the page where the new node should be added. * @param[in] key The key for the new node. @@ -7930,7 +8164,7 @@ mdb_node_add(MDB_cursor *mc, indx_t indx, mdb_cassert(mc, mp->mp_upper >= mp->mp_lower); - DPRINTF(("add to %s %spage %"Y"u index %i, data size %"Z"u key size %"Z"u [%s]", + DPRINTF(("add to %s %spage %"Yu" index %i, data size %"Z"u key size %"Z"u [%s]", IS_LEAF(mp) ? "leaf" : "branch", IS_SUBP(mp) ? "sub-" : "", mdb_dbg_pgno(mp), indx, data ? data->mv_size : 0, @@ -7971,7 +8205,7 @@ mdb_node_add(MDB_cursor *mc, indx_t indx, goto full; if ((rc = mdb_page_new(mc, P_OVERFLOW, ovpages, &ofp))) return rc; - DPRINTF(("allocated overflow page %"Y"u", ofp->mp_pgno)); + DPRINTF(("allocated overflow page %"Yu, ofp->mp_pgno)); flags |= F_BIGDATA; goto update; } else { @@ -8028,7 +8262,7 @@ update: return MDB_SUCCESS; full: - DPRINTF(("not enough room in page %"Y"u, got %u ptrs", + DPRINTF(("not enough room in page %"Yu", got %u ptrs", mdb_dbg_pgno(mp), NUMKEYS(mp))); DPRINTF(("upper-lower = %u - %u = %"Z"d", mp->mp_upper,mp->mp_lower,room)); DPRINTF(("node size = %"Z"u", node_size)); @@ -8051,7 +8285,7 @@ mdb_node_del(MDB_cursor *mc, int ksize) MDB_node *node; char *base; - DPRINTF(("delete node %u on %s page %"Y"u", indx, + DPRINTF(("delete node %u on %s page %"Yu, indx, IS_LEAF(mp) ? "leaf" : "branch", mdb_dbg_pgno(mp))); numkeys = NUMKEYS(mp); mdb_cassert(mc, indx < numkeys); @@ -8160,9 +8394,7 @@ mdb_xcursor_init0(MDB_cursor *mc) mx->mx_cursor.mc_dbflag = &mx->mx_dbflag; mx->mx_cursor.mc_snum = 0; mx->mx_cursor.mc_top = 0; -#ifdef MDB_VL32 - mx->mx_cursor.mc_ovpg = 0; -#endif + MC_SET_OVPG(&mx->mx_cursor, NULL); mx->mx_cursor.mc_flags = C_SUB | (mc->mc_flags & (C_ORIG_RDONLY|C_WRITEMAP)); mx->mx_dbx.md_name.mv_size = 0; mx->mx_dbx.md_name.mv_data = NULL; @@ -8210,13 +8442,11 @@ mdb_xcursor_init1(MDB_cursor *mc, MDB_node *node) mx->mx_db.md_flags |= MDB_INTEGERKEY; } } - DPRINTF(("Sub-db -%u root page %"Y"u", mx->mx_cursor.mc_dbi, + DPRINTF(("Sub-db -%u root page %"Yu, mx->mx_cursor.mc_dbi, mx->mx_db.md_root)); - mx->mx_dbflag = DB_VALID|DB_USRVALID|DB_DIRTY; /* DB_DIRTY guides mdb_cursor_touch */ -#if UINT_MAX < SIZE_MAX || defined(MDB_VL32) - if (mx->mx_dbx.md_cmp == mdb_cmp_int && mx->mx_db.md_pad == sizeof(mdb_size_t)) + mx->mx_dbflag = DB_VALID|DB_USRVALID|DB_DUPDATA; + if (NEED_CMP_CLONG(mx->mx_dbx.md_cmp, mx->mx_db.md_pad)) mx->mx_dbx.md_cmp = mdb_cmp_clong; -#endif } @@ -8238,8 +8468,8 @@ mdb_xcursor_init2(MDB_cursor *mc, MDB_xcursor *src_mx, int new_dupdata) mx->mx_cursor.mc_top = 0; mx->mx_cursor.mc_flags |= C_INITIALIZED; mx->mx_cursor.mc_ki[0] = 0; - mx->mx_dbflag = DB_VALID|DB_USRVALID|DB_DIRTY; /* DB_DIRTY guides mdb_cursor_touch */ -#if UINT_MAX < SIZE_MAX + mx->mx_dbflag = DB_VALID|DB_USRVALID|DB_DUPDATA; +#if UINT_MAX < MDB_SIZE_MAX /* matches mdb_xcursor_init1:NEED_CMP_CLONG() */ mx->mx_dbx.md_cmp = src_mx->mx_dbx.md_cmp; #endif } else if (!(mx->mx_cursor.mc_flags & C_INITIALIZED)) { @@ -8247,7 +8477,7 @@ mdb_xcursor_init2(MDB_cursor *mc, MDB_xcursor *src_mx, int new_dupdata) } mx->mx_db = src_mx->mx_db; mx->mx_cursor.mc_pg[0] = src_mx->mx_cursor.mc_pg[0]; - DPRINTF(("Sub-db -%u root page %"Y"u", mx->mx_cursor.mc_dbi, + DPRINTF(("Sub-db -%u root page %"Yu, mx->mx_cursor.mc_dbi, mx->mx_db.md_root)); } @@ -8266,9 +8496,7 @@ mdb_cursor_init(MDB_cursor *mc, MDB_txn *txn, MDB_dbi dbi, MDB_xcursor *mx) mc->mc_top = 0; mc->mc_pg[0] = 0; mc->mc_ki[0] = 0; -#ifdef MDB_VL32 - mc->mc_ovpg = 0; -#endif + MC_SET_OVPG(mc, NULL); mc->mc_flags = txn->mt_flags & (C_ORIG_RDONLY|C_WRITEMAP); if (txn->mt_dbs[dbi].md_flags & MDB_DUPSORT) { mdb_tassert(txn, mx != NULL); @@ -8350,9 +8578,15 @@ mdb_cursor_count(MDB_cursor *mc, mdb_size_t *countp) if (!(mc->mc_flags & C_INITIALIZED)) return EINVAL; - if (!mc->mc_snum || (mc->mc_flags & C_EOF)) + if (!mc->mc_snum) return MDB_NOTFOUND; + if (mc->mc_flags & C_EOF) { + if (mc->mc_ki[mc->mc_top] >= NUMKEYS(mc->mc_pg[mc->mc_top])) + return MDB_NOTFOUND; + mc->mc_flags ^= C_EOF; + } + leaf = NODEPTR(mc->mc_pg[mc->mc_top], mc->mc_ki[mc->mc_top]); if (!F_ISSET(leaf->mn_flags, F_DUPDATA)) { *countp = 1; @@ -8368,13 +8602,14 @@ mdb_cursor_count(MDB_cursor *mc, mdb_size_t *countp) void mdb_cursor_close(MDB_cursor *mc) { -#ifdef MDB_VL32 if (mc) { - mdb_cursor_unref(mc); + MDB_CURSOR_UNREF(mc, 0); } -#endif if (mc && !mc->mc_backup) { - /* remove from txn, if tracked */ + /* Remove from txn, if tracked. + * A read-only txn (!C_UNTRACK) may have been freed already, + * so do not peek inside it. Only write txns track cursors. + */ if ((mc->mc_flags & C_UNTRACK) && mc->mc_txn->mt_cursors) { MDB_cursor **prev = &mc->mc_txn->mt_cursors[mc->mc_dbi]; while (*prev && *prev != mc) prev = &(*prev)->mc_next; @@ -8399,6 +8634,7 @@ mdb_cursor_dbi(MDB_cursor *mc) } /** Replace the key for a branch node with a new key. + * Set #MDB_TXN_ERROR on failure. * @param[in] mc Cursor pointing to the node to operate on. * @param[in] key The new key to use. * @return 0 on success, non-zero on failure. @@ -8424,7 +8660,7 @@ mdb_update_key(MDB_cursor *mc, MDB_val *key) char kbuf2[DKBUF_MAXKEYSIZE*2+1]; k2.mv_data = NODEKEY(node); k2.mv_size = node->mn_ksize; - DPRINTF(("update key %u (ofs %u) [%s] to [%s] on page %"Y"u", + DPRINTF(("update key %u (ofs %u) [%s] to [%s] on page %"Yu, indx, ptr, mdb_dkey(&k2, kbuf2), DKEY(key), @@ -8572,7 +8808,7 @@ mdb_node_move(MDB_cursor *csrc, MDB_cursor *cdst, int fromleft) return rc; } - DPRINTF(("moving %s node %u [%s] on page %"Y"u to node %u on page %"Y"u", + DPRINTF(("moving %s node %u [%s] on page %"Yu" to node %u on page %"Yu, IS_LEAF(csrc->mc_pg[csrc->mc_top]) ? "leaf" : "branch", csrc->mc_ki[csrc->mc_top], DKEY(&key), @@ -8618,12 +8854,8 @@ mdb_node_move(MDB_cursor *csrc, MDB_cursor *cdst, int fromleft) m3->mc_ki[csrc->mc_top] = cdst->mc_ki[cdst->mc_top]; m3->mc_ki[csrc->mc_top-1]++; } - if (m3->mc_xcursor && (m3->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED) && - IS_LEAF(mps)) { - MDB_node *node = NODEPTR(m3->mc_pg[csrc->mc_top], m3->mc_ki[csrc->mc_top]); - if ((node->mn_flags & (F_DUPDATA|F_SUBDATA)) == F_DUPDATA) - m3->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(node); - } + if (IS_LEAF(mps)) + XCURSOR_REFRESH(m3, csrc->mc_top, m3->mc_pg[csrc->mc_top]); } } else /* Adding on the right, bump others down */ @@ -8644,12 +8876,8 @@ mdb_node_move(MDB_cursor *csrc, MDB_cursor *cdst, int fromleft) } else { m3->mc_ki[csrc->mc_top]--; } - if (m3->mc_xcursor && (m3->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED) && - IS_LEAF(mps)) { - MDB_node *node = NODEPTR(m3->mc_pg[csrc->mc_top], m3->mc_ki[csrc->mc_top]); - if ((node->mn_flags & (F_DUPDATA|F_SUBDATA)) == F_DUPDATA) - m3->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(node); - } + if (IS_LEAF(mps)) + XCURSOR_REFRESH(m3, csrc->mc_top, m3->mc_pg[csrc->mc_top]); } } } @@ -8666,7 +8894,7 @@ mdb_node_move(MDB_cursor *csrc, MDB_cursor *cdst, int fromleft) key.mv_size = NODEKSZ(srcnode); key.mv_data = NODEKEY(srcnode); } - DPRINTF(("update separator for source page %"Y"u to [%s]", + DPRINTF(("update separator for source page %"Yu" to [%s]", csrc->mc_pg[csrc->mc_top]->mp_pgno, DKEY(&key))); mdb_cursor_copy(csrc, &mn); mn.mc_snum--; @@ -8697,7 +8925,7 @@ mdb_node_move(MDB_cursor *csrc, MDB_cursor *cdst, int fromleft) key.mv_size = NODEKSZ(srcnode); key.mv_data = NODEKEY(srcnode); } - DPRINTF(("update separator for destination page %"Y"u to [%s]", + DPRINTF(("update separator for destination page %"Yu" to [%s]", cdst->mc_pg[cdst->mc_top]->mp_pgno, DKEY(&key))); mdb_cursor_copy(cdst, &mn); mn.mc_snum--; @@ -8743,7 +8971,7 @@ mdb_page_merge(MDB_cursor *csrc, MDB_cursor *cdst) psrc = csrc->mc_pg[csrc->mc_top]; pdst = cdst->mc_pg[cdst->mc_top]; - DPRINTF(("merging page %"Y"u into %"Y"u", psrc->mp_pgno, pdst->mp_pgno)); + DPRINTF(("merging page %"Yu" into %"Yu, psrc->mp_pgno, pdst->mp_pgno)); mdb_cassert(csrc, csrc->mc_snum > 1); /* can't merge root page */ mdb_cassert(csrc, cdst->mc_snum > 1); @@ -8800,7 +9028,7 @@ mdb_page_merge(MDB_cursor *csrc, MDB_cursor *cdst) } } - DPRINTF(("dst page %"Y"u now has %u keys (%.1f%% filled)", + DPRINTF(("dst page %"Yu" now has %u keys (%.1f%% filled)", pdst->mp_pgno, NUMKEYS(pdst), (float)PAGEFILL(cdst->mc_txn->mt_env, pdst) / 10)); @@ -8850,12 +9078,8 @@ mdb_page_merge(MDB_cursor *csrc, MDB_cursor *cdst) m3->mc_ki[top-1] > csrc->mc_ki[top-1]) { m3->mc_ki[top-1]--; } - if (m3->mc_xcursor && (m3->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED) && - IS_LEAF(psrc)) { - MDB_node *node = NODEPTR(m3->mc_pg[top], m3->mc_ki[top]); - if ((node->mn_flags & (F_DUPDATA|F_SUBDATA)) == F_DUPDATA) - m3->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(node); - } + if (IS_LEAF(psrc)) + XCURSOR_REFRESH(m3, top, m3->mc_pg[top]); } } { @@ -8888,9 +9112,7 @@ mdb_cursor_copy(const MDB_cursor *csrc, MDB_cursor *cdst) cdst->mc_snum = csrc->mc_snum; cdst->mc_top = csrc->mc_top; cdst->mc_flags = csrc->mc_flags; -#ifdef MDB_VL32 - cdst->mc_ovpg = csrc->mc_ovpg; -#endif + MC_SET_OVPG(cdst, MC_OVPG(csrc)); for (i=0; imc_snum; i++) { cdst->mc_pg[i] = csrc->mc_pg[i]; @@ -8919,14 +9141,14 @@ mdb_rebalance(MDB_cursor *mc) minkeys = 1; thresh = FILL_THRESHOLD; } - DPRINTF(("rebalancing %s page %"Y"u (has %u keys, %.1f%% full)", + DPRINTF(("rebalancing %s page %"Yu" (has %u keys, %.1f%% full)", IS_LEAF(mc->mc_pg[mc->mc_top]) ? "leaf" : "branch", mdb_dbg_pgno(mc->mc_pg[mc->mc_top]), NUMKEYS(mc->mc_pg[mc->mc_top]), (float)PAGEFILL(mc->mc_txn->mt_env, mc->mc_pg[mc->mc_top]) / 10)); if (PAGEFILL(mc->mc_txn->mt_env, mc->mc_pg[mc->mc_top]) >= thresh && NUMKEYS(mc->mc_pg[mc->mc_top]) >= minkeys) { - DPRINTF(("no need to rebalance page %"Y"u, above fill threshold", + DPRINTF(("no need to rebalance page %"Yu", above fill threshold", mdb_dbg_pgno(mc->mc_pg[mc->mc_top]))); return MDB_SUCCESS; } @@ -9055,7 +9277,7 @@ mdb_rebalance(MDB_cursor *mc) fromleft = 1; } - DPRINTF(("found neighbor page %"Y"u (%u keys, %.1f%% full)", + DPRINTF(("found neighbor page %"Yu" (%u keys, %.1f%% full)", mn.mc_pg[mn.mc_top]->mp_pgno, NUMKEYS(mn.mc_pg[mn.mc_top]), (float)PAGEFILL(mc->mc_txn->mt_env, mn.mc_pg[mn.mc_top]) / 10)); @@ -9112,16 +9334,15 @@ mdb_cursor_del0(MDB_cursor *mc) if (m3->mc_pg[mc->mc_top] == mp) { if (m3->mc_ki[mc->mc_top] == ki) { m3->mc_flags |= C_DEL; - if (mc->mc_db->md_flags & MDB_DUPSORT) - m3->mc_xcursor->mx_cursor.mc_flags &= ~C_INITIALIZED; + if (mc->mc_db->md_flags & MDB_DUPSORT) { + /* Sub-cursor referred into dataset which is gone */ + m3->mc_xcursor->mx_cursor.mc_flags &= ~(C_INITIALIZED|C_EOF); + } + continue; } else if (m3->mc_ki[mc->mc_top] > ki) { m3->mc_ki[mc->mc_top]--; } - if (m3->mc_xcursor && (m3->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED)) { - MDB_node *node = NODEPTR(m3->mc_pg[mc->mc_top], m3->mc_ki[mc->mc_top]); - if ((node->mn_flags & (F_DUPDATA|F_SUBDATA)) == F_DUPDATA) - m3->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(node); - } + XCURSOR_REFRESH(m3, mc->mc_top, mp); } } } @@ -9147,11 +9368,32 @@ mdb_cursor_del0(MDB_cursor *mc) continue; if (m3->mc_pg[mc->mc_top] == mp) { /* if m3 points past last node in page, find next sibling */ - if (m3->mc_ki[mc->mc_top] >= nkeys) { - rc = mdb_cursor_sibling(m3, 1); - if (rc == MDB_NOTFOUND) { - m3->mc_flags |= C_EOF; - rc = MDB_SUCCESS; + if (m3->mc_ki[mc->mc_top] >= mc->mc_ki[mc->mc_top]) { + if (m3->mc_ki[mc->mc_top] >= nkeys) { + rc = mdb_cursor_sibling(m3, 1); + if (rc == MDB_NOTFOUND) { + m3->mc_flags |= C_EOF; + rc = MDB_SUCCESS; + continue; + } + } + if (mc->mc_db->md_flags & MDB_DUPSORT) { + MDB_node *node = NODEPTR(m3->mc_pg[m3->mc_top], m3->mc_ki[m3->mc_top]); + /* If this node has dupdata, it may need to be reinited + * because its data has moved. + * If the xcursor was not initd it must be reinited. + * Else if node points to a subDB, nothing is needed. + * Else (xcursor was initd, not a subDB) needs mc_pg[0] reset. + */ + if (node->mn_flags & F_DUPDATA) { + if (m3->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED) { + if (!(node->mn_flags & F_SUBDATA)) + m3->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(node); + } else { + mdb_xcursor_init1(m3, node); + m3->mc_xcursor->mx_cursor.mc_flags |= C_DEL; + } + } } } } @@ -9216,7 +9458,6 @@ mdb_del0(MDB_txn *txn, MDB_dbi dbi, * run out of space, triggering a split. We need this * cursor to be consistent until the end of the rebalance. */ - mc.mc_flags |= C_UNTRACK; mc.mc_next = txn->mt_cursors[dbi]; txn->mt_cursors[dbi] = &mc; rc = mdb_cursor_del(&mc, flags); @@ -9226,6 +9467,7 @@ mdb_del0(MDB_txn *txn, MDB_dbi dbi, } /** Split a page and insert a new node. + * Set #MDB_TXN_ERROR on failure. * @param[in,out] mc Cursor pointing to the page and desired insertion index. * The cursor will be updated to point to the actual page and index where * the node got inserted after the split. @@ -9257,7 +9499,7 @@ mdb_page_split(MDB_cursor *mc, MDB_val *newkey, MDB_val *newdata, pgno_t newpgno newindx = mc->mc_ki[mc->mc_top]; nkeys = NUMKEYS(mp); - DPRINTF(("-----> splitting %s page %"Y"u and adding [%s] at index %i/%i", + DPRINTF(("-----> splitting %s page %"Yu" and adding [%s] at index %i/%i", IS_LEAF(mp) ? "leaf" : "branch", mp->mp_pgno, DKEY(newkey), mc->mc_ki[mc->mc_top], nkeys)); @@ -9265,7 +9507,7 @@ mdb_page_split(MDB_cursor *mc, MDB_val *newkey, MDB_val *newdata, pgno_t newpgno if ((rc = mdb_page_new(mc, mp->mp_flags, 1, &rp))) return rc; rp->mp_pad = mp->mp_pad; - DPRINTF(("new right sibling: page %"Y"u", rp->mp_pgno)); + DPRINTF(("new right sibling: page %"Yu, rp->mp_pgno)); /* Usually when splitting the root page, the cursor * height is 1. But when called from mdb_update_key, @@ -9283,7 +9525,7 @@ mdb_page_split(MDB_cursor *mc, MDB_val *newkey, MDB_val *newdata, pgno_t newpgno mc->mc_pg[0] = pp; mc->mc_ki[0] = 0; mc->mc_db->md_root = pp->mp_pgno; - DPRINTF(("root split! new root = %"Y"u", pp->mp_pgno)); + DPRINTF(("root split! new root = %"Yu, pp->mp_pgno)); new_root = mc->mc_db->md_depth++; /* Add left (implicit) pointer. */ @@ -9300,7 +9542,7 @@ mdb_page_split(MDB_cursor *mc, MDB_val *newkey, MDB_val *newdata, pgno_t newpgno ptop = 0; } else { ptop = mc->mc_top-1; - DPRINTF(("parent branch page is %"Y"u", mc->mc_pg[ptop]->mp_pgno)); + DPRINTF(("parent branch page is %"Yu, mc->mc_pg[ptop]->mp_pgno)); } mdb_cursor_copy(mc, &mn); @@ -9475,7 +9717,7 @@ mdb_page_split(MDB_cursor *mc, MDB_val *newkey, MDB_val *newdata, pgno_t newpgno } else { /* find right page's left sibling */ mc->mc_ki[ptop] = mn.mc_ki[ptop]; - mdb_cursor_sibling(mc, 0); + rc = mdb_cursor_sibling(mc, 0); } } } else { @@ -9484,6 +9726,8 @@ mdb_page_split(MDB_cursor *mc, MDB_val *newkey, MDB_val *newdata, pgno_t newpgno mn.mc_top++; } if (rc != MDB_SUCCESS) { + if (rc == MDB_NOTFOUND) /* improper mdb_cursor_sibling() result */ + rc = MDB_PROBLEM; goto done; } if (nflags & MDB_APPEND) { @@ -9635,12 +9879,8 @@ mdb_page_split(MDB_cursor *mc, MDB_val *newkey, MDB_val *newdata, pgno_t newpgno m3->mc_ki[ptop] >= mc->mc_ki[ptop]) { m3->mc_ki[ptop]++; } - if (m3->mc_xcursor && (m3->mc_xcursor->mx_cursor.mc_flags & C_INITIALIZED) && - IS_LEAF(mp)) { - MDB_node *node = NODEPTR(m3->mc_pg[mc->mc_top], m3->mc_ki[mc->mc_top]); - if ((node->mn_flags & (F_DUPDATA|F_SUBDATA)) == F_DUPDATA) - m3->mc_xcursor->mx_cursor.mc_pg[0] = NODEDATA(node); - } + if (IS_LEAF(mp)) + XCURSOR_REFRESH(m3, mc->mc_top, m3->mc_pg[mc->mc_top]); } } DPRINTF(("mp left: %d, rp left: %d", SIZELEFT(mp), SIZELEFT(rp))); @@ -9681,23 +9921,26 @@ mdb_put(MDB_txn *txn, MDB_dbi dbi, #ifndef MDB_WBUF #define MDB_WBUF (1024*1024) #endif +#define MDB_EOF 0x10 /**< #mdb_env_copyfd1() is done reading */ - /** State needed for a compacting copy. */ + /** State needed for a double-buffering compacting copy. */ typedef struct mdb_copy { - pthread_mutex_t mc_mutex; - pthread_cond_t mc_cond; - char *mc_wbuf[2]; - char *mc_over[2]; MDB_env *mc_env; MDB_txn *mc_txn; + pthread_mutex_t mc_mutex; + pthread_cond_t mc_cond; /**< Condition variable for #mc_new */ + char *mc_wbuf[2]; + char *mc_over[2]; int mc_wlen[2]; int mc_olen[2]; pgno_t mc_next_pgno; HANDLE mc_fd; - int mc_status; - volatile int mc_new; - int mc_toggle; - + int mc_toggle; /**< Buffer number in provider */ + int mc_new; /**< (0-2 buffers to write) | (#MDB_EOF at end) */ + /** Error code. Never cleared if set. Both threads can set nonzero + * to fail the copy. Not mutex-protected, LMDB expects atomic int. + */ + volatile int mc_error; } mdb_copy; /** Dedicated writer thread for compacting copy. */ @@ -9713,26 +9956,38 @@ mdb_env_copythr(void *arg) #else int len; #define DO_WRITE(rc, fd, ptr, w2, len) len = write(fd, ptr, w2); rc = (len >= 0) +#ifdef SIGPIPE + sigset_t set; + sigemptyset(&set); + sigaddset(&set, SIGPIPE); + if ((rc = pthread_sigmask(SIG_BLOCK, &set, NULL)) != 0) + my->mc_error = rc; +#endif #endif pthread_mutex_lock(&my->mc_mutex); - my->mc_new = 0; - pthread_cond_signal(&my->mc_cond); for(;;) { while (!my->mc_new) pthread_cond_wait(&my->mc_cond, &my->mc_mutex); - if (my->mc_new < 0) { - my->mc_new = 0; + if (my->mc_new == 0 + MDB_EOF) /* 0 buffers, just EOF */ break; - } - my->mc_new = 0; wsize = my->mc_wlen[toggle]; ptr = my->mc_wbuf[toggle]; again: - while (wsize > 0) { + rc = MDB_SUCCESS; + while (wsize > 0 && !my->mc_error) { DO_WRITE(rc, my->mc_fd, ptr, wsize, len); if (!rc) { rc = ErrCode(); +#if defined(SIGPIPE) && !defined(_WIN32) + if (rc == EPIPE) { + /* Collect the pending SIGPIPE, otherwise at least OS X + * gives it to the process on thread-exit (ITS#8504). + */ + int tmp; + sigwait(&set, &tmp); + } +#endif break; } else if (len > 0) { rc = MDB_SUCCESS; @@ -9745,8 +10000,7 @@ again: } } if (rc) { - my->mc_status = rc; - break; + my->mc_error = rc; } /* If there's an overflow page tail, write it too */ if (my->mc_olen[toggle]) { @@ -9757,38 +10011,45 @@ again: } my->mc_wlen[toggle] = 0; toggle ^= 1; + /* Return the empty buffer to provider */ + my->mc_new--; pthread_cond_signal(&my->mc_cond); } - pthread_cond_signal(&my->mc_cond); pthread_mutex_unlock(&my->mc_mutex); return (THREAD_RET)0; #undef DO_WRITE } - /** Tell the writer thread there's a buffer ready to write */ + /** Give buffer and/or #MDB_EOF to writer thread, await unused buffer. + * + * @param[in] my control structure. + * @param[in] adjust (1 to hand off 1 buffer) | (MDB_EOF when ending). + */ static int ESECT -mdb_env_cthr_toggle(mdb_copy *my, int st) +mdb_env_cthr_toggle(mdb_copy *my, int adjust) { - int toggle = my->mc_toggle ^ 1; pthread_mutex_lock(&my->mc_mutex); - if (my->mc_status) { - pthread_mutex_unlock(&my->mc_mutex); - return my->mc_status; - } - while (my->mc_new == 1) - pthread_cond_wait(&my->mc_cond, &my->mc_mutex); - my->mc_new = st; - my->mc_toggle = toggle; + my->mc_new += adjust; pthread_cond_signal(&my->mc_cond); + while (my->mc_new & 2) /* both buffers in use */ + pthread_cond_wait(&my->mc_cond, &my->mc_mutex); pthread_mutex_unlock(&my->mc_mutex); - return 0; + + my->mc_toggle ^= (adjust & 1); + /* Both threads reset mc_wlen, to be safe from threading errors */ + my->mc_wlen[my->mc_toggle] = 0; + return my->mc_error; } - /** Depth-first tree traversal for compacting copy. */ + /** Depth-first tree traversal for compacting copy. + * @param[in] my control structure. + * @param[in,out] pg database root. + * @param[in] flags includes #F_DUPDATA if it is a sorted-duplicate sub-DB. + */ static int ESECT mdb_env_cwalk(mdb_copy *my, pgno_t *pg, int flags) { - MDB_cursor mc; + MDB_cursor mc = {0}; MDB_node *ni; MDB_page *mo, *mp, *leaf; char *buf, *ptr; @@ -9800,8 +10061,8 @@ mdb_env_cwalk(mdb_copy *my, pgno_t *pg, int flags) return MDB_SUCCESS; mc.mc_snum = 1; - mc.mc_top = 0; mc.mc_txn = my->mc_txn; + mc.mc_flags = my->mc_txn->mt_flags & (C_ORIG_RDONLY|C_WRITEMAP); rc = mdb_page_get(&mc, *pg, &mc.mc_pg[0], NULL); if (rc) @@ -9847,6 +10108,7 @@ mdb_env_cwalk(mdb_copy *my, pgno_t *pg, int flags) } memcpy(&pg, NODEDATA(ni), sizeof(pg)); + memcpy(NODEDATA(ni), &my->mc_next_pgno, sizeof(pgno_t)); rc = mdb_page_get(&mc, pg, &omp, NULL); if (rc) goto done; @@ -9869,7 +10131,6 @@ mdb_env_cwalk(mdb_copy *my, pgno_t *pg, int flags) goto done; toggle = my->mc_toggle; } - memcpy(NODEDATA(ni), &mo->mp_pgno, sizeof(pgno_t)); } else if (ni->mn_flags & F_SUBDATA) { MDB_db db; @@ -9947,47 +10208,56 @@ mdb_env_copyfd1(MDB_env *env, HANDLE fd) { MDB_meta *mm; MDB_page *mp; - mdb_copy my; + mdb_copy my = {0}; MDB_txn *txn = NULL; pthread_t thr; - int rc; + pgno_t root, new_root; + int rc = MDB_SUCCESS; #ifdef _WIN32 - my.mc_mutex = CreateMutex(NULL, FALSE, NULL); - my.mc_cond = CreateEvent(NULL, FALSE, FALSE, NULL); + if (!(my.mc_mutex = CreateMutex(NULL, FALSE, NULL)) || + !(my.mc_cond = CreateEvent(NULL, FALSE, FALSE, NULL))) { + rc = ErrCode(); + goto done; + } my.mc_wbuf[0] = _aligned_malloc(MDB_WBUF*2, env->me_os_psize); - if (my.mc_wbuf[0] == NULL) - return errno; + if (my.mc_wbuf[0] == NULL) { + /* _aligned_malloc() sets errno, but we use Windows error codes */ + rc = ERROR_NOT_ENOUGH_MEMORY; + goto done; + } #else - pthread_mutex_init(&my.mc_mutex, NULL); - pthread_cond_init(&my.mc_cond, NULL); + if ((rc = pthread_mutex_init(&my.mc_mutex, NULL)) != 0) + return rc; + if ((rc = pthread_cond_init(&my.mc_cond, NULL)) != 0) + goto done2; #ifdef HAVE_MEMALIGN my.mc_wbuf[0] = memalign(env->me_os_psize, MDB_WBUF*2); - if (my.mc_wbuf[0] == NULL) - return errno; + if (my.mc_wbuf[0] == NULL) { + rc = errno; + goto done; + } #else - rc = posix_memalign((void **)&my.mc_wbuf[0], env->me_os_psize, MDB_WBUF*2); - if (rc) - return rc; + { + void *p; + if ((rc = posix_memalign(&p, env->me_os_psize, MDB_WBUF*2)) != 0) + goto done; + my.mc_wbuf[0] = p; + } #endif #endif memset(my.mc_wbuf[0], 0, MDB_WBUF*2); my.mc_wbuf[1] = my.mc_wbuf[0] + MDB_WBUF; - my.mc_wlen[0] = 0; - my.mc_wlen[1] = 0; - my.mc_olen[0] = 0; - my.mc_olen[1] = 0; my.mc_next_pgno = NUM_METAS; - my.mc_status = 0; - my.mc_new = 1; - my.mc_toggle = 0; my.mc_env = env; my.mc_fd = fd; - THREAD_CREATE(thr, mdb_env_copythr, &my); + rc = THREAD_CREATE(thr, mdb_env_copythr, &my); + if (rc) + goto done; rc = mdb_txn_begin(env, NULL, MDB_RDONLY, &txn); if (rc) - return rc; + goto finish; mp = (MDB_page *)my.mc_wbuf[0]; memset(mp, 0, NUM_METAS * env->me_psize); @@ -10003,57 +10273,64 @@ mdb_env_copyfd1(MDB_env *env, HANDLE fd) *(MDB_meta *)METADATA(mp) = *mm; mm = (MDB_meta *)METADATA(mp); - /* Count the number of free pages, subtract from lastpg to find - * number of active pages - */ - { + /* Set metapage 1 with current main DB */ + root = new_root = txn->mt_dbs[MAIN_DBI].md_root; + if (root != P_INVALID) { + /* Count free pages + freeDB pages. Subtract from last_pg + * to find the new last_pg, which also becomes the new root. + */ MDB_ID freecount = 0; MDB_cursor mc; MDB_val key, data; mdb_cursor_init(&mc, txn, FREE_DBI, NULL); while ((rc = mdb_cursor_get(&mc, &key, &data, MDB_NEXT)) == 0) freecount += *(MDB_ID *)data.mv_data; + if (rc != MDB_NOTFOUND) + goto finish; freecount += txn->mt_dbs[FREE_DBI].md_branch_pages + txn->mt_dbs[FREE_DBI].md_leaf_pages + txn->mt_dbs[FREE_DBI].md_overflow_pages; - /* Set metapage 1 */ - mm->mm_last_pg = txn->mt_next_pgno - freecount - 1; + new_root = txn->mt_next_pgno - 1 - freecount; + mm->mm_last_pg = new_root; mm->mm_dbs[MAIN_DBI] = txn->mt_dbs[MAIN_DBI]; - if (mm->mm_last_pg > NUM_METAS-1) { - mm->mm_dbs[MAIN_DBI].md_root = mm->mm_last_pg; - mm->mm_txnid = 1; - } else { - mm->mm_dbs[MAIN_DBI].md_root = P_INVALID; - } + mm->mm_dbs[MAIN_DBI].md_root = new_root; + } else { + /* When the DB is empty, handle it specially to + * fix any breakage like page leaks from ITS#8174. + */ + mm->mm_dbs[MAIN_DBI].md_flags = txn->mt_dbs[MAIN_DBI].md_flags; } + if (root != P_INVALID || mm->mm_dbs[MAIN_DBI].md_flags) { + mm->mm_txnid = 1; /* use metapage 1 */ + } + my.mc_wlen[0] = env->me_psize * NUM_METAS; my.mc_txn = txn; - pthread_mutex_lock(&my.mc_mutex); - while(my.mc_new) - pthread_cond_wait(&my.mc_cond, &my.mc_mutex); - pthread_mutex_unlock(&my.mc_mutex); - rc = mdb_env_cwalk(&my, &txn->mt_dbs[MAIN_DBI].md_root, 0); - if (rc == MDB_SUCCESS && my.mc_wlen[my.mc_toggle]) - rc = mdb_env_cthr_toggle(&my, 1); - mdb_env_cthr_toggle(&my, -1); - pthread_mutex_lock(&my.mc_mutex); - while(my.mc_new) - pthread_cond_wait(&my.mc_cond, &my.mc_mutex); - pthread_mutex_unlock(&my.mc_mutex); - THREAD_FINISH(thr); + rc = mdb_env_cwalk(&my, &root, 0); + if (rc == MDB_SUCCESS && root != new_root) { + rc = MDB_INCOMPATIBLE; /* page leak or corrupt DB */ + } +finish: + if (rc) + my.mc_error = rc; + mdb_env_cthr_toggle(&my, 1 | MDB_EOF); + rc = THREAD_FINISH(thr); mdb_txn_abort(txn); + +done: #ifdef _WIN32 - CloseHandle(my.mc_cond); - CloseHandle(my.mc_mutex); - _aligned_free(my.mc_wbuf[0]); + if (my.mc_wbuf[0]) _aligned_free(my.mc_wbuf[0]); + if (my.mc_cond) CloseHandle(my.mc_cond); + if (my.mc_mutex) CloseHandle(my.mc_mutex); #else - pthread_cond_destroy(&my.mc_cond); - pthread_mutex_destroy(&my.mc_mutex); free(my.mc_wbuf[0]); + pthread_cond_destroy(&my.mc_cond); +done2: + pthread_mutex_destroy(&my.mc_mutex); #endif - return rc; + return rc ? rc : my.mc_error; } /** Copy environment as-is. */ @@ -10174,67 +10451,20 @@ mdb_env_copyfd(MDB_env *env, HANDLE fd) int ESECT mdb_env_copy2(MDB_env *env, const char *path, unsigned int flags) { - int rc, len; - char *lpath; + int rc; + MDB_name fname; HANDLE newfd = INVALID_HANDLE_VALUE; -#ifdef _WIN32 - wchar_t *wpath; -#endif - if (env->me_flags & MDB_NOSUBDIR) { - lpath = (char *)path; - } else { - len = strlen(path); - len += sizeof(DATANAME); - lpath = malloc(len); - if (!lpath) - return ENOMEM; - sprintf(lpath, "%s" DATANAME, path); + rc = mdb_fname_init(path, env->me_flags | MDB_NOLOCK, &fname); + if (rc == MDB_SUCCESS) { + rc = mdb_fopen(env, &fname, MDB_O_COPY, 0666, &newfd); + mdb_fname_destroy(fname); } - - /* The destination path must exist, but the destination file must not. - * We don't want the OS to cache the writes, since the source data is - * already in the OS cache. - */ -#ifdef _WIN32 - rc = utf8_to_utf16(lpath, -1, &wpath, NULL); - if (rc) - goto leave; - newfd = CreateFileW(wpath, GENERIC_WRITE, 0, NULL, CREATE_NEW, - FILE_FLAG_NO_BUFFERING|FILE_FLAG_WRITE_THROUGH, NULL); - free(wpath); -#else - newfd = open(lpath, O_WRONLY|O_CREAT|O_EXCL, 0666); -#endif - if (newfd == INVALID_HANDLE_VALUE) { - rc = ErrCode(); - goto leave; - } - - if (env->me_psize >= env->me_os_psize) { -#ifdef O_DIRECT - /* Set O_DIRECT if the file system supports it */ - if ((rc = fcntl(newfd, F_GETFL)) != -1) - (void) fcntl(newfd, F_SETFL, rc | O_DIRECT); -#endif -#ifdef F_NOCACHE /* __APPLE__ */ - rc = fcntl(newfd, F_NOCACHE, 1); - if (rc) { - rc = ErrCode(); - goto leave; - } -#endif - } - - rc = mdb_env_copyfd2(env, newfd, flags); - -leave: - if (!(env->me_flags & MDB_NOSUBDIR)) - free(lpath); - if (newfd != INVALID_HANDLE_VALUE) + if (rc == MDB_SUCCESS) { + rc = mdb_env_copyfd2(env, newfd, flags); if (close(newfd) < 0 && rc == MDB_SUCCESS) rc = ErrCode(); - + } return rc; } @@ -10456,8 +10686,11 @@ int mdb_dbi_open(MDB_txn *txn, const char *name, unsigned int flags, MDB_dbi *db MDB_node *node = NODEPTR(mc.mc_pg[mc.mc_top], mc.mc_ki[mc.mc_top]); if ((node->mn_flags & (F_DUPDATA|F_SUBDATA)) != F_SUBDATA) return MDB_INCOMPATIBLE; - } else if (! (rc == MDB_NOTFOUND && (flags & MDB_CREATE))) { - return rc; + } else { + if (rc != MDB_NOTFOUND || !(flags & MDB_CREATE)) + return rc; + if (F_ISSET(txn->mt_flags, MDB_TXN_RDONLY)) + return EACCES; } /* Done here so we cannot fail after creating a new DB */ @@ -10471,7 +10704,8 @@ int mdb_dbi_open(MDB_txn *txn, const char *name, unsigned int flags, MDB_dbi *db memset(&dummy, 0, sizeof(dummy)); dummy.md_root = P_INVALID; dummy.md_flags = flags & PERSISTENT_FLAGS; - rc = mdb_cursor_put(&mc, &key, &data, F_SUBDATA); + WITH_CURSOR_TRACKING(mc, + rc = mdb_cursor_put(&mc, &key, &data, F_SUBDATA)); dbflag |= DB_DIRTY; } @@ -10641,10 +10875,8 @@ pop: done: if (rc) txn->mt_flags |= MDB_TXN_ERROR; -#ifdef MDB_VL32 /* drop refcount for mx's pages */ - mdb_cursor_unref(&mx); -#endif + MDB_CURSOR_UNREF(&mx, 0); } else if (rc == MDB_NOTFOUND) { rc = MDB_SUCCESS; } @@ -10764,7 +10996,7 @@ mdb_reader_list(MDB_env *env, MDB_msg_func *func, void *ctx) if (mr[i].mr_pid) { txnid_t txnid = mr[i].mr_txnid; sprintf(buf, txnid == (txnid_t)-1 ? - "%10d %"Z"x -\n" : "%10d %"Z"x %"Y"u\n", + "%10d %"Z"x -\n" : "%10d %"Z"x %"Yu"\n", (int)mr[i].mr_pid, (size_t)mr[i].mr_tid, txnid); if (first) { first = 0; @@ -10833,7 +11065,7 @@ mdb_reader_check(MDB_env *env, int *dead) return env->me_txns ? mdb_reader_check0(env, 0, dead) : MDB_SUCCESS; } -/** As #mdb_reader_check(). rlocked = . */ +/** As #mdb_reader_check(). \b rlocked is set if caller locked #me_rmutex. */ static int ESECT mdb_reader_check0(MDB_env *env, int rlocked, int *dead) { @@ -10869,7 +11101,7 @@ mdb_reader_check0(MDB_env *env, int rlocked, int *dead) } for (; jmn_alloced = 1; + dst->mn_len = need - 1; + dst->mn_val = result; + return MDB_SUCCESS; + } } #endif /* defined(_WIN32) */ +/** @} */ diff --git a/external/db_drivers/liblmdb/mdb_copy.1 b/external/db_drivers/liblmdb/mdb_copy.1 index 401e47abd..30e4754f1 100644 --- a/external/db_drivers/liblmdb/mdb_copy.1 +++ b/external/db_drivers/liblmdb/mdb_copy.1 @@ -1,5 +1,5 @@ -.TH MDB_COPY 1 "2014/06/20" "LMDB 0.9.14" -.\" Copyright 2012-2015 Howard Chu, Symas Corp. All Rights Reserved. +.TH MDB_COPY 1 "2017/07/31" "LMDB 0.9.70" +.\" Copyright 2012-2019 Howard Chu, Symas Corp. All Rights Reserved. .\" Copying restrictions apply. See COPYRIGHT/LICENSE. .SH NAME mdb_copy \- LMDB environment copy tool @@ -38,6 +38,7 @@ Write the library version number to the standard output, and exit. Compact while copying. Only current data pages will be copied; freed or unused pages will be omitted from the copy. This option will slow down the backup process as it is more CPU-intensive. +Currently it fails if the environment has suffered a page leak. .TP .BR \-n Open LDMB environment(s) which do not use subdirectories. diff --git a/external/db_drivers/liblmdb/mdb_copy.c b/external/db_drivers/liblmdb/mdb_copy.c index 95a6e7130..23be81506 100644 --- a/external/db_drivers/liblmdb/mdb_copy.c +++ b/external/db_drivers/liblmdb/mdb_copy.c @@ -1,6 +1,6 @@ /* mdb_copy.c - memory-mapped database backup tool */ /* - * Copyright 2012-2015 Howard Chu, Symas Corp. + * Copyright 2012-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without diff --git a/external/db_drivers/liblmdb/mdb_drop.1 b/external/db_drivers/liblmdb/mdb_drop.1 index 997e29118..10666e520 100644 --- a/external/db_drivers/liblmdb/mdb_drop.1 +++ b/external/db_drivers/liblmdb/mdb_drop.1 @@ -1,5 +1,5 @@ .TH MDB_DROP 1 "2017/11/19" "LMDB 0.9.70" -.\" Copyright 2014-2017 Howard Chu, Symas Corp. All Rights Reserved. +.\" Copyright 2014-2018 Howard Chu, Symas Corp. All Rights Reserved. .\" Copying restrictions apply. See COPYRIGHT/LICENSE. .SH NAME mdb_drop \- LMDB database delete tool diff --git a/external/db_drivers/liblmdb/mdb_drop.c b/external/db_drivers/liblmdb/mdb_drop.c index 725891685..7d2af4b62 100644 --- a/external/db_drivers/liblmdb/mdb_drop.c +++ b/external/db_drivers/liblmdb/mdb_drop.c @@ -1,6 +1,6 @@ /* mdb_drop.c - memory-mapped database delete tool */ /* - * Copyright 2016-2017 Howard Chu, Symas Corp. + * Copyright 2016-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without diff --git a/external/db_drivers/liblmdb/mdb_dump.1 b/external/db_drivers/liblmdb/mdb_dump.1 index a25fb92e9..424ad9321 100644 --- a/external/db_drivers/liblmdb/mdb_dump.1 +++ b/external/db_drivers/liblmdb/mdb_dump.1 @@ -1,5 +1,5 @@ -.TH MDB_DUMP 1 "2014/06/20" "LMDB 0.9.14" -.\" Copyright 2014-2015 Howard Chu, Symas Corp. All Rights Reserved. +.TH MDB_DUMP 1 "2017/07/31" "LMDB 0.9.70" +.\" Copyright 2014-2017 Howard Chu, Symas Corp. All Rights Reserved. .\" Copying restrictions apply. See COPYRIGHT/LICENSE. .SH NAME mdb_dump \- LMDB environment export tool diff --git a/external/db_drivers/liblmdb/mdb_dump.c b/external/db_drivers/liblmdb/mdb_dump.c index 7a42bc0b6..b7737f12d 100644 --- a/external/db_drivers/liblmdb/mdb_dump.c +++ b/external/db_drivers/liblmdb/mdb_dump.c @@ -1,6 +1,6 @@ /* mdb_dump.c - memory-mapped database dump tool */ /* - * Copyright 2011-2015 Howard Chu, Symas Corp. + * Copyright 2011-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -20,20 +20,7 @@ #include #include "lmdb.h" -#ifdef _WIN32 -#define Z "I" -#else -#define Z "z" -#endif -#ifdef MDB_VL32 -#ifdef _WIN32 -#define Y "I64" -#else -#define Y "ll" -#endif -#else -#define Y Z -#endif +#define Yu MDB_PRIy(u) #define PRINT 1 static int mode; @@ -124,7 +111,7 @@ static int dumpit(MDB_txn *txn, MDB_dbi dbi, char *name) if (name) printf("database=%s\n", name); printf("type=btree\n"); - printf("mapsize=%" Y "u\n", info.me_mapsize); + printf("mapsize=%"Yu"\n", info.me_mapsize); if (info.me_mapaddr) printf("mapaddr=%p\n", info.me_mapaddr); printf("maxreaders=%u\n", info.me_maxreaders); diff --git a/external/db_drivers/liblmdb/mdb_load.1 b/external/db_drivers/liblmdb/mdb_load.1 index ede3702d9..a2f8373c5 100644 --- a/external/db_drivers/liblmdb/mdb_load.1 +++ b/external/db_drivers/liblmdb/mdb_load.1 @@ -1,5 +1,5 @@ -.TH MDB_LOAD 1 "2014/06/20" "LMDB 0.9.14" -.\" Copyright 2014-2015 Howard Chu, Symas Corp. All Rights Reserved. +.TH MDB_LOAD 1 "2015/09/30" "LMDB 0.9.17" +.\" Copyright 2014-2018 Howard Chu, Symas Corp. All Rights Reserved. .\" Copying restrictions apply. See COPYRIGHT/LICENSE. .SH NAME mdb_load \- LMDB environment import tool diff --git a/external/db_drivers/liblmdb/mdb_load.c b/external/db_drivers/liblmdb/mdb_load.c index c74ce81c9..ad911c088 100644 --- a/external/db_drivers/liblmdb/mdb_load.c +++ b/external/db_drivers/liblmdb/mdb_load.c @@ -1,6 +1,6 @@ /* mdb_load.c - memory-mapped database load tool */ /* - * Copyright 2011-2015 Howard Chu, Symas Corp. + * Copyright 2011-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -25,7 +25,7 @@ static int mode; static char *subname = NULL; -static size_t lineno; +static mdb_size_t lineno; static int version; static int flags; @@ -39,20 +39,7 @@ static MDB_envinfo info; static MDB_val kbuf, dbuf; static MDB_val k0buf; -#ifdef _WIN32 -#define Z "I" -#else -#define Z "z" -#endif -#ifdef MDB_VL32 -#ifdef _WIN32 -#define Y "I64" -#else -#define Y "ll" -#endif -#else -#define Y Z -#endif +#define Yu MDB_PRIy(u) #define STRLENOF(s) (sizeof(s)-1) @@ -84,7 +71,7 @@ static void readhdr(void) if (!strncmp(dbuf.mv_data, "VERSION=", STRLENOF("VERSION="))) { version=atoi((char *)dbuf.mv_data+STRLENOF("VERSION=")); if (version > 3) { - fprintf(stderr, "%s: line %" Z "d: unsupported VERSION %d\n", + fprintf(stderr, "%s: line %"Yu": unsupported VERSION %d\n", prog, lineno, version); exit(EXIT_FAILURE); } @@ -94,7 +81,7 @@ static void readhdr(void) if (!strncmp((char *)dbuf.mv_data+STRLENOF("FORMAT="), "print", STRLENOF("print"))) mode |= PRINT; else if (strncmp((char *)dbuf.mv_data+STRLENOF("FORMAT="), "bytevalue", STRLENOF("bytevalue"))) { - fprintf(stderr, "%s: line %" Z "d: unsupported FORMAT %s\n", + fprintf(stderr, "%s: line %"Yu": unsupported FORMAT %s\n", prog, lineno, (char *)dbuf.mv_data+STRLENOF("FORMAT=")); exit(EXIT_FAILURE); } @@ -105,7 +92,7 @@ static void readhdr(void) subname = strdup((char *)dbuf.mv_data+STRLENOF("database=")); } else if (!strncmp(dbuf.mv_data, "type=", STRLENOF("type="))) { if (strncmp((char *)dbuf.mv_data+STRLENOF("type="), "btree", STRLENOF("btree"))) { - fprintf(stderr, "%s: line %" Z "d: unsupported type %s\n", + fprintf(stderr, "%s: line %"Yu": unsupported type %s\n", prog, lineno, (char *)dbuf.mv_data+STRLENOF("type=")); exit(EXIT_FAILURE); } @@ -115,7 +102,7 @@ static void readhdr(void) if (ptr) *ptr = '\0'; i = sscanf((char *)dbuf.mv_data+STRLENOF("mapaddr="), "%p", &info.me_mapaddr); if (i != 1) { - fprintf(stderr, "%s: line %" Z "d: invalid mapaddr %s\n", + fprintf(stderr, "%s: line %"Yu": invalid mapaddr %s\n", prog, lineno, (char *)dbuf.mv_data+STRLENOF("mapaddr=")); exit(EXIT_FAILURE); } @@ -123,9 +110,10 @@ static void readhdr(void) int i; ptr = memchr(dbuf.mv_data, '\n', dbuf.mv_size); if (ptr) *ptr = '\0'; - i = sscanf((char *)dbuf.mv_data+STRLENOF("mapsize="), "%" Y "u", &info.me_mapsize); + i = sscanf((char *)dbuf.mv_data+STRLENOF("mapsize="), + "%" MDB_SCNy(u), &info.me_mapsize); if (i != 1) { - fprintf(stderr, "%s: line %" Z "d: invalid mapsize %s\n", + fprintf(stderr, "%s: line %"Yu": invalid mapsize %s\n", prog, lineno, (char *)dbuf.mv_data+STRLENOF("mapsize=")); exit(EXIT_FAILURE); } @@ -135,7 +123,7 @@ static void readhdr(void) if (ptr) *ptr = '\0'; i = sscanf((char *)dbuf.mv_data+STRLENOF("maxreaders="), "%u", &info.me_maxreaders); if (i != 1) { - fprintf(stderr, "%s: line %" Z "d: invalid maxreaders %s\n", + fprintf(stderr, "%s: line %"Yu": invalid maxreaders %s\n", prog, lineno, (char *)dbuf.mv_data+STRLENOF("maxreaders=")); exit(EXIT_FAILURE); } @@ -151,12 +139,12 @@ static void readhdr(void) if (!dbflags[i].bit) { ptr = memchr(dbuf.mv_data, '=', dbuf.mv_size); if (!ptr) { - fprintf(stderr, "%s: line %" Z "d: unexpected format\n", + fprintf(stderr, "%s: line %"Yu": unexpected format\n", prog, lineno); exit(EXIT_FAILURE); } else { *ptr = '\0'; - fprintf(stderr, "%s: line %" Z "d: unrecognized keyword ignored: %s\n", + fprintf(stderr, "%s: line %"Yu": unrecognized keyword ignored: %s\n", prog, lineno, (char *)dbuf.mv_data); } } @@ -166,7 +154,7 @@ static void readhdr(void) static void badend(void) { - fprintf(stderr, "%s: line %" Z "d: unexpected end of input\n", + fprintf(stderr, "%s: line %"Yu": unexpected end of input\n", prog, lineno); } @@ -224,7 +212,7 @@ badend: buf->mv_data = realloc(buf->mv_data, buf->mv_size*2); if (!buf->mv_data) { Eof = 1; - fprintf(stderr, "%s: line %" Z "d: out of memory, line too long\n", + fprintf(stderr, "%s: line %"Yu": out of memory, line too long\n", prog, lineno); return EOF; } @@ -259,7 +247,8 @@ badend: c2 += 2; } } else { - c1++; c2++; + /* copies are redundant when no escapes were used */ + *c1++ = *c2++; } } } else { @@ -435,7 +424,7 @@ int main(int argc, char *argv[]) rc = readline(&data, &dbuf); if (rc) { - fprintf(stderr, "%s: line %" Z "d: failed to read key value\n", prog, lineno); + fprintf(stderr, "%s: line %"Yu": failed to read key value\n", prog, lineno); goto txn_abort; } @@ -463,7 +452,7 @@ int main(int argc, char *argv[]) if (batch == 100) { rc = mdb_txn_commit(txn); if (rc) { - fprintf(stderr, "%s: line %" Z "d: txn_commit: %s\n", + fprintf(stderr, "%s: line %"Yu": txn_commit: %s\n", prog, lineno, mdb_strerror(rc)); goto env_close; } @@ -487,7 +476,7 @@ int main(int argc, char *argv[]) rc = mdb_txn_commit(txn); txn = NULL; if (rc) { - fprintf(stderr, "%s: line %" Z "d: txn_commit: %s\n", + fprintf(stderr, "%s: line %"Yu": txn_commit: %s\n", prog, lineno, mdb_strerror(rc)); goto env_close; } diff --git a/external/db_drivers/liblmdb/mdb_stat.1 b/external/db_drivers/liblmdb/mdb_stat.1 index bf49bd3bd..83988a0fa 100644 --- a/external/db_drivers/liblmdb/mdb_stat.1 +++ b/external/db_drivers/liblmdb/mdb_stat.1 @@ -1,5 +1,5 @@ -.TH MDB_STAT 1 "2014/06/20" "LMDB 0.9.14" -.\" Copyright 2012-2015 Howard Chu, Symas Corp. All Rights Reserved. +.TH MDB_STAT 1 "2017/07/31" "LMDB 0.9.70" +.\" Copyright 2012-2019 Howard Chu, Symas Corp. All Rights Reserved. .\" Copying restrictions apply. See COPYRIGHT/LICENSE. .SH NAME mdb_stat \- LMDB environment status tool diff --git a/external/db_drivers/liblmdb/mdb_stat.c b/external/db_drivers/liblmdb/mdb_stat.c index 30ec81fea..08f30befd 100644 --- a/external/db_drivers/liblmdb/mdb_stat.c +++ b/external/db_drivers/liblmdb/mdb_stat.c @@ -1,6 +1,6 @@ /* mdb_stat.c - memory-mapped database status tool */ /* - * Copyright 2011-2015 Howard Chu, Symas Corp. + * Copyright 2011-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -17,20 +17,8 @@ #include #include "lmdb.h" -#ifdef _WIN32 -#define Z "I" -#else -#define Z "z" -#endif -#ifdef MDB_VL32 -#ifdef _WIN32 -#define Y "I64" -#else -#define Y "ll" -#endif -#else -#define Y Z -#endif +#define Z MDB_FMT_Z +#define Yu MDB_PRIy(u) static void prstat(MDB_stat *ms) { @@ -38,10 +26,10 @@ static void prstat(MDB_stat *ms) printf(" Page size: %u\n", ms->ms_psize); #endif printf(" Tree depth: %u\n", ms->ms_depth); - printf(" Branch pages: %"Y"u\n", ms->ms_branch_pages); - printf(" Leaf pages: %"Y"u\n", ms->ms_leaf_pages); - printf(" Overflow pages: %"Y"u\n", ms->ms_overflow_pages); - printf(" Entries: %"Y"u\n", ms->ms_entries); + printf(" Branch pages: %"Yu"\n", ms->ms_branch_pages); + printf(" Leaf pages: %"Yu"\n", ms->ms_leaf_pages); + printf(" Overflow pages: %"Yu"\n", ms->ms_overflow_pages); + printf(" Entries: %"Yu"\n", ms->ms_entries); } static void usage(char *prog) @@ -138,11 +126,11 @@ int main(int argc, char *argv[]) (void)mdb_env_info(env, &mei); printf("Environment Info\n"); printf(" Map address: %p\n", mei.me_mapaddr); - printf(" Map size: %"Y"u\n", mei.me_mapsize); + printf(" Map size: %"Yu"\n", mei.me_mapsize); printf(" Page size: %u\n", mst.ms_psize); - printf(" Max pages: %"Y"u\n", mei.me_mapsize / mst.ms_psize); - printf(" Number of pages used: %"Y"u\n", mei.me_last_pgno+1); - printf(" Last transaction ID: %"Y"u\n", mei.me_last_txnid); + printf(" Max pages: %"Yu"\n", mei.me_mapsize / mst.ms_psize); + printf(" Number of pages used: %"Yu"\n", mei.me_last_pgno+1); + printf(" Last transaction ID: %"Yu"\n", mei.me_last_txnid); printf(" Max readers: %u\n", mei.me_maxreaders); printf(" Number of readers used: %u\n", mei.me_numreaders); } @@ -169,7 +157,7 @@ int main(int argc, char *argv[]) if (freinfo) { MDB_cursor *cursor; MDB_val key, data; - size_t pages = 0, *iptr; + mdb_size_t pages = 0, *iptr; printf("Freelist Status\n"); dbi = 0; @@ -189,7 +177,7 @@ int main(int argc, char *argv[]) pages += *iptr; if (freinfo > 1) { char *bad = ""; - size_t pg, prev; + mdb_size_t pg, prev; ssize_t i, j, span = 0; j = *iptr++; for (i = j, prev = 1; --i >= 0; ) { @@ -200,20 +188,20 @@ int main(int argc, char *argv[]) pg += span; for (; i >= span && iptr[i-span] == pg; span++, pg++) ; } - printf(" Transaction %"Z"u, %"Z"d pages, maxspan %"Z"d%s\n", - *(size_t *)key.mv_data, j, span, bad); + printf(" Transaction %"Yu", %"Z"d pages, maxspan %"Z"d%s\n", + *(mdb_size_t *)key.mv_data, j, span, bad); if (freinfo > 2) { for (--j; j >= 0; ) { pg = iptr[j]; for (span=1; --j >= 0 && iptr[j] == pg+span; span++) ; - printf(span>1 ? " %9"Z"u[%"Z"d]\n" : " %9"Z"u\n", + printf(span>1 ? " %9"Yu"[%"Z"d]\n" : " %9"Yu"\n", pg, span); } } } } mdb_cursor_close(cursor); - printf(" Free pages: %"Z"u\n", pages); + printf(" Free pages: %"Yu"\n", pages); } rc = mdb_open(txn, subname, 0, &dbi); diff --git a/external/db_drivers/liblmdb/midl.c b/external/db_drivers/liblmdb/midl.c index 152a1ec0d..ee89822e3 100644 --- a/external/db_drivers/liblmdb/midl.c +++ b/external/db_drivers/liblmdb/midl.c @@ -3,7 +3,8 @@ /* $OpenLDAP$ */ /* This work is part of OpenLDAP Software . * - * Copyright 2000-2015 The OpenLDAP Foundation. + * Copyright 2000-2019 The OpenLDAP Foundation. + * Portions Copyright 2001-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without diff --git a/external/db_drivers/liblmdb/midl.h b/external/db_drivers/liblmdb/midl.h index 1555ecb19..0f826771a 100644 --- a/external/db_drivers/liblmdb/midl.h +++ b/external/db_drivers/liblmdb/midl.h @@ -11,7 +11,8 @@ /* $OpenLDAP$ */ /* This work is part of OpenLDAP Software . * - * Copyright 2000-2015 The OpenLDAP Foundation. + * Copyright 2000-2019 The OpenLDAP Foundation. + * Portions Copyright 2001-2019 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -26,8 +27,7 @@ #ifndef _MDB_MIDL_H_ #define _MDB_MIDL_H_ -#include -#include +#include "lmdb.h" #ifdef __cplusplus extern "C" { @@ -43,11 +43,7 @@ extern "C" { /** A generic unsigned ID number. These were entryIDs in back-bdb. * Preferably it should have the same size as a pointer. */ -#ifdef MDB_VL32 -typedef uint64_t MDB_ID; -#else -typedef size_t MDB_ID; -#endif +typedef mdb_size_t MDB_ID; /** An IDL is an ID List, a sorted array of IDs. The first * element of the array is a counter for how many actual diff --git a/external/db_drivers/liblmdb/mtest.c b/external/db_drivers/liblmdb/mtest.c index 9d15088b0..6fc5840c3 100644 --- a/external/db_drivers/liblmdb/mtest.c +++ b/external/db_drivers/liblmdb/mtest.c @@ -1,6 +1,6 @@ /* mtest.c - memory-mapped database tester/toy */ /* - * Copyright 2011-2015 Howard Chu, Symas Corp. + * Copyright 2011-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without diff --git a/external/db_drivers/liblmdb/mtest2.c b/external/db_drivers/liblmdb/mtest2.c index eacbe59d5..64b742aa4 100644 --- a/external/db_drivers/liblmdb/mtest2.c +++ b/external/db_drivers/liblmdb/mtest2.c @@ -1,6 +1,6 @@ /* mtest2.c - memory-mapped database tester/toy */ /* - * Copyright 2011-2015 Howard Chu, Symas Corp. + * Copyright 2011-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without diff --git a/external/db_drivers/liblmdb/mtest3.c b/external/db_drivers/liblmdb/mtest3.c index 9db79e625..81e4bbf9b 100644 --- a/external/db_drivers/liblmdb/mtest3.c +++ b/external/db_drivers/liblmdb/mtest3.c @@ -1,6 +1,6 @@ /* mtest3.c - memory-mapped database tester/toy */ /* - * Copyright 2011-2015 Howard Chu, Symas Corp. + * Copyright 2011-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without diff --git a/external/db_drivers/liblmdb/mtest4.c b/external/db_drivers/liblmdb/mtest4.c index 6df890e2d..c355cf105 100644 --- a/external/db_drivers/liblmdb/mtest4.c +++ b/external/db_drivers/liblmdb/mtest4.c @@ -1,6 +1,6 @@ /* mtest4.c - memory-mapped database tester/toy */ /* - * Copyright 2011-2015 Howard Chu, Symas Corp. + * Copyright 2011-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without diff --git a/external/db_drivers/liblmdb/mtest5.c b/external/db_drivers/liblmdb/mtest5.c index 14e3c0da4..95793ec1f 100644 --- a/external/db_drivers/liblmdb/mtest5.c +++ b/external/db_drivers/liblmdb/mtest5.c @@ -1,6 +1,6 @@ /* mtest5.c - memory-mapped database tester/toy */ /* - * Copyright 2011-2015 Howard Chu, Symas Corp. + * Copyright 2011-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without diff --git a/external/db_drivers/liblmdb/mtest6.c b/external/db_drivers/liblmdb/mtest6.c index ae3c7f264..cb0d4d73c 100644 --- a/external/db_drivers/liblmdb/mtest6.c +++ b/external/db_drivers/liblmdb/mtest6.c @@ -1,6 +1,6 @@ /* mtest6.c - memory-mapped database tester/toy */ /* - * Copyright 2011-2015 Howard Chu, Symas Corp. + * Copyright 2011-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without diff --git a/external/db_drivers/liblmdb/sample-bdb.txt b/external/db_drivers/liblmdb/sample-bdb.txt index 563807a2b..97220f0ed 100644 --- a/external/db_drivers/liblmdb/sample-bdb.txt +++ b/external/db_drivers/liblmdb/sample-bdb.txt @@ -3,7 +3,7 @@ * Do a line-by-line comparison of this and sample-mdb.txt */ /* - * Copyright 2012-2015 Howard Chu, Symas Corp. + * Copyright 2012-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without diff --git a/external/db_drivers/liblmdb/sample-mdb.txt b/external/db_drivers/liblmdb/sample-mdb.txt index 10a256870..1d20ed3d0 100644 --- a/external/db_drivers/liblmdb/sample-mdb.txt +++ b/external/db_drivers/liblmdb/sample-mdb.txt @@ -3,7 +3,7 @@ * Do a line-by-line comparison of this and sample-bdb.txt */ /* - * Copyright 2012-2015 Howard Chu, Symas Corp. + * Copyright 2012-2018 Howard Chu, Symas Corp. * All rights reserved. * * Redistribution and use in source and binary forms, with or without From d91f84f275124a1b62a90af7170abee23b1b79de Mon Sep 17 00:00:00 2001 From: xiphon Date: Fri, 18 Jan 2019 00:55:55 +0000 Subject: [PATCH 16/17] daemon: extend 'print_pl' command, optional filter by type and limit --- src/daemon/command_parser_executor.cpp | 29 ++++++++++++++++++++++++-- src/daemon/command_server.cpp | 1 + src/daemon/rpc_command_executor.cpp | 20 +++++++++++++----- src/daemon/rpc_command_executor.h | 2 +- 4 files changed, 44 insertions(+), 8 deletions(-) diff --git a/src/daemon/command_parser_executor.cpp b/src/daemon/command_parser_executor.cpp index 8b0f9a9ae..dbadd6896 100644 --- a/src/daemon/command_parser_executor.cpp +++ b/src/daemon/command_parser_executor.cpp @@ -48,9 +48,34 @@ t_command_parser_executor::t_command_parser_executor( bool t_command_parser_executor::print_peer_list(const std::vector& args) { - if (!args.empty()) return false; + if (args.size() > 3) + { + std::cout << "use: print_pl [white] [gray] []" << std::endl; + return true; + } - return m_executor.print_peer_list(); + bool white = false; + bool gray = false; + size_t limit = 0; + for (size_t i = 0; i < args.size(); ++i) + { + if (args[i] == "white") + { + white = true; + } + else if (args[i] == "gray") + { + gray = true; + } + else if (!epee::string_tools::get_xtype_from_string(limit, args[i])) + { + std::cout << "unexpected argument: " << args[i] << std::endl; + return true; + } + } + + const bool print_both = !white && !gray; + return m_executor.print_peer_list(white | print_both, gray | print_both, limit); } bool t_command_parser_executor::print_peer_list_stats(const std::vector& args) diff --git a/src/daemon/command_server.cpp b/src/daemon/command_server.cpp index 1c3bbfb72..de0cdd2ca 100644 --- a/src/daemon/command_server.cpp +++ b/src/daemon/command_server.cpp @@ -64,6 +64,7 @@ t_command_server::t_command_server( m_command_lookup.set_handler( "print_pl" , std::bind(&t_command_parser_executor::print_peer_list, &m_parser, p::_1) + , "print_pl [white] [gray] []" , "Print the current peer list." ); m_command_lookup.set_handler( diff --git a/src/daemon/rpc_command_executor.cpp b/src/daemon/rpc_command_executor.cpp index 5eee48b0c..a75549f87 100644 --- a/src/daemon/rpc_command_executor.cpp +++ b/src/daemon/rpc_command_executor.cpp @@ -154,7 +154,7 @@ t_rpc_command_executor::~t_rpc_command_executor() } } -bool t_rpc_command_executor::print_peer_list() { +bool t_rpc_command_executor::print_peer_list(bool white, bool gray, size_t limit) { cryptonote::COMMAND_RPC_GET_PEER_LIST::request req; cryptonote::COMMAND_RPC_GET_PEER_LIST::response res; @@ -175,14 +175,24 @@ bool t_rpc_command_executor::print_peer_list() { } } - for (auto & peer : res.white_list) + if (white) { - print_peer("white", peer); + auto peer = res.white_list.cbegin(); + const auto end = limit ? peer + std::min(limit, res.white_list.size()) : res.white_list.cend(); + for (; peer != end; ++peer) + { + print_peer("white", *peer); + } } - for (auto & peer : res.gray_list) + if (gray) { - print_peer("gray", peer); + auto peer = res.gray_list.cbegin(); + const auto end = limit ? peer + std::min(limit, res.gray_list.size()) : res.gray_list.cend(); + for (; peer != end; ++peer) + { + print_peer("gray", *peer); + } } return true; diff --git a/src/daemon/rpc_command_executor.h b/src/daemon/rpc_command_executor.h index cc88e2611..ca9452090 100644 --- a/src/daemon/rpc_command_executor.h +++ b/src/daemon/rpc_command_executor.h @@ -67,7 +67,7 @@ public: ~t_rpc_command_executor(); - bool print_peer_list(); + bool print_peer_list(bool white = true, bool gray = true, size_t limit = 0); bool print_peer_list_stats(); From d65809476152c22cf350cee83f208328247208ef Mon Sep 17 00:00:00 2001 From: moneromooo-monero Date: Fri, 11 Jan 2019 19:09:39 +0000 Subject: [PATCH 17/17] rpc: fix internal daemon calls in restricted rpc getting partial data --- .../include/net/http_server_handlers_map2.h | 12 +- src/daemon/rpc_command_executor.cpp | 6 +- src/rpc/core_rpc_server.cpp | 214 ++++++++++-------- src/rpc/core_rpc_server.h | 116 +++++----- src/wallet/wallet_rpc_server.cpp | 152 ++++++------- src/wallet/wallet_rpc_server.h | 155 ++++++------- 6 files changed, 338 insertions(+), 317 deletions(-) diff --git a/contrib/epee/include/net/http_server_handlers_map2.h b/contrib/epee/include/net/http_server_handlers_map2.h index 64d035df9..4b2053091 100644 --- a/contrib/epee/include/net/http_server_handlers_map2.h +++ b/contrib/epee/include/net/http_server_handlers_map2.h @@ -54,7 +54,7 @@ bool handled = false; \ if(false) return true; //just a stub to have "else if" -#define MAP_URI2(pattern, callback) else if(std::string::npos != query_info.m_URI.find(pattern)) return callback(query_info, response_info, m_conn_context); +#define MAP_URI2(pattern, callback) else if(std::string::npos != query_info.m_URI.find(pattern)) return callback(query_info, response_info, &m_conn_context); #define MAP_URI_AUTO_XML2(s_pattern, callback_f, command_type) //TODO: don't think i ever again will use xml - ambiguous and "overtagged" format @@ -69,7 +69,7 @@ uint64_t ticks1 = epee::misc_utils::get_tick_count(); \ boost::value_initialized resp;\ MINFO(m_conn_context << "calling " << s_pattern); \ - if(!callback_f(static_cast(req), static_cast(resp))) \ + if(!callback_f(static_cast(req), static_cast(resp), &m_conn_context)) \ { \ LOG_ERROR("Failed to " << #callback_f << "()"); \ response_info.m_response_code = 500; \ @@ -97,7 +97,7 @@ uint64_t ticks1 = misc_utils::get_tick_count(); \ boost::value_initialized resp;\ MINFO(m_conn_context << "calling " << s_pattern); \ - if(!callback_f(static_cast(req), static_cast(resp))) \ + if(!callback_f(static_cast(req), static_cast(resp), &m_conn_context)) \ { \ LOG_ERROR("Failed to " << #callback_f << "()"); \ response_info.m_response_code = 500; \ @@ -182,7 +182,7 @@ fail_resp.jsonrpc = "2.0"; \ fail_resp.id = req.id; \ MINFO(m_conn_context << "Calling RPC method " << method_name); \ - if(!callback_f(req.params, resp.result, fail_resp.error)) \ + if(!callback_f(req.params, resp.result, fail_resp.error, &m_conn_context)) \ { \ epee::serialization::store_t_to_json(static_cast(fail_resp), response_info.m_body); \ return true; \ @@ -201,7 +201,7 @@ fail_resp.jsonrpc = "2.0"; \ fail_resp.id = req.id; \ MINFO(m_conn_context << "calling RPC method " << method_name); \ - if(!callback_f(req.params, resp.result, fail_resp.error, m_conn_context, response_info)) \ + if(!callback_f(req.params, resp.result, fail_resp.error, response_info, &m_conn_context)) \ { \ epee::serialization::store_t_to_json(static_cast(fail_resp), response_info.m_body); \ return true; \ @@ -215,7 +215,7 @@ { \ PREPARE_OBJECTS_FROM_JSON(command_type) \ MINFO(m_conn_context << "calling RPC method " << method_name); \ - if(!callback_f(req.params, resp.result)) \ + if(!callback_f(req.params, resp.result, &m_conn_context)) \ { \ epee::json_rpc::error_response fail_resp = AUTO_VAL_INIT(fail_resp); \ fail_resp.jsonrpc = "2.0"; \ diff --git a/src/daemon/rpc_command_executor.cpp b/src/daemon/rpc_command_executor.cpp index a75549f87..f1f4da3cf 100644 --- a/src/daemon/rpc_command_executor.cpp +++ b/src/daemon/rpc_command_executor.cpp @@ -864,7 +864,7 @@ bool t_rpc_command_executor::print_transaction_pool_long() { } else { - if (!m_rpc_server->on_get_transaction_pool(req, res, false) || res.status != CORE_RPC_STATUS_OK) + if (!m_rpc_server->on_get_transaction_pool(req, res) || res.status != CORE_RPC_STATUS_OK) { tools::fail_msg_writer() << make_error(fail_message, res.status); return true; @@ -950,7 +950,7 @@ bool t_rpc_command_executor::print_transaction_pool_short() { } else { - if (!m_rpc_server->on_get_transaction_pool(req, res, false) || res.status != CORE_RPC_STATUS_OK) + if (!m_rpc_server->on_get_transaction_pool(req, res) || res.status != CORE_RPC_STATUS_OK) { tools::fail_msg_writer() << make_error(fail_message, res.status); return true; @@ -1008,7 +1008,7 @@ bool t_rpc_command_executor::print_transaction_pool_stats() { else { res.pool_stats = {}; - if (!m_rpc_server->on_get_transaction_pool_stats(req, res, false) || res.status != CORE_RPC_STATUS_OK) + if (!m_rpc_server->on_get_transaction_pool_stats(req, res) || res.status != CORE_RPC_STATUS_OK) { tools::fail_msg_writer() << make_error(fail_message, res.status); return true; diff --git a/src/rpc/core_rpc_server.cpp b/src/rpc/core_rpc_server.cpp index 2d0169df0..bb9415e03 100644 --- a/src/rpc/core_rpc_server.cpp +++ b/src/rpc/core_rpc_server.cpp @@ -147,7 +147,7 @@ namespace cryptonote #define CHECK_CORE_READY() do { if(!check_core_ready()){res.status = CORE_RPC_STATUS_BUSY;return true;} } while(0) //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_height(const COMMAND_RPC_GET_HEIGHT::request& req, COMMAND_RPC_GET_HEIGHT::response& res) + bool core_rpc_server::on_get_height(const COMMAND_RPC_GET_HEIGHT::request& req, COMMAND_RPC_GET_HEIGHT::response& res, const connection_context *ctx) { PERF_TIMER(on_get_height); bool r; @@ -159,7 +159,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_info(const COMMAND_RPC_GET_INFO::request& req, COMMAND_RPC_GET_INFO::response& res) + bool core_rpc_server::on_get_info(const COMMAND_RPC_GET_INFO::request& req, COMMAND_RPC_GET_INFO::response& res, const connection_context *ctx) { PERF_TIMER(on_get_info); bool r; @@ -173,6 +173,8 @@ namespace cryptonote return r; } + const bool restricted = m_restricted && ctx; + crypto::hash top_hash; m_core.get_blockchain_top(res.height, top_hash); ++res.height; // turn top block height into blockchain height @@ -182,13 +184,13 @@ namespace cryptonote res.target = m_core.get_blockchain_storage().get_difficulty_target(); res.tx_count = m_core.get_blockchain_storage().get_total_transactions() - res.height; //without coinbase res.tx_pool_size = m_core.get_pool_transactions_count(); - res.alt_blocks_count = m_restricted ? 0 : m_core.get_blockchain_storage().get_alternative_blocks_count(); - uint64_t total_conn = m_restricted ? 0 : m_p2p.get_connections_count(); - res.outgoing_connections_count = m_restricted ? 0 : m_p2p.get_outgoing_connections_count(); - res.incoming_connections_count = m_restricted ? 0 : (total_conn - res.outgoing_connections_count); - res.rpc_connections_count = m_restricted ? 0 : get_connections_count(); - res.white_peerlist_size = m_restricted ? 0 : m_p2p.get_peerlist_manager().get_white_peers_count(); - res.grey_peerlist_size = m_restricted ? 0 : m_p2p.get_peerlist_manager().get_gray_peers_count(); + res.alt_blocks_count = restricted ? 0 : m_core.get_blockchain_storage().get_alternative_blocks_count(); + uint64_t total_conn = restricted ? 0 : m_p2p.get_connections_count(); + res.outgoing_connections_count = restricted ? 0 : m_p2p.get_outgoing_connections_count(); + res.incoming_connections_count = restricted ? 0 : (total_conn - res.outgoing_connections_count); + res.rpc_connections_count = restricted ? 0 : get_connections_count(); + res.white_peerlist_size = restricted ? 0 : m_p2p.get_peerlist_manager().get_white_peers_count(); + res.grey_peerlist_size = restricted ? 0 : m_p2p.get_peerlist_manager().get_gray_peers_count(); cryptonote::network_type net_type = nettype(); res.mainnet = net_type == MAINNET; @@ -199,21 +201,21 @@ namespace cryptonote res.block_size_limit = res.block_weight_limit = m_core.get_blockchain_storage().get_current_cumulative_block_weight_limit(); res.block_size_median = res.block_weight_median = m_core.get_blockchain_storage().get_current_cumulative_block_weight_median(); res.status = CORE_RPC_STATUS_OK; - res.start_time = m_restricted ? 0 : (uint64_t)m_core.get_start_time(); - res.free_space = m_restricted ? std::numeric_limits::max() : m_core.get_free_space(); + res.start_time = restricted ? 0 : (uint64_t)m_core.get_start_time(); + res.free_space = restricted ? std::numeric_limits::max() : m_core.get_free_space(); res.offline = m_core.offline(); - res.bootstrap_daemon_address = m_restricted ? "" : m_bootstrap_daemon_address; - res.height_without_bootstrap = m_restricted ? 0 : res.height; - if (m_restricted) + res.bootstrap_daemon_address = restricted ? "" : m_bootstrap_daemon_address; + res.height_without_bootstrap = restricted ? 0 : res.height; + if (restricted) res.was_bootstrap_ever_used = false; else { boost::shared_lock lock(m_bootstrap_daemon_mutex); res.was_bootstrap_ever_used = m_was_bootstrap_ever_used; } - res.database_size = m_restricted ? 0 : m_core.get_blockchain_storage().get_db().get_database_size(); - res.update_available = m_restricted ? false : m_core.is_update_available(); - res.version = m_restricted ? "" : MONERO_VERSION; + res.database_size = restricted ? 0 : m_core.get_blockchain_storage().get_db().get_database_size(); + res.update_available = restricted ? false : m_core.is_update_available(); + res.version = restricted ? "" : MONERO_VERSION; return true; } //------------------------------------------------------------------------------------------------------------------------------ @@ -227,7 +229,7 @@ namespace cryptonote END_SERIALIZE() }; //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_blocks(const COMMAND_RPC_GET_BLOCKS_FAST::request& req, COMMAND_RPC_GET_BLOCKS_FAST::response& res) + bool core_rpc_server::on_get_blocks(const COMMAND_RPC_GET_BLOCKS_FAST::request& req, COMMAND_RPC_GET_BLOCKS_FAST::response& res, const connection_context *ctx) { PERF_TIMER(on_get_blocks); bool r; @@ -290,7 +292,7 @@ namespace cryptonote res.status = CORE_RPC_STATUS_OK; return true; } - bool core_rpc_server::on_get_alt_blocks_hashes(const COMMAND_RPC_GET_ALT_BLOCKS_HASHES::request& req, COMMAND_RPC_GET_ALT_BLOCKS_HASHES::response& res) + bool core_rpc_server::on_get_alt_blocks_hashes(const COMMAND_RPC_GET_ALT_BLOCKS_HASHES::request& req, COMMAND_RPC_GET_ALT_BLOCKS_HASHES::response& res, const connection_context *ctx) { PERF_TIMER(on_get_alt_blocks_hashes); bool r; @@ -317,7 +319,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_blocks_by_height(const COMMAND_RPC_GET_BLOCKS_BY_HEIGHT::request& req, COMMAND_RPC_GET_BLOCKS_BY_HEIGHT::response& res) + bool core_rpc_server::on_get_blocks_by_height(const COMMAND_RPC_GET_BLOCKS_BY_HEIGHT::request& req, COMMAND_RPC_GET_BLOCKS_BY_HEIGHT::response& res, const connection_context *ctx) { PERF_TIMER(on_get_blocks_by_height); bool r; @@ -351,7 +353,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_hashes(const COMMAND_RPC_GET_HASHES_FAST::request& req, COMMAND_RPC_GET_HASHES_FAST::response& res) + bool core_rpc_server::on_get_hashes(const COMMAND_RPC_GET_HASHES_FAST::request& req, COMMAND_RPC_GET_HASHES_FAST::response& res, const connection_context *ctx) { PERF_TIMER(on_get_hashes); bool r; @@ -374,7 +376,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_outs_bin(const COMMAND_RPC_GET_OUTPUTS_BIN::request& req, COMMAND_RPC_GET_OUTPUTS_BIN::response& res) + bool core_rpc_server::on_get_outs_bin(const COMMAND_RPC_GET_OUTPUTS_BIN::request& req, COMMAND_RPC_GET_OUTPUTS_BIN::response& res, const connection_context *ctx) { PERF_TIMER(on_get_outs_bin); bool r; @@ -383,7 +385,8 @@ namespace cryptonote res.status = "Failed"; - if (m_restricted) + const bool restricted = m_restricted && ctx; + if (restricted) { if (req.outputs.size() > MAX_RESTRICTED_GLOBAL_FAKE_OUTS_COUNT) { @@ -401,7 +404,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_outs(const COMMAND_RPC_GET_OUTPUTS::request& req, COMMAND_RPC_GET_OUTPUTS::response& res) + bool core_rpc_server::on_get_outs(const COMMAND_RPC_GET_OUTPUTS::request& req, COMMAND_RPC_GET_OUTPUTS::response& res, const connection_context *ctx) { PERF_TIMER(on_get_outs); bool r; @@ -410,7 +413,8 @@ namespace cryptonote res.status = "Failed"; - if (m_restricted) + const bool restricted = m_restricted && ctx; + if (restricted) { if (req.outputs.size() > MAX_RESTRICTED_GLOBAL_FAKE_OUTS_COUNT) { @@ -443,7 +447,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_indexes(const COMMAND_RPC_GET_TX_GLOBAL_OUTPUTS_INDEXES::request& req, COMMAND_RPC_GET_TX_GLOBAL_OUTPUTS_INDEXES::response& res) + bool core_rpc_server::on_get_indexes(const COMMAND_RPC_GET_TX_GLOBAL_OUTPUTS_INDEXES::request& req, COMMAND_RPC_GET_TX_GLOBAL_OUTPUTS_INDEXES::response& res, const connection_context *ctx) { PERF_TIMER(on_get_indexes); bool ok; @@ -461,7 +465,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_transactions(const COMMAND_RPC_GET_TRANSACTIONS::request& req, COMMAND_RPC_GET_TRANSACTIONS::response& res) + bool core_rpc_server::on_get_transactions(const COMMAND_RPC_GET_TRANSACTIONS::request& req, COMMAND_RPC_GET_TRANSACTIONS::response& res, const connection_context *ctx) { PERF_TIMER(on_get_transactions); bool ok; @@ -617,13 +621,15 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_is_key_image_spent(const COMMAND_RPC_IS_KEY_IMAGE_SPENT::request& req, COMMAND_RPC_IS_KEY_IMAGE_SPENT::response& res, bool request_has_rpc_origin) + bool core_rpc_server::on_is_key_image_spent(const COMMAND_RPC_IS_KEY_IMAGE_SPENT::request& req, COMMAND_RPC_IS_KEY_IMAGE_SPENT::response& res, const connection_context *ctx) { PERF_TIMER(on_is_key_image_spent); bool ok; if (use_bootstrap_daemon_if_necessary(invoke_http_mode::JON, "/is_key_image_spent", req, res, ok)) return ok; + const bool restricted = m_restricted && ctx; + const bool request_has_rpc_origin = ctx != NULL; std::vector key_images; for(const auto& ki_hex_str: req.key_images) { @@ -653,7 +659,7 @@ namespace cryptonote // check the pool too std::vector txs; std::vector ki; - r = m_core.get_pool_transactions_and_spent_keys_info(txs, ki, !request_has_rpc_origin || !m_restricted); + r = m_core.get_pool_transactions_and_spent_keys_info(txs, ki, !request_has_rpc_origin || !restricted); if(!r) { res.status = "Failed"; @@ -684,7 +690,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_send_raw_tx(const COMMAND_RPC_SEND_RAW_TX::request& req, COMMAND_RPC_SEND_RAW_TX::response& res) + bool core_rpc_server::on_send_raw_tx(const COMMAND_RPC_SEND_RAW_TX::request& req, COMMAND_RPC_SEND_RAW_TX::response& res, const connection_context *ctx) { PERF_TIMER(on_send_raw_tx); bool ok; @@ -752,7 +758,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_start_mining(const COMMAND_RPC_START_MINING::request& req, COMMAND_RPC_START_MINING::response& res) + bool core_rpc_server::on_start_mining(const COMMAND_RPC_START_MINING::request& req, COMMAND_RPC_START_MINING::response& res, const connection_context *ctx) { PERF_TIMER(on_start_mining); CHECK_CORE_READY(); @@ -806,7 +812,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_stop_mining(const COMMAND_RPC_STOP_MINING::request& req, COMMAND_RPC_STOP_MINING::response& res) + bool core_rpc_server::on_stop_mining(const COMMAND_RPC_STOP_MINING::request& req, COMMAND_RPC_STOP_MINING::response& res, const connection_context *ctx) { PERF_TIMER(on_stop_mining); cryptonote::miner &miner= m_core.get_miner(); @@ -826,7 +832,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_mining_status(const COMMAND_RPC_MINING_STATUS::request& req, COMMAND_RPC_MINING_STATUS::response& res) + bool core_rpc_server::on_mining_status(const COMMAND_RPC_MINING_STATUS::request& req, COMMAND_RPC_MINING_STATUS::response& res, const connection_context *ctx) { PERF_TIMER(on_mining_status); @@ -845,7 +851,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_save_bc(const COMMAND_RPC_SAVE_BC::request& req, COMMAND_RPC_SAVE_BC::response& res) + bool core_rpc_server::on_save_bc(const COMMAND_RPC_SAVE_BC::request& req, COMMAND_RPC_SAVE_BC::response& res, const connection_context *ctx) { PERF_TIMER(on_save_bc); if( !m_core.get_blockchain_storage().store_blockchain() ) @@ -857,7 +863,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_peer_list(const COMMAND_RPC_GET_PEER_LIST::request& req, COMMAND_RPC_GET_PEER_LIST::response& res) + bool core_rpc_server::on_get_peer_list(const COMMAND_RPC_GET_PEER_LIST::request& req, COMMAND_RPC_GET_PEER_LIST::response& res, const connection_context *ctx) { PERF_TIMER(on_get_peer_list); std::vector white_list; @@ -888,7 +894,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_set_log_hash_rate(const COMMAND_RPC_SET_LOG_HASH_RATE::request& req, COMMAND_RPC_SET_LOG_HASH_RATE::response& res) + bool core_rpc_server::on_set_log_hash_rate(const COMMAND_RPC_SET_LOG_HASH_RATE::request& req, COMMAND_RPC_SET_LOG_HASH_RATE::response& res, const connection_context *ctx) { PERF_TIMER(on_set_log_hash_rate); if(m_core.get_miner().is_mining()) @@ -903,7 +909,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_set_log_level(const COMMAND_RPC_SET_LOG_LEVEL::request& req, COMMAND_RPC_SET_LOG_LEVEL::response& res) + bool core_rpc_server::on_set_log_level(const COMMAND_RPC_SET_LOG_LEVEL::request& req, COMMAND_RPC_SET_LOG_LEVEL::response& res, const connection_context *ctx) { PERF_TIMER(on_set_log_level); if (req.level < 0 || req.level > 4) @@ -916,7 +922,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_set_log_categories(const COMMAND_RPC_SET_LOG_CATEGORIES::request& req, COMMAND_RPC_SET_LOG_CATEGORIES::response& res) + bool core_rpc_server::on_set_log_categories(const COMMAND_RPC_SET_LOG_CATEGORIES::request& req, COMMAND_RPC_SET_LOG_CATEGORIES::response& res, const connection_context *ctx) { PERF_TIMER(on_set_log_categories); mlog_set_log(req.categories.c_str()); @@ -925,41 +931,47 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_transaction_pool(const COMMAND_RPC_GET_TRANSACTION_POOL::request& req, COMMAND_RPC_GET_TRANSACTION_POOL::response& res, bool request_has_rpc_origin) + bool core_rpc_server::on_get_transaction_pool(const COMMAND_RPC_GET_TRANSACTION_POOL::request& req, COMMAND_RPC_GET_TRANSACTION_POOL::response& res, const connection_context *ctx) { PERF_TIMER(on_get_transaction_pool); bool r; if (use_bootstrap_daemon_if_necessary(invoke_http_mode::JON, "/get_transaction_pool", req, res, r)) return r; - m_core.get_pool_transactions_and_spent_keys_info(res.transactions, res.spent_key_images, !request_has_rpc_origin || !m_restricted); + const bool restricted = m_restricted && ctx; + const bool request_has_rpc_origin = ctx != NULL; + m_core.get_pool_transactions_and_spent_keys_info(res.transactions, res.spent_key_images, !request_has_rpc_origin || !restricted); for (tx_info& txi : res.transactions) txi.tx_blob = epee::string_tools::buff_to_hex_nodelimer(txi.tx_blob); res.status = CORE_RPC_STATUS_OK; return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_transaction_pool_hashes_bin(const COMMAND_RPC_GET_TRANSACTION_POOL_HASHES_BIN::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_HASHES_BIN::response& res, bool request_has_rpc_origin) + bool core_rpc_server::on_get_transaction_pool_hashes_bin(const COMMAND_RPC_GET_TRANSACTION_POOL_HASHES_BIN::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_HASHES_BIN::response& res, const connection_context *ctx) { PERF_TIMER(on_get_transaction_pool_hashes); bool r; if (use_bootstrap_daemon_if_necessary(invoke_http_mode::JON, "/get_transaction_pool_hashes.bin", req, res, r)) return r; - m_core.get_pool_transaction_hashes(res.tx_hashes, !request_has_rpc_origin || !m_restricted); + const bool restricted = m_restricted && ctx; + const bool request_has_rpc_origin = ctx != NULL; + m_core.get_pool_transaction_hashes(res.tx_hashes, !request_has_rpc_origin || !restricted); res.status = CORE_RPC_STATUS_OK; return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_transaction_pool_hashes(const COMMAND_RPC_GET_TRANSACTION_POOL_HASHES::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_HASHES::response& res, bool request_has_rpc_origin) + bool core_rpc_server::on_get_transaction_pool_hashes(const COMMAND_RPC_GET_TRANSACTION_POOL_HASHES::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_HASHES::response& res, const connection_context *ctx) { PERF_TIMER(on_get_transaction_pool_hashes); bool r; if (use_bootstrap_daemon_if_necessary(invoke_http_mode::JON, "/get_transaction_pool_hashes", req, res, r)) return r; + const bool restricted = m_restricted && ctx; + const bool request_has_rpc_origin = ctx != NULL; std::vector tx_hashes; - m_core.get_pool_transaction_hashes(tx_hashes, !request_has_rpc_origin || !m_restricted); + m_core.get_pool_transaction_hashes(tx_hashes, !request_has_rpc_origin || !restricted); res.tx_hashes.reserve(tx_hashes.size()); for (const crypto::hash &tx_hash: tx_hashes) res.tx_hashes.push_back(epee::string_tools::pod_to_hex(tx_hash)); @@ -967,19 +979,21 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_transaction_pool_stats(const COMMAND_RPC_GET_TRANSACTION_POOL_STATS::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_STATS::response& res, bool request_has_rpc_origin) + bool core_rpc_server::on_get_transaction_pool_stats(const COMMAND_RPC_GET_TRANSACTION_POOL_STATS::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_STATS::response& res, const connection_context *ctx) { PERF_TIMER(on_get_transaction_pool_stats); bool r; if (use_bootstrap_daemon_if_necessary(invoke_http_mode::JON, "/get_transaction_pool_stats", req, res, r)) return r; - m_core.get_pool_transaction_stats(res.pool_stats, !request_has_rpc_origin || !m_restricted); + const bool restricted = m_restricted && ctx; + const bool request_has_rpc_origin = ctx != NULL; + m_core.get_pool_transaction_stats(res.pool_stats, !request_has_rpc_origin || !restricted); res.status = CORE_RPC_STATUS_OK; return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_stop_daemon(const COMMAND_RPC_STOP_DAEMON::request& req, COMMAND_RPC_STOP_DAEMON::response& res) + bool core_rpc_server::on_stop_daemon(const COMMAND_RPC_STOP_DAEMON::request& req, COMMAND_RPC_STOP_DAEMON::response& res, const connection_context *ctx) { PERF_TIMER(on_stop_daemon); // FIXME: replace back to original m_p2p.send_stop_signal() after @@ -989,7 +1003,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_getblockcount(const COMMAND_RPC_GETBLOCKCOUNT::request& req, COMMAND_RPC_GETBLOCKCOUNT::response& res) + bool core_rpc_server::on_getblockcount(const COMMAND_RPC_GETBLOCKCOUNT::request& req, COMMAND_RPC_GETBLOCKCOUNT::response& res, const connection_context *ctx) { PERF_TIMER(on_getblockcount); { @@ -1005,7 +1019,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_getblockhash(const COMMAND_RPC_GETBLOCKHASH::request& req, COMMAND_RPC_GETBLOCKHASH::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_getblockhash(const COMMAND_RPC_GETBLOCKHASH::request& req, COMMAND_RPC_GETBLOCKHASH::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_getblockhash); { @@ -1049,7 +1063,7 @@ namespace cryptonote return 0; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_getblocktemplate(const COMMAND_RPC_GETBLOCKTEMPLATE::request& req, COMMAND_RPC_GETBLOCKTEMPLATE::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_getblocktemplate(const COMMAND_RPC_GETBLOCKTEMPLATE::request& req, COMMAND_RPC_GETBLOCKTEMPLATE::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_getblocktemplate); bool r; @@ -1128,7 +1142,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_submitblock(const COMMAND_RPC_SUBMITBLOCK::request& req, COMMAND_RPC_SUBMITBLOCK::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_submitblock(const COMMAND_RPC_SUBMITBLOCK::request& req, COMMAND_RPC_SUBMITBLOCK::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_submitblock); { @@ -1183,7 +1197,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_generateblocks(const COMMAND_RPC_GENERATEBLOCKS::request& req, COMMAND_RPC_GENERATEBLOCKS::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_generateblocks(const COMMAND_RPC_GENERATEBLOCKS::request& req, COMMAND_RPC_GENERATEBLOCKS::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_generateblocks); @@ -1212,7 +1226,7 @@ namespace cryptonote for(size_t i = 0; i < req.amount_of_blocks; i++) { - r = on_getblocktemplate(template_req, template_res, error_resp); + r = on_getblocktemplate(template_req, template_res, error_resp, ctx); res.status = template_res.status; if (!r) return false; @@ -1234,7 +1248,7 @@ namespace cryptonote miner::find_nonce_for_given_block(b, template_res.difficulty, template_res.height); submit_req.front() = string_tools::buff_to_hex_nodelimer(block_to_blob(b)); - r = on_submitblock(submit_req, submit_res, error_resp); + r = on_submitblock(submit_req, submit_res, error_resp, ctx); res.status = submit_res.status; if (!r) return false; @@ -1343,7 +1357,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_last_block_header(const COMMAND_RPC_GET_LAST_BLOCK_HEADER::request& req, COMMAND_RPC_GET_LAST_BLOCK_HEADER::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_get_last_block_header(const COMMAND_RPC_GET_LAST_BLOCK_HEADER::request& req, COMMAND_RPC_GET_LAST_BLOCK_HEADER::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_get_last_block_header); bool r; @@ -1373,7 +1387,8 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_block_header_by_hash(const COMMAND_RPC_GET_BLOCK_HEADER_BY_HASH::request& req, COMMAND_RPC_GET_BLOCK_HEADER_BY_HASH::response& res, epee::json_rpc::error& error_resp){ + bool core_rpc_server::on_get_block_header_by_hash(const COMMAND_RPC_GET_BLOCK_HEADER_BY_HASH::request& req, COMMAND_RPC_GET_BLOCK_HEADER_BY_HASH::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) + { PERF_TIMER(on_get_block_header_by_hash); bool r; if (use_bootstrap_daemon_if_necessary(invoke_http_mode::JON_RPC, "getblockheaderbyhash", req, res, r)) @@ -1414,7 +1429,8 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_block_headers_range(const COMMAND_RPC_GET_BLOCK_HEADERS_RANGE::request& req, COMMAND_RPC_GET_BLOCK_HEADERS_RANGE::response& res, epee::json_rpc::error& error_resp){ + bool core_rpc_server::on_get_block_headers_range(const COMMAND_RPC_GET_BLOCK_HEADERS_RANGE::request& req, COMMAND_RPC_GET_BLOCK_HEADERS_RANGE::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) + { PERF_TIMER(on_get_block_headers_range); bool r; if (use_bootstrap_daemon_if_necessary(invoke_http_mode::JON_RPC, "getblockheadersrange", req, res, r)) @@ -1464,7 +1480,8 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_block_header_by_height(const COMMAND_RPC_GET_BLOCK_HEADER_BY_HEIGHT::request& req, COMMAND_RPC_GET_BLOCK_HEADER_BY_HEIGHT::response& res, epee::json_rpc::error& error_resp){ + bool core_rpc_server::on_get_block_header_by_height(const COMMAND_RPC_GET_BLOCK_HEADER_BY_HEIGHT::request& req, COMMAND_RPC_GET_BLOCK_HEADER_BY_HEIGHT::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) + { PERF_TIMER(on_get_block_header_by_height); bool r; if (use_bootstrap_daemon_if_necessary(invoke_http_mode::JON_RPC, "getblockheaderbyheight", req, res, r)) @@ -1496,7 +1513,8 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_block(const COMMAND_RPC_GET_BLOCK::request& req, COMMAND_RPC_GET_BLOCK::response& res, epee::json_rpc::error& error_resp){ + bool core_rpc_server::on_get_block(const COMMAND_RPC_GET_BLOCK::request& req, COMMAND_RPC_GET_BLOCK::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) + { PERF_TIMER(on_get_block); bool r; if (use_bootstrap_daemon_if_necessary(invoke_http_mode::JON_RPC, "getblock", req, res, r)) @@ -1557,7 +1575,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_connections(const COMMAND_RPC_GET_CONNECTIONS::request& req, COMMAND_RPC_GET_CONNECTIONS::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_get_connections(const COMMAND_RPC_GET_CONNECTIONS::request& req, COMMAND_RPC_GET_CONNECTIONS::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_get_connections); @@ -1568,7 +1586,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_info_json(const COMMAND_RPC_GET_INFO::request& req, COMMAND_RPC_GET_INFO::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_get_info_json(const COMMAND_RPC_GET_INFO::request& req, COMMAND_RPC_GET_INFO::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_get_info_json); bool r; @@ -1582,6 +1600,8 @@ namespace cryptonote return r; } + const bool restricted = m_restricted && ctx; + crypto::hash top_hash; m_core.get_blockchain_top(res.height, top_hash); ++res.height; // turn top block height into blockchain height @@ -1591,13 +1611,13 @@ namespace cryptonote res.target = m_core.get_blockchain_storage().get_current_hard_fork_version() < 2 ? DIFFICULTY_TARGET_V1 : DIFFICULTY_TARGET_V2; res.tx_count = m_core.get_blockchain_storage().get_total_transactions() - res.height; //without coinbase res.tx_pool_size = m_core.get_pool_transactions_count(); - res.alt_blocks_count = m_restricted ? 0 : m_core.get_blockchain_storage().get_alternative_blocks_count(); - uint64_t total_conn = m_restricted ? 0 : m_p2p.get_connections_count(); - res.outgoing_connections_count = m_restricted ? 0 : m_p2p.get_outgoing_connections_count(); - res.incoming_connections_count = m_restricted ? 0 : (total_conn - res.outgoing_connections_count); - res.rpc_connections_count = m_restricted ? 0 : get_connections_count(); - res.white_peerlist_size = m_restricted ? 0 : m_p2p.get_peerlist_manager().get_white_peers_count(); - res.grey_peerlist_size = m_restricted ? 0 : m_p2p.get_peerlist_manager().get_gray_peers_count(); + res.alt_blocks_count = restricted ? 0 : m_core.get_blockchain_storage().get_alternative_blocks_count(); + uint64_t total_conn = restricted ? 0 : m_p2p.get_connections_count(); + res.outgoing_connections_count = restricted ? 0 : m_p2p.get_outgoing_connections_count(); + res.incoming_connections_count = restricted ? 0 : (total_conn - res.outgoing_connections_count); + res.rpc_connections_count = restricted ? 0 : get_connections_count(); + res.white_peerlist_size = restricted ? 0 : m_p2p.get_peerlist_manager().get_white_peers_count(); + res.grey_peerlist_size = restricted ? 0 : m_p2p.get_peerlist_manager().get_gray_peers_count(); cryptonote::network_type net_type = nettype(); res.mainnet = net_type == MAINNET; @@ -1609,25 +1629,25 @@ namespace cryptonote res.block_size_limit = res.block_weight_limit = m_core.get_blockchain_storage().get_current_cumulative_block_weight_limit(); res.block_size_median = res.block_weight_median = m_core.get_blockchain_storage().get_current_cumulative_block_weight_median(); res.status = CORE_RPC_STATUS_OK; - res.start_time = m_restricted ? 0 : (uint64_t)m_core.get_start_time(); - res.free_space = m_restricted ? std::numeric_limits::max() : m_core.get_free_space(); + res.start_time = restricted ? 0 : (uint64_t)m_core.get_start_time(); + res.free_space = restricted ? std::numeric_limits::max() : m_core.get_free_space(); res.offline = m_core.offline(); - res.bootstrap_daemon_address = m_restricted ? "" : m_bootstrap_daemon_address; - res.height_without_bootstrap = m_restricted ? 0 : res.height; - if (m_restricted) + res.bootstrap_daemon_address = restricted ? "" : m_bootstrap_daemon_address; + res.height_without_bootstrap = restricted ? 0 : res.height; + if (restricted) res.was_bootstrap_ever_used = false; else { boost::shared_lock lock(m_bootstrap_daemon_mutex); res.was_bootstrap_ever_used = m_was_bootstrap_ever_used; } - res.database_size = m_restricted ? 0 : m_core.get_blockchain_storage().get_db().get_database_size(); - res.update_available = m_restricted ? false : m_core.is_update_available(); - res.version = m_restricted ? "" : MONERO_VERSION; + res.database_size = restricted ? 0 : m_core.get_blockchain_storage().get_db().get_database_size(); + res.update_available = restricted ? false : m_core.is_update_available(); + res.version = restricted ? "" : MONERO_VERSION; return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_hard_fork_info(const COMMAND_RPC_HARD_FORK_INFO::request& req, COMMAND_RPC_HARD_FORK_INFO::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_hard_fork_info(const COMMAND_RPC_HARD_FORK_INFO::request& req, COMMAND_RPC_HARD_FORK_INFO::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_hard_fork_info); bool r; @@ -1643,7 +1663,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_bans(const COMMAND_RPC_GETBANS::request& req, COMMAND_RPC_GETBANS::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_get_bans(const COMMAND_RPC_GETBANS::request& req, COMMAND_RPC_GETBANS::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_get_bans); @@ -1667,7 +1687,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_set_bans(const COMMAND_RPC_SETBANS::request& req, COMMAND_RPC_SETBANS::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_set_bans(const COMMAND_RPC_SETBANS::request& req, COMMAND_RPC_SETBANS::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_set_bans); @@ -1697,7 +1717,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_flush_txpool(const COMMAND_RPC_FLUSH_TRANSACTION_POOL::request& req, COMMAND_RPC_FLUSH_TRANSACTION_POOL::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_flush_txpool(const COMMAND_RPC_FLUSH_TRANSACTION_POOL::request& req, COMMAND_RPC_FLUSH_TRANSACTION_POOL::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_flush_txpool); @@ -1752,7 +1772,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_output_histogram(const COMMAND_RPC_GET_OUTPUT_HISTOGRAM::request& req, COMMAND_RPC_GET_OUTPUT_HISTOGRAM::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_get_output_histogram(const COMMAND_RPC_GET_OUTPUT_HISTOGRAM::request& req, COMMAND_RPC_GET_OUTPUT_HISTOGRAM::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_get_output_histogram); bool r; @@ -1782,7 +1802,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_version(const COMMAND_RPC_GET_VERSION::request& req, COMMAND_RPC_GET_VERSION::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_get_version(const COMMAND_RPC_GET_VERSION::request& req, COMMAND_RPC_GET_VERSION::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_get_version); bool r; @@ -1794,7 +1814,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_coinbase_tx_sum(const COMMAND_RPC_GET_COINBASE_TX_SUM::request& req, COMMAND_RPC_GET_COINBASE_TX_SUM::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_get_coinbase_tx_sum(const COMMAND_RPC_GET_COINBASE_TX_SUM::request& req, COMMAND_RPC_GET_COINBASE_TX_SUM::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_get_coinbase_tx_sum); std::pair amounts = m_core.get_coinbase_tx_sum(req.height, req.count); @@ -1804,7 +1824,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_base_fee_estimate(const COMMAND_RPC_GET_BASE_FEE_ESTIMATE::request& req, COMMAND_RPC_GET_BASE_FEE_ESTIMATE::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_get_base_fee_estimate(const COMMAND_RPC_GET_BASE_FEE_ESTIMATE::request& req, COMMAND_RPC_GET_BASE_FEE_ESTIMATE::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_get_base_fee_estimate); bool r; @@ -1817,7 +1837,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_alternate_chains(const COMMAND_RPC_GET_ALTERNATE_CHAINS::request& req, COMMAND_RPC_GET_ALTERNATE_CHAINS::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_get_alternate_chains(const COMMAND_RPC_GET_ALTERNATE_CHAINS::request& req, COMMAND_RPC_GET_ALTERNATE_CHAINS::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_get_alternate_chains); try @@ -1848,7 +1868,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_limit(const COMMAND_RPC_GET_LIMIT::request& req, COMMAND_RPC_GET_LIMIT::response& res) + bool core_rpc_server::on_get_limit(const COMMAND_RPC_GET_LIMIT::request& req, COMMAND_RPC_GET_LIMIT::response& res, const connection_context *ctx) { PERF_TIMER(on_get_limit); bool r; @@ -1861,7 +1881,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_set_limit(const COMMAND_RPC_SET_LIMIT::request& req, COMMAND_RPC_SET_LIMIT::response& res) + bool core_rpc_server::on_set_limit(const COMMAND_RPC_SET_LIMIT::request& req, COMMAND_RPC_SET_LIMIT::response& res, const connection_context *ctx) { PERF_TIMER(on_set_limit); // -1 = reset to default @@ -1901,7 +1921,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_out_peers(const COMMAND_RPC_OUT_PEERS::request& req, COMMAND_RPC_OUT_PEERS::response& res) + bool core_rpc_server::on_out_peers(const COMMAND_RPC_OUT_PEERS::request& req, COMMAND_RPC_OUT_PEERS::response& res, const connection_context *ctx) { PERF_TIMER(on_out_peers); size_t n_connections = m_p2p.get_outgoing_connections_count(); @@ -1913,7 +1933,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_in_peers(const COMMAND_RPC_IN_PEERS::request& req, COMMAND_RPC_IN_PEERS::response& res) + bool core_rpc_server::on_in_peers(const COMMAND_RPC_IN_PEERS::request& req, COMMAND_RPC_IN_PEERS::response& res, const connection_context *ctx) { PERF_TIMER(on_in_peers); size_t n_connections = m_p2p.get_incoming_connections_count(); @@ -1925,7 +1945,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_start_save_graph(const COMMAND_RPC_START_SAVE_GRAPH::request& req, COMMAND_RPC_START_SAVE_GRAPH::response& res) + bool core_rpc_server::on_start_save_graph(const COMMAND_RPC_START_SAVE_GRAPH::request& req, COMMAND_RPC_START_SAVE_GRAPH::response& res, const connection_context *ctx) { PERF_TIMER(on_start_save_graph); m_p2p.set_save_graph(true); @@ -1933,7 +1953,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_stop_save_graph(const COMMAND_RPC_STOP_SAVE_GRAPH::request& req, COMMAND_RPC_STOP_SAVE_GRAPH::response& res) + bool core_rpc_server::on_stop_save_graph(const COMMAND_RPC_STOP_SAVE_GRAPH::request& req, COMMAND_RPC_STOP_SAVE_GRAPH::response& res, const connection_context *ctx) { PERF_TIMER(on_stop_save_graph); m_p2p.set_save_graph(false); @@ -1941,7 +1961,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_update(const COMMAND_RPC_UPDATE::request& req, COMMAND_RPC_UPDATE::response& res) + bool core_rpc_server::on_update(const COMMAND_RPC_UPDATE::request& req, COMMAND_RPC_UPDATE::response& res, const connection_context *ctx) { PERF_TIMER(on_update); static const char software[] = "monero"; @@ -2036,7 +2056,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_pop_blocks(const COMMAND_RPC_POP_BLOCKS::request& req, COMMAND_RPC_POP_BLOCKS::response& res) + bool core_rpc_server::on_pop_blocks(const COMMAND_RPC_POP_BLOCKS::request& req, COMMAND_RPC_POP_BLOCKS::response& res, const connection_context *ctx) { PERF_TIMER(on_pop_blocks); @@ -2048,7 +2068,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_relay_tx(const COMMAND_RPC_RELAY_TX::request& req, COMMAND_RPC_RELAY_TX::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_relay_tx(const COMMAND_RPC_RELAY_TX::request& req, COMMAND_RPC_RELAY_TX::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_relay_tx); @@ -2094,7 +2114,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_sync_info(const COMMAND_RPC_SYNC_INFO::request& req, COMMAND_RPC_SYNC_INFO::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_sync_info(const COMMAND_RPC_SYNC_INFO::request& req, COMMAND_RPC_SYNC_INFO::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_sync_info); @@ -2121,7 +2141,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_txpool_backlog(const COMMAND_RPC_GET_TRANSACTION_POOL_BACKLOG::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_BACKLOG::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_get_txpool_backlog(const COMMAND_RPC_GET_TRANSACTION_POOL_BACKLOG::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_BACKLOG::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_get_txpool_backlog); bool r; @@ -2139,7 +2159,7 @@ namespace cryptonote return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool core_rpc_server::on_get_output_distribution(const COMMAND_RPC_GET_OUTPUT_DISTRIBUTION::request& req, COMMAND_RPC_GET_OUTPUT_DISTRIBUTION::response& res, epee::json_rpc::error& error_resp) + bool core_rpc_server::on_get_output_distribution(const COMMAND_RPC_GET_OUTPUT_DISTRIBUTION::request& req, COMMAND_RPC_GET_OUTPUT_DISTRIBUTION::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx) { PERF_TIMER(on_get_output_distribution); bool r; diff --git a/src/rpc/core_rpc_server.h b/src/rpc/core_rpc_server.h index 56d891749..d26a1a08d 100644 --- a/src/rpc/core_rpc_server.h +++ b/src/rpc/core_rpc_server.h @@ -155,66 +155,66 @@ namespace cryptonote END_JSON_RPC_MAP() END_URI_MAP2() - bool on_get_height(const COMMAND_RPC_GET_HEIGHT::request& req, COMMAND_RPC_GET_HEIGHT::response& res); - bool on_get_blocks(const COMMAND_RPC_GET_BLOCKS_FAST::request& req, COMMAND_RPC_GET_BLOCKS_FAST::response& res); - bool on_get_alt_blocks_hashes(const COMMAND_RPC_GET_ALT_BLOCKS_HASHES::request& req, COMMAND_RPC_GET_ALT_BLOCKS_HASHES::response& res); - bool on_get_blocks_by_height(const COMMAND_RPC_GET_BLOCKS_BY_HEIGHT::request& req, COMMAND_RPC_GET_BLOCKS_BY_HEIGHT::response& res); - bool on_get_hashes(const COMMAND_RPC_GET_HASHES_FAST::request& req, COMMAND_RPC_GET_HASHES_FAST::response& res); - bool on_get_transactions(const COMMAND_RPC_GET_TRANSACTIONS::request& req, COMMAND_RPC_GET_TRANSACTIONS::response& res); - bool on_is_key_image_spent(const COMMAND_RPC_IS_KEY_IMAGE_SPENT::request& req, COMMAND_RPC_IS_KEY_IMAGE_SPENT::response& res, bool request_has_rpc_origin = true); - bool on_get_indexes(const COMMAND_RPC_GET_TX_GLOBAL_OUTPUTS_INDEXES::request& req, COMMAND_RPC_GET_TX_GLOBAL_OUTPUTS_INDEXES::response& res); - bool on_send_raw_tx(const COMMAND_RPC_SEND_RAW_TX::request& req, COMMAND_RPC_SEND_RAW_TX::response& res); - bool on_start_mining(const COMMAND_RPC_START_MINING::request& req, COMMAND_RPC_START_MINING::response& res); - bool on_stop_mining(const COMMAND_RPC_STOP_MINING::request& req, COMMAND_RPC_STOP_MINING::response& res); - bool on_mining_status(const COMMAND_RPC_MINING_STATUS::request& req, COMMAND_RPC_MINING_STATUS::response& res); - bool on_get_outs_bin(const COMMAND_RPC_GET_OUTPUTS_BIN::request& req, COMMAND_RPC_GET_OUTPUTS_BIN::response& res); - bool on_get_outs(const COMMAND_RPC_GET_OUTPUTS::request& req, COMMAND_RPC_GET_OUTPUTS::response& res); - bool on_get_info(const COMMAND_RPC_GET_INFO::request& req, COMMAND_RPC_GET_INFO::response& res); - bool on_save_bc(const COMMAND_RPC_SAVE_BC::request& req, COMMAND_RPC_SAVE_BC::response& res); - bool on_get_peer_list(const COMMAND_RPC_GET_PEER_LIST::request& req, COMMAND_RPC_GET_PEER_LIST::response& res); - bool on_set_log_hash_rate(const COMMAND_RPC_SET_LOG_HASH_RATE::request& req, COMMAND_RPC_SET_LOG_HASH_RATE::response& res); - bool on_set_log_level(const COMMAND_RPC_SET_LOG_LEVEL::request& req, COMMAND_RPC_SET_LOG_LEVEL::response& res); - bool on_set_log_categories(const COMMAND_RPC_SET_LOG_CATEGORIES::request& req, COMMAND_RPC_SET_LOG_CATEGORIES::response& res); - bool on_get_transaction_pool(const COMMAND_RPC_GET_TRANSACTION_POOL::request& req, COMMAND_RPC_GET_TRANSACTION_POOL::response& res, bool request_has_rpc_origin = true); - bool on_get_transaction_pool_hashes_bin(const COMMAND_RPC_GET_TRANSACTION_POOL_HASHES_BIN::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_HASHES_BIN::response& res, bool request_has_rpc_origin = true); - bool on_get_transaction_pool_hashes(const COMMAND_RPC_GET_TRANSACTION_POOL_HASHES::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_HASHES::response& res, bool request_has_rpc_origin = true); - bool on_get_transaction_pool_stats(const COMMAND_RPC_GET_TRANSACTION_POOL_STATS::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_STATS::response& res, bool request_has_rpc_origin = true); - bool on_stop_daemon(const COMMAND_RPC_STOP_DAEMON::request& req, COMMAND_RPC_STOP_DAEMON::response& res); - bool on_get_limit(const COMMAND_RPC_GET_LIMIT::request& req, COMMAND_RPC_GET_LIMIT::response& res); - bool on_set_limit(const COMMAND_RPC_SET_LIMIT::request& req, COMMAND_RPC_SET_LIMIT::response& res); - bool on_out_peers(const COMMAND_RPC_OUT_PEERS::request& req, COMMAND_RPC_OUT_PEERS::response& res); - bool on_in_peers(const COMMAND_RPC_IN_PEERS::request& req, COMMAND_RPC_IN_PEERS::response& res); - bool on_start_save_graph(const COMMAND_RPC_START_SAVE_GRAPH::request& req, COMMAND_RPC_START_SAVE_GRAPH::response& res); - bool on_stop_save_graph(const COMMAND_RPC_STOP_SAVE_GRAPH::request& req, COMMAND_RPC_STOP_SAVE_GRAPH::response& res); - bool on_update(const COMMAND_RPC_UPDATE::request& req, COMMAND_RPC_UPDATE::response& res); - bool on_pop_blocks(const COMMAND_RPC_POP_BLOCKS::request& req, COMMAND_RPC_POP_BLOCKS::response& res); + bool on_get_height(const COMMAND_RPC_GET_HEIGHT::request& req, COMMAND_RPC_GET_HEIGHT::response& res, const connection_context *ctx = NULL); + bool on_get_blocks(const COMMAND_RPC_GET_BLOCKS_FAST::request& req, COMMAND_RPC_GET_BLOCKS_FAST::response& res, const connection_context *ctx = NULL); + bool on_get_alt_blocks_hashes(const COMMAND_RPC_GET_ALT_BLOCKS_HASHES::request& req, COMMAND_RPC_GET_ALT_BLOCKS_HASHES::response& res, const connection_context *ctx = NULL); + bool on_get_blocks_by_height(const COMMAND_RPC_GET_BLOCKS_BY_HEIGHT::request& req, COMMAND_RPC_GET_BLOCKS_BY_HEIGHT::response& res, const connection_context *ctx = NULL); + bool on_get_hashes(const COMMAND_RPC_GET_HASHES_FAST::request& req, COMMAND_RPC_GET_HASHES_FAST::response& res, const connection_context *ctx = NULL); + bool on_get_transactions(const COMMAND_RPC_GET_TRANSACTIONS::request& req, COMMAND_RPC_GET_TRANSACTIONS::response& res, const connection_context *ctx = NULL); + bool on_is_key_image_spent(const COMMAND_RPC_IS_KEY_IMAGE_SPENT::request& req, COMMAND_RPC_IS_KEY_IMAGE_SPENT::response& res, const connection_context *ctx = NULL); + bool on_get_indexes(const COMMAND_RPC_GET_TX_GLOBAL_OUTPUTS_INDEXES::request& req, COMMAND_RPC_GET_TX_GLOBAL_OUTPUTS_INDEXES::response& res, const connection_context *ctx = NULL); + bool on_send_raw_tx(const COMMAND_RPC_SEND_RAW_TX::request& req, COMMAND_RPC_SEND_RAW_TX::response& res, const connection_context *ctx = NULL); + bool on_start_mining(const COMMAND_RPC_START_MINING::request& req, COMMAND_RPC_START_MINING::response& res, const connection_context *ctx = NULL); + bool on_stop_mining(const COMMAND_RPC_STOP_MINING::request& req, COMMAND_RPC_STOP_MINING::response& res, const connection_context *ctx = NULL); + bool on_mining_status(const COMMAND_RPC_MINING_STATUS::request& req, COMMAND_RPC_MINING_STATUS::response& res, const connection_context *ctx = NULL); + bool on_get_outs_bin(const COMMAND_RPC_GET_OUTPUTS_BIN::request& req, COMMAND_RPC_GET_OUTPUTS_BIN::response& res, const connection_context *ctx = NULL); + bool on_get_outs(const COMMAND_RPC_GET_OUTPUTS::request& req, COMMAND_RPC_GET_OUTPUTS::response& res, const connection_context *ctx = NULL); + bool on_get_info(const COMMAND_RPC_GET_INFO::request& req, COMMAND_RPC_GET_INFO::response& res, const connection_context *ctx = NULL); + bool on_save_bc(const COMMAND_RPC_SAVE_BC::request& req, COMMAND_RPC_SAVE_BC::response& res, const connection_context *ctx = NULL); + bool on_get_peer_list(const COMMAND_RPC_GET_PEER_LIST::request& req, COMMAND_RPC_GET_PEER_LIST::response& res, const connection_context *ctx = NULL); + bool on_set_log_hash_rate(const COMMAND_RPC_SET_LOG_HASH_RATE::request& req, COMMAND_RPC_SET_LOG_HASH_RATE::response& res, const connection_context *ctx = NULL); + bool on_set_log_level(const COMMAND_RPC_SET_LOG_LEVEL::request& req, COMMAND_RPC_SET_LOG_LEVEL::response& res, const connection_context *ctx = NULL); + bool on_set_log_categories(const COMMAND_RPC_SET_LOG_CATEGORIES::request& req, COMMAND_RPC_SET_LOG_CATEGORIES::response& res, const connection_context *ctx = NULL); + bool on_get_transaction_pool(const COMMAND_RPC_GET_TRANSACTION_POOL::request& req, COMMAND_RPC_GET_TRANSACTION_POOL::response& res, const connection_context *ctx = NULL); + bool on_get_transaction_pool_hashes_bin(const COMMAND_RPC_GET_TRANSACTION_POOL_HASHES_BIN::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_HASHES_BIN::response& res, const connection_context *ctx = NULL); + bool on_get_transaction_pool_hashes(const COMMAND_RPC_GET_TRANSACTION_POOL_HASHES::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_HASHES::response& res, const connection_context *ctx = NULL); + bool on_get_transaction_pool_stats(const COMMAND_RPC_GET_TRANSACTION_POOL_STATS::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_STATS::response& res, const connection_context *ctx = NULL); + bool on_stop_daemon(const COMMAND_RPC_STOP_DAEMON::request& req, COMMAND_RPC_STOP_DAEMON::response& res, const connection_context *ctx = NULL); + bool on_get_limit(const COMMAND_RPC_GET_LIMIT::request& req, COMMAND_RPC_GET_LIMIT::response& res, const connection_context *ctx = NULL); + bool on_set_limit(const COMMAND_RPC_SET_LIMIT::request& req, COMMAND_RPC_SET_LIMIT::response& res, const connection_context *ctx = NULL); + bool on_out_peers(const COMMAND_RPC_OUT_PEERS::request& req, COMMAND_RPC_OUT_PEERS::response& res, const connection_context *ctx = NULL); + bool on_in_peers(const COMMAND_RPC_IN_PEERS::request& req, COMMAND_RPC_IN_PEERS::response& res, const connection_context *ctx = NULL); + bool on_start_save_graph(const COMMAND_RPC_START_SAVE_GRAPH::request& req, COMMAND_RPC_START_SAVE_GRAPH::response& res, const connection_context *ctx = NULL); + bool on_stop_save_graph(const COMMAND_RPC_STOP_SAVE_GRAPH::request& req, COMMAND_RPC_STOP_SAVE_GRAPH::response& res, const connection_context *ctx = NULL); + bool on_update(const COMMAND_RPC_UPDATE::request& req, COMMAND_RPC_UPDATE::response& res, const connection_context *ctx = NULL); + bool on_pop_blocks(const COMMAND_RPC_POP_BLOCKS::request& req, COMMAND_RPC_POP_BLOCKS::response& res, const connection_context *ctx = NULL); //json_rpc - bool on_getblockcount(const COMMAND_RPC_GETBLOCKCOUNT::request& req, COMMAND_RPC_GETBLOCKCOUNT::response& res); - bool on_getblockhash(const COMMAND_RPC_GETBLOCKHASH::request& req, COMMAND_RPC_GETBLOCKHASH::response& res, epee::json_rpc::error& error_resp); - bool on_getblocktemplate(const COMMAND_RPC_GETBLOCKTEMPLATE::request& req, COMMAND_RPC_GETBLOCKTEMPLATE::response& res, epee::json_rpc::error& error_resp); - bool on_submitblock(const COMMAND_RPC_SUBMITBLOCK::request& req, COMMAND_RPC_SUBMITBLOCK::response& res, epee::json_rpc::error& error_resp); - bool on_generateblocks(const COMMAND_RPC_GENERATEBLOCKS::request& req, COMMAND_RPC_GENERATEBLOCKS::response& res, epee::json_rpc::error& error_resp); - bool on_get_last_block_header(const COMMAND_RPC_GET_LAST_BLOCK_HEADER::request& req, COMMAND_RPC_GET_LAST_BLOCK_HEADER::response& res, epee::json_rpc::error& error_resp); - bool on_get_block_header_by_hash(const COMMAND_RPC_GET_BLOCK_HEADER_BY_HASH::request& req, COMMAND_RPC_GET_BLOCK_HEADER_BY_HASH::response& res, epee::json_rpc::error& error_resp); - bool on_get_block_header_by_height(const COMMAND_RPC_GET_BLOCK_HEADER_BY_HEIGHT::request& req, COMMAND_RPC_GET_BLOCK_HEADER_BY_HEIGHT::response& res, epee::json_rpc::error& error_resp); - bool on_get_block_headers_range(const COMMAND_RPC_GET_BLOCK_HEADERS_RANGE::request& req, COMMAND_RPC_GET_BLOCK_HEADERS_RANGE::response& res, epee::json_rpc::error& error_resp); - bool on_get_block(const COMMAND_RPC_GET_BLOCK::request& req, COMMAND_RPC_GET_BLOCK::response& res, epee::json_rpc::error& error_resp); - bool on_get_connections(const COMMAND_RPC_GET_CONNECTIONS::request& req, COMMAND_RPC_GET_CONNECTIONS::response& res, epee::json_rpc::error& error_resp); - bool on_get_info_json(const COMMAND_RPC_GET_INFO::request& req, COMMAND_RPC_GET_INFO::response& res, epee::json_rpc::error& error_resp); - bool on_hard_fork_info(const COMMAND_RPC_HARD_FORK_INFO::request& req, COMMAND_RPC_HARD_FORK_INFO::response& res, epee::json_rpc::error& error_resp); - bool on_set_bans(const COMMAND_RPC_SETBANS::request& req, COMMAND_RPC_SETBANS::response& res, epee::json_rpc::error& error_resp); - bool on_get_bans(const COMMAND_RPC_GETBANS::request& req, COMMAND_RPC_GETBANS::response& res, epee::json_rpc::error& error_resp); - bool on_flush_txpool(const COMMAND_RPC_FLUSH_TRANSACTION_POOL::request& req, COMMAND_RPC_FLUSH_TRANSACTION_POOL::response& res, epee::json_rpc::error& error_resp); - bool on_get_output_histogram(const COMMAND_RPC_GET_OUTPUT_HISTOGRAM::request& req, COMMAND_RPC_GET_OUTPUT_HISTOGRAM::response& res, epee::json_rpc::error& error_resp); - bool on_get_version(const COMMAND_RPC_GET_VERSION::request& req, COMMAND_RPC_GET_VERSION::response& res, epee::json_rpc::error& error_resp); - bool on_get_coinbase_tx_sum(const COMMAND_RPC_GET_COINBASE_TX_SUM::request& req, COMMAND_RPC_GET_COINBASE_TX_SUM::response& res, epee::json_rpc::error& error_resp); - bool on_get_base_fee_estimate(const COMMAND_RPC_GET_BASE_FEE_ESTIMATE::request& req, COMMAND_RPC_GET_BASE_FEE_ESTIMATE::response& res, epee::json_rpc::error& error_resp); - bool on_get_alternate_chains(const COMMAND_RPC_GET_ALTERNATE_CHAINS::request& req, COMMAND_RPC_GET_ALTERNATE_CHAINS::response& res, epee::json_rpc::error& error_resp); - bool on_relay_tx(const COMMAND_RPC_RELAY_TX::request& req, COMMAND_RPC_RELAY_TX::response& res, epee::json_rpc::error& error_resp); - bool on_sync_info(const COMMAND_RPC_SYNC_INFO::request& req, COMMAND_RPC_SYNC_INFO::response& res, epee::json_rpc::error& error_resp); - bool on_get_txpool_backlog(const COMMAND_RPC_GET_TRANSACTION_POOL_BACKLOG::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_BACKLOG::response& res, epee::json_rpc::error& error_resp); - bool on_get_output_distribution(const COMMAND_RPC_GET_OUTPUT_DISTRIBUTION::request& req, COMMAND_RPC_GET_OUTPUT_DISTRIBUTION::response& res, epee::json_rpc::error& error_resp); + bool on_getblockcount(const COMMAND_RPC_GETBLOCKCOUNT::request& req, COMMAND_RPC_GETBLOCKCOUNT::response& res, const connection_context *ctx = NULL); + bool on_getblockhash(const COMMAND_RPC_GETBLOCKHASH::request& req, COMMAND_RPC_GETBLOCKHASH::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_getblocktemplate(const COMMAND_RPC_GETBLOCKTEMPLATE::request& req, COMMAND_RPC_GETBLOCKTEMPLATE::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_submitblock(const COMMAND_RPC_SUBMITBLOCK::request& req, COMMAND_RPC_SUBMITBLOCK::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_generateblocks(const COMMAND_RPC_GENERATEBLOCKS::request& req, COMMAND_RPC_GENERATEBLOCKS::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_last_block_header(const COMMAND_RPC_GET_LAST_BLOCK_HEADER::request& req, COMMAND_RPC_GET_LAST_BLOCK_HEADER::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_block_header_by_hash(const COMMAND_RPC_GET_BLOCK_HEADER_BY_HASH::request& req, COMMAND_RPC_GET_BLOCK_HEADER_BY_HASH::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_block_header_by_height(const COMMAND_RPC_GET_BLOCK_HEADER_BY_HEIGHT::request& req, COMMAND_RPC_GET_BLOCK_HEADER_BY_HEIGHT::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_block_headers_range(const COMMAND_RPC_GET_BLOCK_HEADERS_RANGE::request& req, COMMAND_RPC_GET_BLOCK_HEADERS_RANGE::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_block(const COMMAND_RPC_GET_BLOCK::request& req, COMMAND_RPC_GET_BLOCK::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_connections(const COMMAND_RPC_GET_CONNECTIONS::request& req, COMMAND_RPC_GET_CONNECTIONS::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_info_json(const COMMAND_RPC_GET_INFO::request& req, COMMAND_RPC_GET_INFO::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_hard_fork_info(const COMMAND_RPC_HARD_FORK_INFO::request& req, COMMAND_RPC_HARD_FORK_INFO::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_set_bans(const COMMAND_RPC_SETBANS::request& req, COMMAND_RPC_SETBANS::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_bans(const COMMAND_RPC_GETBANS::request& req, COMMAND_RPC_GETBANS::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_flush_txpool(const COMMAND_RPC_FLUSH_TRANSACTION_POOL::request& req, COMMAND_RPC_FLUSH_TRANSACTION_POOL::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_output_histogram(const COMMAND_RPC_GET_OUTPUT_HISTOGRAM::request& req, COMMAND_RPC_GET_OUTPUT_HISTOGRAM::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_version(const COMMAND_RPC_GET_VERSION::request& req, COMMAND_RPC_GET_VERSION::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_coinbase_tx_sum(const COMMAND_RPC_GET_COINBASE_TX_SUM::request& req, COMMAND_RPC_GET_COINBASE_TX_SUM::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_base_fee_estimate(const COMMAND_RPC_GET_BASE_FEE_ESTIMATE::request& req, COMMAND_RPC_GET_BASE_FEE_ESTIMATE::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_alternate_chains(const COMMAND_RPC_GET_ALTERNATE_CHAINS::request& req, COMMAND_RPC_GET_ALTERNATE_CHAINS::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_relay_tx(const COMMAND_RPC_RELAY_TX::request& req, COMMAND_RPC_RELAY_TX::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_sync_info(const COMMAND_RPC_SYNC_INFO::request& req, COMMAND_RPC_SYNC_INFO::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_txpool_backlog(const COMMAND_RPC_GET_TRANSACTION_POOL_BACKLOG::request& req, COMMAND_RPC_GET_TRANSACTION_POOL_BACKLOG::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); + bool on_get_output_distribution(const COMMAND_RPC_GET_OUTPUT_DISTRIBUTION::request& req, COMMAND_RPC_GET_OUTPUT_DISTRIBUTION::response& res, epee::json_rpc::error& error_resp, const connection_context *ctx = NULL); //----------------------- private: diff --git a/src/wallet/wallet_rpc_server.cpp b/src/wallet/wallet_rpc_server.cpp index f27441b91..6702d2cc0 100644 --- a/src/wallet/wallet_rpc_server.cpp +++ b/src/wallet/wallet_rpc_server.cpp @@ -332,7 +332,7 @@ namespace tools set_confirmations(entry, m_wallet->get_blockchain_current_height(), m_wallet->get_last_block_reward()); } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_getbalance(const wallet_rpc::COMMAND_RPC_GET_BALANCE::request& req, wallet_rpc::COMMAND_RPC_GET_BALANCE::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_getbalance(const wallet_rpc::COMMAND_RPC_GET_BALANCE::request& req, wallet_rpc::COMMAND_RPC_GET_BALANCE::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -371,7 +371,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_getaddress(const wallet_rpc::COMMAND_RPC_GET_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_GET_ADDRESS::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_getaddress(const wallet_rpc::COMMAND_RPC_GET_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_GET_ADDRESS::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -411,7 +411,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_getaddress_index(const wallet_rpc::COMMAND_RPC_GET_ADDRESS_INDEX::request& req, wallet_rpc::COMMAND_RPC_GET_ADDRESS_INDEX::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_getaddress_index(const wallet_rpc::COMMAND_RPC_GET_ADDRESS_INDEX::request& req, wallet_rpc::COMMAND_RPC_GET_ADDRESS_INDEX::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); cryptonote::address_parse_info info; @@ -432,7 +432,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_create_address(const wallet_rpc::COMMAND_RPC_CREATE_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_CREATE_ADDRESS::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_create_address(const wallet_rpc::COMMAND_RPC_CREATE_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_CREATE_ADDRESS::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -449,7 +449,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_label_address(const wallet_rpc::COMMAND_RPC_LABEL_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_LABEL_ADDRESS::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_label_address(const wallet_rpc::COMMAND_RPC_LABEL_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_LABEL_ADDRESS::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -464,7 +464,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_get_accounts(const wallet_rpc::COMMAND_RPC_GET_ACCOUNTS::request& req, wallet_rpc::COMMAND_RPC_GET_ACCOUNTS::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_accounts(const wallet_rpc::COMMAND_RPC_GET_ACCOUNTS::request& req, wallet_rpc::COMMAND_RPC_GET_ACCOUNTS::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -503,7 +503,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_create_account(const wallet_rpc::COMMAND_RPC_CREATE_ACCOUNT::request& req, wallet_rpc::COMMAND_RPC_CREATE_ACCOUNT::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_create_account(const wallet_rpc::COMMAND_RPC_CREATE_ACCOUNT::request& req, wallet_rpc::COMMAND_RPC_CREATE_ACCOUNT::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -520,7 +520,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_label_account(const wallet_rpc::COMMAND_RPC_LABEL_ACCOUNT::request& req, wallet_rpc::COMMAND_RPC_LABEL_ACCOUNT::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_label_account(const wallet_rpc::COMMAND_RPC_LABEL_ACCOUNT::request& req, wallet_rpc::COMMAND_RPC_LABEL_ACCOUNT::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -535,7 +535,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_get_account_tags(const wallet_rpc::COMMAND_RPC_GET_ACCOUNT_TAGS::request& req, wallet_rpc::COMMAND_RPC_GET_ACCOUNT_TAGS::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_account_tags(const wallet_rpc::COMMAND_RPC_GET_ACCOUNT_TAGS::request& req, wallet_rpc::COMMAND_RPC_GET_ACCOUNT_TAGS::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); const std::pair, std::vector> account_tags = m_wallet->get_account_tags(); @@ -554,7 +554,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_tag_accounts(const wallet_rpc::COMMAND_RPC_TAG_ACCOUNTS::request& req, wallet_rpc::COMMAND_RPC_TAG_ACCOUNTS::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_tag_accounts(const wallet_rpc::COMMAND_RPC_TAG_ACCOUNTS::request& req, wallet_rpc::COMMAND_RPC_TAG_ACCOUNTS::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -569,7 +569,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_untag_accounts(const wallet_rpc::COMMAND_RPC_UNTAG_ACCOUNTS::request& req, wallet_rpc::COMMAND_RPC_UNTAG_ACCOUNTS::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_untag_accounts(const wallet_rpc::COMMAND_RPC_UNTAG_ACCOUNTS::request& req, wallet_rpc::COMMAND_RPC_UNTAG_ACCOUNTS::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -584,7 +584,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_set_account_tag_description(const wallet_rpc::COMMAND_RPC_SET_ACCOUNT_TAG_DESCRIPTION::request& req, wallet_rpc::COMMAND_RPC_SET_ACCOUNT_TAG_DESCRIPTION::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_set_account_tag_description(const wallet_rpc::COMMAND_RPC_SET_ACCOUNT_TAG_DESCRIPTION::request& req, wallet_rpc::COMMAND_RPC_SET_ACCOUNT_TAG_DESCRIPTION::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -599,7 +599,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_getheight(const wallet_rpc::COMMAND_RPC_GET_HEIGHT::request& req, wallet_rpc::COMMAND_RPC_GET_HEIGHT::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_getheight(const wallet_rpc::COMMAND_RPC_GET_HEIGHT::request& req, wallet_rpc::COMMAND_RPC_GET_HEIGHT::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -813,7 +813,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_transfer(const wallet_rpc::COMMAND_RPC_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_TRANSFER::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_transfer(const wallet_rpc::COMMAND_RPC_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_TRANSFER::response& res, epee::json_rpc::error& er, const connection_context *ctx) { std::vector dsts; @@ -874,7 +874,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_transfer_split(const wallet_rpc::COMMAND_RPC_TRANSFER_SPLIT::request& req, wallet_rpc::COMMAND_RPC_TRANSFER_SPLIT::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_transfer_split(const wallet_rpc::COMMAND_RPC_TRANSFER_SPLIT::request& req, wallet_rpc::COMMAND_RPC_TRANSFER_SPLIT::response& res, epee::json_rpc::error& er, const connection_context *ctx) { std::vector dsts; @@ -921,7 +921,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_sign_transfer(const wallet_rpc::COMMAND_RPC_SIGN_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_SIGN_TRANSFER::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_sign_transfer(const wallet_rpc::COMMAND_RPC_SIGN_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_SIGN_TRANSFER::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -1002,7 +1002,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_describe_transfer(const wallet_rpc::COMMAND_RPC_DESCRIBE_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_DESCRIBE_TRANSFER::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_describe_transfer(const wallet_rpc::COMMAND_RPC_DESCRIBE_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_DESCRIBE_TRANSFER::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -1167,7 +1167,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_submit_transfer(const wallet_rpc::COMMAND_RPC_SUBMIT_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_SUBMIT_TRANSFER::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_submit_transfer(const wallet_rpc::COMMAND_RPC_SUBMIT_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_SUBMIT_TRANSFER::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -1227,7 +1227,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_sweep_dust(const wallet_rpc::COMMAND_RPC_SWEEP_DUST::request& req, wallet_rpc::COMMAND_RPC_SWEEP_DUST::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_sweep_dust(const wallet_rpc::COMMAND_RPC_SWEEP_DUST::request& req, wallet_rpc::COMMAND_RPC_SWEEP_DUST::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -1252,7 +1252,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::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 wallet_rpc_server::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, const connection_context *ctx) { std::vector dsts; std::vector extra; @@ -1307,7 +1307,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::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 wallet_rpc_server::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, const connection_context *ctx) { std::vector dsts; std::vector extra; @@ -1396,7 +1396,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::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 wallet_rpc_server::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, const connection_context *ctx) { if (!m_wallet) return not_open(er); @@ -1438,7 +1438,7 @@ namespace tools 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) + 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, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -1502,7 +1502,7 @@ namespace tools 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) + 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, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -1533,7 +1533,7 @@ namespace tools 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, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -1555,7 +1555,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::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 wallet_rpc_server::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, const connection_context *ctx) { if (!m_wallet) return not_open(er); crypto::hash payment_id; @@ -1604,7 +1604,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::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 wallet_rpc_server::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, const connection_context *ctx) { res.payments.clear(); if (!m_wallet) return not_open(er); @@ -1683,7 +1683,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_incoming_transfers(const wallet_rpc::COMMAND_RPC_INCOMING_TRANSFERS::request& req, wallet_rpc::COMMAND_RPC_INCOMING_TRANSFERS::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_incoming_transfers(const wallet_rpc::COMMAND_RPC_INCOMING_TRANSFERS::request& req, wallet_rpc::COMMAND_RPC_INCOMING_TRANSFERS::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if(req.transfer_type.compare("all") != 0 && req.transfer_type.compare("available") != 0 && req.transfer_type.compare("unavailable") != 0) @@ -1735,7 +1735,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_query_key(const wallet_rpc::COMMAND_RPC_QUERY_KEY::request& req, wallet_rpc::COMMAND_RPC_QUERY_KEY::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_query_key(const wallet_rpc::COMMAND_RPC_QUERY_KEY::request& req, wallet_rpc::COMMAND_RPC_QUERY_KEY::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -1806,7 +1806,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_rescan_blockchain(const wallet_rpc::COMMAND_RPC_RESCAN_BLOCKCHAIN::request& req, wallet_rpc::COMMAND_RPC_RESCAN_BLOCKCHAIN::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_rescan_blockchain(const wallet_rpc::COMMAND_RPC_RESCAN_BLOCKCHAIN::request& req, wallet_rpc::COMMAND_RPC_RESCAN_BLOCKCHAIN::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -1828,7 +1828,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_sign(const wallet_rpc::COMMAND_RPC_SIGN::request& req, wallet_rpc::COMMAND_RPC_SIGN::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_sign(const wallet_rpc::COMMAND_RPC_SIGN::request& req, wallet_rpc::COMMAND_RPC_SIGN::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -1842,7 +1842,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_verify(const wallet_rpc::COMMAND_RPC_VERIFY::request& req, wallet_rpc::COMMAND_RPC_VERIFY::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_verify(const wallet_rpc::COMMAND_RPC_VERIFY::request& req, wallet_rpc::COMMAND_RPC_VERIFY::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -1877,7 +1877,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_stop_wallet(const wallet_rpc::COMMAND_RPC_STOP_WALLET::request& req, wallet_rpc::COMMAND_RPC_STOP_WALLET::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_stop_wallet(const wallet_rpc::COMMAND_RPC_STOP_WALLET::request& req, wallet_rpc::COMMAND_RPC_STOP_WALLET::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -1900,7 +1900,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_set_tx_notes(const wallet_rpc::COMMAND_RPC_SET_TX_NOTES::request& req, wallet_rpc::COMMAND_RPC_SET_TX_NOTES::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_set_tx_notes(const wallet_rpc::COMMAND_RPC_SET_TX_NOTES::request& req, wallet_rpc::COMMAND_RPC_SET_TX_NOTES::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -1943,7 +1943,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_get_tx_notes(const wallet_rpc::COMMAND_RPC_GET_TX_NOTES::request& req, wallet_rpc::COMMAND_RPC_GET_TX_NOTES::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_tx_notes(const wallet_rpc::COMMAND_RPC_GET_TX_NOTES::request& req, wallet_rpc::COMMAND_RPC_GET_TX_NOTES::response& res, epee::json_rpc::error& er, const connection_context *ctx) { res.notes.clear(); if (!m_wallet) return not_open(er); @@ -1972,7 +1972,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_set_attribute(const wallet_rpc::COMMAND_RPC_SET_ATTRIBUTE::request& req, wallet_rpc::COMMAND_RPC_SET_ATTRIBUTE::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_set_attribute(const wallet_rpc::COMMAND_RPC_SET_ATTRIBUTE::request& req, wallet_rpc::COMMAND_RPC_SET_ATTRIBUTE::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -1987,7 +1987,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_get_attribute(const wallet_rpc::COMMAND_RPC_GET_ATTRIBUTE::request& req, wallet_rpc::COMMAND_RPC_GET_ATTRIBUTE::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_attribute(const wallet_rpc::COMMAND_RPC_GET_ATTRIBUTE::request& req, wallet_rpc::COMMAND_RPC_GET_ATTRIBUTE::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -2000,7 +2000,7 @@ namespace tools res.value = m_wallet->get_attribute(req.key); return true; } - bool wallet_rpc_server::on_get_tx_key(const wallet_rpc::COMMAND_RPC_GET_TX_KEY::request& req, wallet_rpc::COMMAND_RPC_GET_TX_KEY::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_tx_key(const wallet_rpc::COMMAND_RPC_GET_TX_KEY::request& req, wallet_rpc::COMMAND_RPC_GET_TX_KEY::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); @@ -2029,7 +2029,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_check_tx_key(const wallet_rpc::COMMAND_RPC_CHECK_TX_KEY::request& req, wallet_rpc::COMMAND_RPC_CHECK_TX_KEY::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_check_tx_key(const wallet_rpc::COMMAND_RPC_CHECK_TX_KEY::request& req, wallet_rpc::COMMAND_RPC_CHECK_TX_KEY::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); @@ -2091,7 +2091,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_get_tx_proof(const wallet_rpc::COMMAND_RPC_GET_TX_PROOF::request& req, wallet_rpc::COMMAND_RPC_GET_TX_PROOF::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_tx_proof(const wallet_rpc::COMMAND_RPC_GET_TX_PROOF::request& req, wallet_rpc::COMMAND_RPC_GET_TX_PROOF::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); @@ -2124,7 +2124,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_check_tx_proof(const wallet_rpc::COMMAND_RPC_CHECK_TX_PROOF::request& req, wallet_rpc::COMMAND_RPC_CHECK_TX_PROOF::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_check_tx_proof(const wallet_rpc::COMMAND_RPC_CHECK_TX_PROOF::request& req, wallet_rpc::COMMAND_RPC_CHECK_TX_PROOF::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); @@ -2160,7 +2160,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_get_spend_proof(const wallet_rpc::COMMAND_RPC_GET_SPEND_PROOF::request& req, wallet_rpc::COMMAND_RPC_GET_SPEND_PROOF::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_spend_proof(const wallet_rpc::COMMAND_RPC_GET_SPEND_PROOF::request& req, wallet_rpc::COMMAND_RPC_GET_SPEND_PROOF::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); @@ -2185,7 +2185,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_check_spend_proof(const wallet_rpc::COMMAND_RPC_CHECK_SPEND_PROOF::request& req, wallet_rpc::COMMAND_RPC_CHECK_SPEND_PROOF::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_check_spend_proof(const wallet_rpc::COMMAND_RPC_CHECK_SPEND_PROOF::request& req, wallet_rpc::COMMAND_RPC_CHECK_SPEND_PROOF::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); @@ -2210,7 +2210,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_get_reserve_proof(const wallet_rpc::COMMAND_RPC_GET_RESERVE_PROOF::request& req, wallet_rpc::COMMAND_RPC_GET_RESERVE_PROOF::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_reserve_proof(const wallet_rpc::COMMAND_RPC_GET_RESERVE_PROOF::request& req, wallet_rpc::COMMAND_RPC_GET_RESERVE_PROOF::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); @@ -2239,7 +2239,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_check_reserve_proof(const wallet_rpc::COMMAND_RPC_CHECK_RESERVE_PROOF::request& req, wallet_rpc::COMMAND_RPC_CHECK_RESERVE_PROOF::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_check_reserve_proof(const wallet_rpc::COMMAND_RPC_CHECK_RESERVE_PROOF::request& req, wallet_rpc::COMMAND_RPC_CHECK_RESERVE_PROOF::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); @@ -2270,7 +2270,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_get_transfers(const wallet_rpc::COMMAND_RPC_GET_TRANSFERS::request& req, wallet_rpc::COMMAND_RPC_GET_TRANSFERS::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_transfers(const wallet_rpc::COMMAND_RPC_GET_TRANSFERS::request& req, wallet_rpc::COMMAND_RPC_GET_TRANSFERS::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -2336,7 +2336,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_get_transfer_by_txid(const wallet_rpc::COMMAND_RPC_GET_TRANSFER_BY_TXID::request& req, wallet_rpc::COMMAND_RPC_GET_TRANSFER_BY_TXID::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_transfer_by_txid(const wallet_rpc::COMMAND_RPC_GET_TRANSFER_BY_TXID::request& req, wallet_rpc::COMMAND_RPC_GET_TRANSFER_BY_TXID::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -2426,7 +2426,7 @@ namespace tools return false; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_export_outputs(const wallet_rpc::COMMAND_RPC_EXPORT_OUTPUTS::request& req, wallet_rpc::COMMAND_RPC_EXPORT_OUTPUTS::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_export_outputs(const wallet_rpc::COMMAND_RPC_EXPORT_OUTPUTS::request& req, wallet_rpc::COMMAND_RPC_EXPORT_OUTPUTS::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -2455,7 +2455,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_import_outputs(const wallet_rpc::COMMAND_RPC_IMPORT_OUTPUTS::request& req, wallet_rpc::COMMAND_RPC_IMPORT_OUTPUTS::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_import_outputs(const wallet_rpc::COMMAND_RPC_IMPORT_OUTPUTS::request& req, wallet_rpc::COMMAND_RPC_IMPORT_OUTPUTS::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -2492,7 +2492,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_export_key_images(const wallet_rpc::COMMAND_RPC_EXPORT_KEY_IMAGES::request& req, wallet_rpc::COMMAND_RPC_EXPORT_KEY_IMAGES::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_export_key_images(const wallet_rpc::COMMAND_RPC_EXPORT_KEY_IMAGES::request& req, wallet_rpc::COMMAND_RPC_EXPORT_KEY_IMAGES::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); try @@ -2516,7 +2516,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_import_key_images(const wallet_rpc::COMMAND_RPC_IMPORT_KEY_IMAGES::request& req, wallet_rpc::COMMAND_RPC_IMPORT_KEY_IMAGES::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_import_key_images(const wallet_rpc::COMMAND_RPC_IMPORT_KEY_IMAGES::request& req, wallet_rpc::COMMAND_RPC_IMPORT_KEY_IMAGES::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -2571,7 +2571,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_make_uri(const wallet_rpc::COMMAND_RPC_MAKE_URI::request& req, wallet_rpc::COMMAND_RPC_MAKE_URI::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_make_uri(const wallet_rpc::COMMAND_RPC_MAKE_URI::request& req, wallet_rpc::COMMAND_RPC_MAKE_URI::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); std::string error; @@ -2587,7 +2587,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_parse_uri(const wallet_rpc::COMMAND_RPC_PARSE_URI::request& req, wallet_rpc::COMMAND_RPC_PARSE_URI::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_parse_uri(const wallet_rpc::COMMAND_RPC_PARSE_URI::request& req, wallet_rpc::COMMAND_RPC_PARSE_URI::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); std::string error; @@ -2600,7 +2600,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_get_address_book(const wallet_rpc::COMMAND_RPC_GET_ADDRESS_BOOK_ENTRY::request& req, wallet_rpc::COMMAND_RPC_GET_ADDRESS_BOOK_ENTRY::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_address_book(const wallet_rpc::COMMAND_RPC_GET_ADDRESS_BOOK_ENTRY::request& req, wallet_rpc::COMMAND_RPC_GET_ADDRESS_BOOK_ENTRY::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); const auto ab = m_wallet->get_address_book(); @@ -2627,7 +2627,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_add_address_book(const wallet_rpc::COMMAND_RPC_ADD_ADDRESS_BOOK_ENTRY::request& req, wallet_rpc::COMMAND_RPC_ADD_ADDRESS_BOOK_ENTRY::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_add_address_book(const wallet_rpc::COMMAND_RPC_ADD_ADDRESS_BOOK_ENTRY::request& req, wallet_rpc::COMMAND_RPC_ADD_ADDRESS_BOOK_ENTRY::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -2702,7 +2702,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_delete_address_book(const wallet_rpc::COMMAND_RPC_DELETE_ADDRESS_BOOK_ENTRY::request& req, wallet_rpc::COMMAND_RPC_DELETE_ADDRESS_BOOK_ENTRY::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_delete_address_book(const wallet_rpc::COMMAND_RPC_DELETE_ADDRESS_BOOK_ENTRY::request& req, wallet_rpc::COMMAND_RPC_DELETE_ADDRESS_BOOK_ENTRY::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -2728,7 +2728,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_refresh(const wallet_rpc::COMMAND_RPC_REFRESH::request& req, wallet_rpc::COMMAND_RPC_REFRESH::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_refresh(const wallet_rpc::COMMAND_RPC_REFRESH::request& req, wallet_rpc::COMMAND_RPC_REFRESH::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -2750,7 +2750,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_rescan_spent(const wallet_rpc::COMMAND_RPC_RESCAN_SPENT::request& req, wallet_rpc::COMMAND_RPC_RESCAN_SPENT::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_rescan_spent(const wallet_rpc::COMMAND_RPC_RESCAN_SPENT::request& req, wallet_rpc::COMMAND_RPC_RESCAN_SPENT::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -2772,7 +2772,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_start_mining(const wallet_rpc::COMMAND_RPC_START_MINING::request& req, wallet_rpc::COMMAND_RPC_START_MINING::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_start_mining(const wallet_rpc::COMMAND_RPC_START_MINING::request& req, wallet_rpc::COMMAND_RPC_START_MINING::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (!m_wallet->is_trusted_daemon()) @@ -2807,7 +2807,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_stop_mining(const wallet_rpc::COMMAND_RPC_STOP_MINING::request& req, wallet_rpc::COMMAND_RPC_STOP_MINING::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_stop_mining(const wallet_rpc::COMMAND_RPC_STOP_MINING::request& req, wallet_rpc::COMMAND_RPC_STOP_MINING::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); cryptonote::COMMAND_RPC_STOP_MINING::request daemon_req; @@ -2822,13 +2822,13 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_get_languages(const wallet_rpc::COMMAND_RPC_GET_LANGUAGES::request& req, wallet_rpc::COMMAND_RPC_GET_LANGUAGES::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_languages(const wallet_rpc::COMMAND_RPC_GET_LANGUAGES::request& req, wallet_rpc::COMMAND_RPC_GET_LANGUAGES::response& res, epee::json_rpc::error& er, const connection_context *ctx) { crypto::ElectrumWords::get_language_list(res.languages); return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_create_wallet(const wallet_rpc::COMMAND_RPC_CREATE_WALLET::request& req, wallet_rpc::COMMAND_RPC_CREATE_WALLET::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_create_wallet(const wallet_rpc::COMMAND_RPC_CREATE_WALLET::request& req, wallet_rpc::COMMAND_RPC_CREATE_WALLET::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (m_wallet_dir.empty()) { @@ -2928,7 +2928,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_open_wallet(const wallet_rpc::COMMAND_RPC_OPEN_WALLET::request& req, wallet_rpc::COMMAND_RPC_OPEN_WALLET::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_open_wallet(const wallet_rpc::COMMAND_RPC_OPEN_WALLET::request& req, wallet_rpc::COMMAND_RPC_OPEN_WALLET::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (m_wallet_dir.empty()) { @@ -2998,7 +2998,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_close_wallet(const wallet_rpc::COMMAND_RPC_CLOSE_WALLET::request& req, wallet_rpc::COMMAND_RPC_CLOSE_WALLET::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_close_wallet(const wallet_rpc::COMMAND_RPC_CLOSE_WALLET::request& req, wallet_rpc::COMMAND_RPC_CLOSE_WALLET::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); @@ -3016,7 +3016,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_change_wallet_password(const wallet_rpc::COMMAND_RPC_CHANGE_WALLET_PASSWORD::request& req, wallet_rpc::COMMAND_RPC_CHANGE_WALLET_PASSWORD::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_change_wallet_password(const wallet_rpc::COMMAND_RPC_CHANGE_WALLET_PASSWORD::request& req, wallet_rpc::COMMAND_RPC_CHANGE_WALLET_PASSWORD::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -3129,7 +3129,7 @@ namespace tools } } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_restore_deterministic_wallet(const wallet_rpc::COMMAND_RPC_RESTORE_DETERMINISTIC_WALLET::request &req, wallet_rpc::COMMAND_RPC_RESTORE_DETERMINISTIC_WALLET::response &res, epee::json_rpc::error &er) + bool wallet_rpc_server::on_restore_deterministic_wallet(const wallet_rpc::COMMAND_RPC_RESTORE_DETERMINISTIC_WALLET::request &req, wallet_rpc::COMMAND_RPC_RESTORE_DETERMINISTIC_WALLET::response &res, epee::json_rpc::error &er, const connection_context *ctx) { if (m_wallet_dir.empty()) { @@ -3323,14 +3323,14 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_is_multisig(const wallet_rpc::COMMAND_RPC_IS_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_IS_MULTISIG::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_is_multisig(const wallet_rpc::COMMAND_RPC_IS_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_IS_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); res.multisig = m_wallet->multisig(&res.ready, &res.threshold, &res.total); return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_prepare_multisig(const wallet_rpc::COMMAND_RPC_PREPARE_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_PREPARE_MULTISIG::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_prepare_multisig(const wallet_rpc::COMMAND_RPC_PREPARE_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_PREPARE_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -3356,7 +3356,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_make_multisig(const wallet_rpc::COMMAND_RPC_MAKE_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_MAKE_MULTISIG::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_make_multisig(const wallet_rpc::COMMAND_RPC_MAKE_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_MAKE_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -3393,7 +3393,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_export_multisig(const wallet_rpc::COMMAND_RPC_EXPORT_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_EXPORT_MULTISIG::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_export_multisig(const wallet_rpc::COMMAND_RPC_EXPORT_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_EXPORT_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -3433,7 +3433,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_import_multisig(const wallet_rpc::COMMAND_RPC_IMPORT_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_IMPORT_MULTISIG::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_import_multisig(const wallet_rpc::COMMAND_RPC_IMPORT_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_IMPORT_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -3506,7 +3506,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_finalize_multisig(const wallet_rpc::COMMAND_RPC_FINALIZE_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_FINALIZE_MULTISIG::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_finalize_multisig(const wallet_rpc::COMMAND_RPC_FINALIZE_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_FINALIZE_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -3557,7 +3557,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_exchange_multisig_keys(const wallet_rpc::COMMAND_RPC_EXCHANGE_MULTISIG_KEYS::request& req, wallet_rpc::COMMAND_RPC_EXCHANGE_MULTISIG_KEYS::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_exchange_multisig_keys(const wallet_rpc::COMMAND_RPC_EXCHANGE_MULTISIG_KEYS::request& req, wallet_rpc::COMMAND_RPC_EXCHANGE_MULTISIG_KEYS::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -3606,7 +3606,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_sign_multisig(const wallet_rpc::COMMAND_RPC_SIGN_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_SIGN_MULTISIG::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_sign_multisig(const wallet_rpc::COMMAND_RPC_SIGN_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_SIGN_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -3675,7 +3675,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_submit_multisig(const wallet_rpc::COMMAND_RPC_SUBMIT_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_SUBMIT_MULTISIG::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_submit_multisig(const wallet_rpc::COMMAND_RPC_SUBMIT_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_SUBMIT_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx) { if (!m_wallet) return not_open(er); if (m_restricted) @@ -3741,7 +3741,7 @@ namespace tools return true; } //------------------------------------------------------------------------------------------------------------------------------ - bool wallet_rpc_server::on_get_version(const wallet_rpc::COMMAND_RPC_GET_VERSION::request& req, wallet_rpc::COMMAND_RPC_GET_VERSION::response& res, epee::json_rpc::error& er) + bool wallet_rpc_server::on_get_version(const wallet_rpc::COMMAND_RPC_GET_VERSION::request& req, wallet_rpc::COMMAND_RPC_GET_VERSION::response& res, epee::json_rpc::error& er, const connection_context *ctx) { res.version = WALLET_RPC_VERSION; return true; diff --git a/src/wallet/wallet_rpc_server.h b/src/wallet/wallet_rpc_server.h index 18ed45ff8..f16a311a6 100644 --- a/src/wallet/wallet_rpc_server.h +++ b/src/wallet/wallet_rpc_server.h @@ -152,85 +152,84 @@ namespace tools END_URI_MAP2() //json_rpc - bool on_getbalance(const wallet_rpc::COMMAND_RPC_GET_BALANCE::request& req, wallet_rpc::COMMAND_RPC_GET_BALANCE::response& res, epee::json_rpc::error& er); - bool on_getaddress(const wallet_rpc::COMMAND_RPC_GET_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_GET_ADDRESS::response& res, epee::json_rpc::error& er); - bool on_getaddress_index(const wallet_rpc::COMMAND_RPC_GET_ADDRESS_INDEX::request& req, wallet_rpc::COMMAND_RPC_GET_ADDRESS_INDEX::response& res, epee::json_rpc::error& er); - bool on_create_address(const wallet_rpc::COMMAND_RPC_CREATE_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_CREATE_ADDRESS::response& res, epee::json_rpc::error& er); - bool on_label_address(const wallet_rpc::COMMAND_RPC_LABEL_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_LABEL_ADDRESS::response& res, epee::json_rpc::error& er); - bool on_get_accounts(const wallet_rpc::COMMAND_RPC_GET_ACCOUNTS::request& req, wallet_rpc::COMMAND_RPC_GET_ACCOUNTS::response& res, epee::json_rpc::error& er); - bool on_create_account(const wallet_rpc::COMMAND_RPC_CREATE_ACCOUNT::request& req, wallet_rpc::COMMAND_RPC_CREATE_ACCOUNT::response& res, epee::json_rpc::error& er); - bool on_label_account(const wallet_rpc::COMMAND_RPC_LABEL_ACCOUNT::request& req, wallet_rpc::COMMAND_RPC_LABEL_ACCOUNT::response& res, epee::json_rpc::error& er); - bool on_get_account_tags(const wallet_rpc::COMMAND_RPC_GET_ACCOUNT_TAGS::request& req, wallet_rpc::COMMAND_RPC_GET_ACCOUNT_TAGS::response& res, epee::json_rpc::error& er); - bool on_tag_accounts(const wallet_rpc::COMMAND_RPC_TAG_ACCOUNTS::request& req, wallet_rpc::COMMAND_RPC_TAG_ACCOUNTS::response& res, epee::json_rpc::error& er); - bool on_untag_accounts(const wallet_rpc::COMMAND_RPC_UNTAG_ACCOUNTS::request& req, wallet_rpc::COMMAND_RPC_UNTAG_ACCOUNTS::response& res, epee::json_rpc::error& er); - bool on_set_account_tag_description(const wallet_rpc::COMMAND_RPC_SET_ACCOUNT_TAG_DESCRIPTION::request& req, wallet_rpc::COMMAND_RPC_SET_ACCOUNT_TAG_DESCRIPTION::response& res, epee::json_rpc::error& er); - bool on_getheight(const wallet_rpc::COMMAND_RPC_GET_HEIGHT::request& req, wallet_rpc::COMMAND_RPC_GET_HEIGHT::response& res, epee::json_rpc::error& er); - bool validate_transfer(const std::list& destinations, const std::string& payment_id, std::vector& dsts, std::vector& extra, bool at_least_one_destination, epee::json_rpc::error& er); - bool on_transfer(const wallet_rpc::COMMAND_RPC_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_TRANSFER::response& res, epee::json_rpc::error& er); - bool on_transfer_split(const wallet_rpc::COMMAND_RPC_TRANSFER_SPLIT::request& req, wallet_rpc::COMMAND_RPC_TRANSFER_SPLIT::response& res, epee::json_rpc::error& er); - bool on_sign_transfer(const wallet_rpc::COMMAND_RPC_SIGN_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_SIGN_TRANSFER::response& res, epee::json_rpc::error& er); - bool on_describe_transfer(const wallet_rpc::COMMAND_RPC_DESCRIBE_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_DESCRIBE_TRANSFER::response& res, epee::json_rpc::error& er); - bool on_submit_transfer(const wallet_rpc::COMMAND_RPC_SUBMIT_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_SUBMIT_TRANSFER::response& res, epee::json_rpc::error& er); - bool on_sweep_dust(const wallet_rpc::COMMAND_RPC_SWEEP_DUST::request& req, wallet_rpc::COMMAND_RPC_SWEEP_DUST::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_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_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_incoming_transfers(const wallet_rpc::COMMAND_RPC_INCOMING_TRANSFERS::request& req, wallet_rpc::COMMAND_RPC_INCOMING_TRANSFERS::response& res, epee::json_rpc::error& er); - bool on_stop_wallet(const wallet_rpc::COMMAND_RPC_STOP_WALLET::request& req, wallet_rpc::COMMAND_RPC_STOP_WALLET::response& res, epee::json_rpc::error& er); - bool on_rescan_blockchain(const wallet_rpc::COMMAND_RPC_RESCAN_BLOCKCHAIN::request& req, wallet_rpc::COMMAND_RPC_RESCAN_BLOCKCHAIN::response& res, epee::json_rpc::error& er); - bool on_set_tx_notes(const wallet_rpc::COMMAND_RPC_SET_TX_NOTES::request& req, wallet_rpc::COMMAND_RPC_SET_TX_NOTES::response& res, epee::json_rpc::error& er); - bool on_get_tx_notes(const wallet_rpc::COMMAND_RPC_GET_TX_NOTES::request& req, wallet_rpc::COMMAND_RPC_GET_TX_NOTES::response& res, epee::json_rpc::error& er); - bool on_set_attribute(const wallet_rpc::COMMAND_RPC_SET_ATTRIBUTE::request& req, wallet_rpc::COMMAND_RPC_SET_ATTRIBUTE::response& res, epee::json_rpc::error& er); - bool on_get_attribute(const wallet_rpc::COMMAND_RPC_GET_ATTRIBUTE::request& req, wallet_rpc::COMMAND_RPC_GET_ATTRIBUTE::response& res, epee::json_rpc::error& er); - bool on_get_tx_key(const wallet_rpc::COMMAND_RPC_GET_TX_KEY::request& req, wallet_rpc::COMMAND_RPC_GET_TX_KEY::response& res, epee::json_rpc::error& er); - bool on_check_tx_key(const wallet_rpc::COMMAND_RPC_CHECK_TX_KEY::request& req, wallet_rpc::COMMAND_RPC_CHECK_TX_KEY::response& res, epee::json_rpc::error& er); - bool on_get_tx_proof(const wallet_rpc::COMMAND_RPC_GET_TX_PROOF::request& req, wallet_rpc::COMMAND_RPC_GET_TX_PROOF::response& res, epee::json_rpc::error& er); - bool on_check_tx_proof(const wallet_rpc::COMMAND_RPC_CHECK_TX_PROOF::request& req, wallet_rpc::COMMAND_RPC_CHECK_TX_PROOF::response& res, epee::json_rpc::error& er); - bool on_get_spend_proof(const wallet_rpc::COMMAND_RPC_GET_SPEND_PROOF::request& req, wallet_rpc::COMMAND_RPC_GET_SPEND_PROOF::response& res, epee::json_rpc::error& er); - bool on_check_spend_proof(const wallet_rpc::COMMAND_RPC_CHECK_SPEND_PROOF::request& req, wallet_rpc::COMMAND_RPC_CHECK_SPEND_PROOF::response& res, epee::json_rpc::error& er); - bool on_get_reserve_proof(const wallet_rpc::COMMAND_RPC_GET_RESERVE_PROOF::request& req, wallet_rpc::COMMAND_RPC_GET_RESERVE_PROOF::response& res, epee::json_rpc::error& er); - bool on_check_reserve_proof(const wallet_rpc::COMMAND_RPC_CHECK_RESERVE_PROOF::request& req, wallet_rpc::COMMAND_RPC_CHECK_RESERVE_PROOF::response& res, epee::json_rpc::error& er); - bool on_get_transfers(const wallet_rpc::COMMAND_RPC_GET_TRANSFERS::request& req, wallet_rpc::COMMAND_RPC_GET_TRANSFERS::response& res, epee::json_rpc::error& er); - bool on_get_transfer_by_txid(const wallet_rpc::COMMAND_RPC_GET_TRANSFER_BY_TXID::request& req, wallet_rpc::COMMAND_RPC_GET_TRANSFER_BY_TXID::response& res, epee::json_rpc::error& er); - bool on_sign(const wallet_rpc::COMMAND_RPC_SIGN::request& req, wallet_rpc::COMMAND_RPC_SIGN::response& res, epee::json_rpc::error& er); - bool on_verify(const wallet_rpc::COMMAND_RPC_VERIFY::request& req, wallet_rpc::COMMAND_RPC_VERIFY::response& res, epee::json_rpc::error& er); - bool on_export_outputs(const wallet_rpc::COMMAND_RPC_EXPORT_OUTPUTS::request& req, wallet_rpc::COMMAND_RPC_EXPORT_OUTPUTS::response& res, epee::json_rpc::error& er); - bool on_import_outputs(const wallet_rpc::COMMAND_RPC_IMPORT_OUTPUTS::request& req, wallet_rpc::COMMAND_RPC_IMPORT_OUTPUTS::response& res, epee::json_rpc::error& er); - bool on_export_key_images(const wallet_rpc::COMMAND_RPC_EXPORT_KEY_IMAGES::request& req, wallet_rpc::COMMAND_RPC_EXPORT_KEY_IMAGES::response& res, epee::json_rpc::error& er); - bool on_import_key_images(const wallet_rpc::COMMAND_RPC_IMPORT_KEY_IMAGES::request& req, wallet_rpc::COMMAND_RPC_IMPORT_KEY_IMAGES::response& res, epee::json_rpc::error& er); - bool on_make_uri(const wallet_rpc::COMMAND_RPC_MAKE_URI::request& req, wallet_rpc::COMMAND_RPC_MAKE_URI::response& res, epee::json_rpc::error& er); - bool on_parse_uri(const wallet_rpc::COMMAND_RPC_PARSE_URI::request& req, wallet_rpc::COMMAND_RPC_PARSE_URI::response& res, epee::json_rpc::error& er); - bool on_get_address_book(const wallet_rpc::COMMAND_RPC_GET_ADDRESS_BOOK_ENTRY::request& req, wallet_rpc::COMMAND_RPC_GET_ADDRESS_BOOK_ENTRY::response& res, epee::json_rpc::error& er); - bool on_add_address_book(const wallet_rpc::COMMAND_RPC_ADD_ADDRESS_BOOK_ENTRY::request& req, wallet_rpc::COMMAND_RPC_ADD_ADDRESS_BOOK_ENTRY::response& res, epee::json_rpc::error& er); - bool on_delete_address_book(const wallet_rpc::COMMAND_RPC_DELETE_ADDRESS_BOOK_ENTRY::request& req, wallet_rpc::COMMAND_RPC_DELETE_ADDRESS_BOOK_ENTRY::response& res, epee::json_rpc::error& er); - bool on_refresh(const wallet_rpc::COMMAND_RPC_REFRESH::request& req, wallet_rpc::COMMAND_RPC_REFRESH::response& res, epee::json_rpc::error& er); - bool on_rescan_spent(const wallet_rpc::COMMAND_RPC_RESCAN_SPENT::request& req, wallet_rpc::COMMAND_RPC_RESCAN_SPENT::response& res, epee::json_rpc::error& er); - bool on_start_mining(const wallet_rpc::COMMAND_RPC_START_MINING::request& req, wallet_rpc::COMMAND_RPC_START_MINING::response& res, epee::json_rpc::error& er); - bool on_stop_mining(const wallet_rpc::COMMAND_RPC_STOP_MINING::request& req, wallet_rpc::COMMAND_RPC_STOP_MINING::response& res, epee::json_rpc::error& er); - bool on_get_languages(const wallet_rpc::COMMAND_RPC_GET_LANGUAGES::request& req, wallet_rpc::COMMAND_RPC_GET_LANGUAGES::response& res, epee::json_rpc::error& er); - bool on_create_wallet(const wallet_rpc::COMMAND_RPC_CREATE_WALLET::request& req, wallet_rpc::COMMAND_RPC_CREATE_WALLET::response& res, epee::json_rpc::error& er); - bool on_open_wallet(const wallet_rpc::COMMAND_RPC_OPEN_WALLET::request& req, wallet_rpc::COMMAND_RPC_OPEN_WALLET::response& res, epee::json_rpc::error& er); - bool on_close_wallet(const wallet_rpc::COMMAND_RPC_CLOSE_WALLET::request& req, wallet_rpc::COMMAND_RPC_CLOSE_WALLET::response& res, epee::json_rpc::error& er); - bool on_change_wallet_password(const wallet_rpc::COMMAND_RPC_CHANGE_WALLET_PASSWORD::request& req, wallet_rpc::COMMAND_RPC_CHANGE_WALLET_PASSWORD::response& res, epee::json_rpc::error& er); - bool on_restore_deterministic_wallet(const wallet_rpc::COMMAND_RPC_RESTORE_DETERMINISTIC_WALLET::request& req, wallet_rpc::COMMAND_RPC_RESTORE_DETERMINISTIC_WALLET::response& res, epee::json_rpc::error& er); - bool on_is_multisig(const wallet_rpc::COMMAND_RPC_IS_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_IS_MULTISIG::response& res, epee::json_rpc::error& er); - bool on_prepare_multisig(const wallet_rpc::COMMAND_RPC_PREPARE_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_PREPARE_MULTISIG::response& res, epee::json_rpc::error& er); - bool on_make_multisig(const wallet_rpc::COMMAND_RPC_MAKE_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_MAKE_MULTISIG::response& res, epee::json_rpc::error& er); - bool on_export_multisig(const wallet_rpc::COMMAND_RPC_EXPORT_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_EXPORT_MULTISIG::response& res, epee::json_rpc::error& er); - bool on_import_multisig(const wallet_rpc::COMMAND_RPC_IMPORT_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_IMPORT_MULTISIG::response& res, epee::json_rpc::error& er); - bool on_finalize_multisig(const wallet_rpc::COMMAND_RPC_FINALIZE_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_FINALIZE_MULTISIG::response& res, epee::json_rpc::error& er); - bool on_exchange_multisig_keys(const wallet_rpc::COMMAND_RPC_EXCHANGE_MULTISIG_KEYS::request& req, wallet_rpc::COMMAND_RPC_EXCHANGE_MULTISIG_KEYS::response& res, epee::json_rpc::error& er); - bool on_sign_multisig(const wallet_rpc::COMMAND_RPC_SIGN_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_SIGN_MULTISIG::response& res, epee::json_rpc::error& er); - bool on_submit_multisig(const wallet_rpc::COMMAND_RPC_SUBMIT_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_SUBMIT_MULTISIG::response& res, epee::json_rpc::error& er); - bool on_get_version(const wallet_rpc::COMMAND_RPC_GET_VERSION::request& req, wallet_rpc::COMMAND_RPC_GET_VERSION::response& res, epee::json_rpc::error& er); + bool on_getbalance(const wallet_rpc::COMMAND_RPC_GET_BALANCE::request& req, wallet_rpc::COMMAND_RPC_GET_BALANCE::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_getaddress(const wallet_rpc::COMMAND_RPC_GET_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_GET_ADDRESS::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_getaddress_index(const wallet_rpc::COMMAND_RPC_GET_ADDRESS_INDEX::request& req, wallet_rpc::COMMAND_RPC_GET_ADDRESS_INDEX::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_create_address(const wallet_rpc::COMMAND_RPC_CREATE_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_CREATE_ADDRESS::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_label_address(const wallet_rpc::COMMAND_RPC_LABEL_ADDRESS::request& req, wallet_rpc::COMMAND_RPC_LABEL_ADDRESS::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_accounts(const wallet_rpc::COMMAND_RPC_GET_ACCOUNTS::request& req, wallet_rpc::COMMAND_RPC_GET_ACCOUNTS::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_create_account(const wallet_rpc::COMMAND_RPC_CREATE_ACCOUNT::request& req, wallet_rpc::COMMAND_RPC_CREATE_ACCOUNT::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_label_account(const wallet_rpc::COMMAND_RPC_LABEL_ACCOUNT::request& req, wallet_rpc::COMMAND_RPC_LABEL_ACCOUNT::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_account_tags(const wallet_rpc::COMMAND_RPC_GET_ACCOUNT_TAGS::request& req, wallet_rpc::COMMAND_RPC_GET_ACCOUNT_TAGS::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_tag_accounts(const wallet_rpc::COMMAND_RPC_TAG_ACCOUNTS::request& req, wallet_rpc::COMMAND_RPC_TAG_ACCOUNTS::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_untag_accounts(const wallet_rpc::COMMAND_RPC_UNTAG_ACCOUNTS::request& req, wallet_rpc::COMMAND_RPC_UNTAG_ACCOUNTS::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_set_account_tag_description(const wallet_rpc::COMMAND_RPC_SET_ACCOUNT_TAG_DESCRIPTION::request& req, wallet_rpc::COMMAND_RPC_SET_ACCOUNT_TAG_DESCRIPTION::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_getheight(const wallet_rpc::COMMAND_RPC_GET_HEIGHT::request& req, wallet_rpc::COMMAND_RPC_GET_HEIGHT::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_transfer(const wallet_rpc::COMMAND_RPC_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_TRANSFER::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_transfer_split(const wallet_rpc::COMMAND_RPC_TRANSFER_SPLIT::request& req, wallet_rpc::COMMAND_RPC_TRANSFER_SPLIT::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_sign_transfer(const wallet_rpc::COMMAND_RPC_SIGN_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_SIGN_TRANSFER::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_describe_transfer(const wallet_rpc::COMMAND_RPC_DESCRIBE_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_DESCRIBE_TRANSFER::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_submit_transfer(const wallet_rpc::COMMAND_RPC_SUBMIT_TRANSFER::request& req, wallet_rpc::COMMAND_RPC_SUBMIT_TRANSFER::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_sweep_dust(const wallet_rpc::COMMAND_RPC_SWEEP_DUST::request& req, wallet_rpc::COMMAND_RPC_SWEEP_DUST::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + 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, const connection_context *ctx = NULL); + 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, const connection_context *ctx = NULL); + 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, const connection_context *ctx = NULL); + 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, const connection_context *ctx = NULL); + 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, const connection_context *ctx = NULL); + bool on_store(const wallet_rpc::COMMAND_RPC_STORE::request& req, wallet_rpc::COMMAND_RPC_STORE::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + 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, const connection_context *ctx = NULL); + 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, const connection_context *ctx = NULL); + bool on_incoming_transfers(const wallet_rpc::COMMAND_RPC_INCOMING_TRANSFERS::request& req, wallet_rpc::COMMAND_RPC_INCOMING_TRANSFERS::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_stop_wallet(const wallet_rpc::COMMAND_RPC_STOP_WALLET::request& req, wallet_rpc::COMMAND_RPC_STOP_WALLET::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_rescan_blockchain(const wallet_rpc::COMMAND_RPC_RESCAN_BLOCKCHAIN::request& req, wallet_rpc::COMMAND_RPC_RESCAN_BLOCKCHAIN::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_set_tx_notes(const wallet_rpc::COMMAND_RPC_SET_TX_NOTES::request& req, wallet_rpc::COMMAND_RPC_SET_TX_NOTES::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_tx_notes(const wallet_rpc::COMMAND_RPC_GET_TX_NOTES::request& req, wallet_rpc::COMMAND_RPC_GET_TX_NOTES::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_set_attribute(const wallet_rpc::COMMAND_RPC_SET_ATTRIBUTE::request& req, wallet_rpc::COMMAND_RPC_SET_ATTRIBUTE::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_attribute(const wallet_rpc::COMMAND_RPC_GET_ATTRIBUTE::request& req, wallet_rpc::COMMAND_RPC_GET_ATTRIBUTE::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_tx_key(const wallet_rpc::COMMAND_RPC_GET_TX_KEY::request& req, wallet_rpc::COMMAND_RPC_GET_TX_KEY::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_check_tx_key(const wallet_rpc::COMMAND_RPC_CHECK_TX_KEY::request& req, wallet_rpc::COMMAND_RPC_CHECK_TX_KEY::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_tx_proof(const wallet_rpc::COMMAND_RPC_GET_TX_PROOF::request& req, wallet_rpc::COMMAND_RPC_GET_TX_PROOF::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_check_tx_proof(const wallet_rpc::COMMAND_RPC_CHECK_TX_PROOF::request& req, wallet_rpc::COMMAND_RPC_CHECK_TX_PROOF::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_spend_proof(const wallet_rpc::COMMAND_RPC_GET_SPEND_PROOF::request& req, wallet_rpc::COMMAND_RPC_GET_SPEND_PROOF::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_check_spend_proof(const wallet_rpc::COMMAND_RPC_CHECK_SPEND_PROOF::request& req, wallet_rpc::COMMAND_RPC_CHECK_SPEND_PROOF::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_reserve_proof(const wallet_rpc::COMMAND_RPC_GET_RESERVE_PROOF::request& req, wallet_rpc::COMMAND_RPC_GET_RESERVE_PROOF::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_check_reserve_proof(const wallet_rpc::COMMAND_RPC_CHECK_RESERVE_PROOF::request& req, wallet_rpc::COMMAND_RPC_CHECK_RESERVE_PROOF::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_transfers(const wallet_rpc::COMMAND_RPC_GET_TRANSFERS::request& req, wallet_rpc::COMMAND_RPC_GET_TRANSFERS::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_transfer_by_txid(const wallet_rpc::COMMAND_RPC_GET_TRANSFER_BY_TXID::request& req, wallet_rpc::COMMAND_RPC_GET_TRANSFER_BY_TXID::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_sign(const wallet_rpc::COMMAND_RPC_SIGN::request& req, wallet_rpc::COMMAND_RPC_SIGN::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_verify(const wallet_rpc::COMMAND_RPC_VERIFY::request& req, wallet_rpc::COMMAND_RPC_VERIFY::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_export_outputs(const wallet_rpc::COMMAND_RPC_EXPORT_OUTPUTS::request& req, wallet_rpc::COMMAND_RPC_EXPORT_OUTPUTS::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_import_outputs(const wallet_rpc::COMMAND_RPC_IMPORT_OUTPUTS::request& req, wallet_rpc::COMMAND_RPC_IMPORT_OUTPUTS::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_export_key_images(const wallet_rpc::COMMAND_RPC_EXPORT_KEY_IMAGES::request& req, wallet_rpc::COMMAND_RPC_EXPORT_KEY_IMAGES::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_import_key_images(const wallet_rpc::COMMAND_RPC_IMPORT_KEY_IMAGES::request& req, wallet_rpc::COMMAND_RPC_IMPORT_KEY_IMAGES::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_make_uri(const wallet_rpc::COMMAND_RPC_MAKE_URI::request& req, wallet_rpc::COMMAND_RPC_MAKE_URI::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_parse_uri(const wallet_rpc::COMMAND_RPC_PARSE_URI::request& req, wallet_rpc::COMMAND_RPC_PARSE_URI::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_address_book(const wallet_rpc::COMMAND_RPC_GET_ADDRESS_BOOK_ENTRY::request& req, wallet_rpc::COMMAND_RPC_GET_ADDRESS_BOOK_ENTRY::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_add_address_book(const wallet_rpc::COMMAND_RPC_ADD_ADDRESS_BOOK_ENTRY::request& req, wallet_rpc::COMMAND_RPC_ADD_ADDRESS_BOOK_ENTRY::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_delete_address_book(const wallet_rpc::COMMAND_RPC_DELETE_ADDRESS_BOOK_ENTRY::request& req, wallet_rpc::COMMAND_RPC_DELETE_ADDRESS_BOOK_ENTRY::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_refresh(const wallet_rpc::COMMAND_RPC_REFRESH::request& req, wallet_rpc::COMMAND_RPC_REFRESH::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_rescan_spent(const wallet_rpc::COMMAND_RPC_RESCAN_SPENT::request& req, wallet_rpc::COMMAND_RPC_RESCAN_SPENT::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_start_mining(const wallet_rpc::COMMAND_RPC_START_MINING::request& req, wallet_rpc::COMMAND_RPC_START_MINING::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_stop_mining(const wallet_rpc::COMMAND_RPC_STOP_MINING::request& req, wallet_rpc::COMMAND_RPC_STOP_MINING::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_languages(const wallet_rpc::COMMAND_RPC_GET_LANGUAGES::request& req, wallet_rpc::COMMAND_RPC_GET_LANGUAGES::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_create_wallet(const wallet_rpc::COMMAND_RPC_CREATE_WALLET::request& req, wallet_rpc::COMMAND_RPC_CREATE_WALLET::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_open_wallet(const wallet_rpc::COMMAND_RPC_OPEN_WALLET::request& req, wallet_rpc::COMMAND_RPC_OPEN_WALLET::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_close_wallet(const wallet_rpc::COMMAND_RPC_CLOSE_WALLET::request& req, wallet_rpc::COMMAND_RPC_CLOSE_WALLET::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_change_wallet_password(const wallet_rpc::COMMAND_RPC_CHANGE_WALLET_PASSWORD::request& req, wallet_rpc::COMMAND_RPC_CHANGE_WALLET_PASSWORD::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_restore_deterministic_wallet(const wallet_rpc::COMMAND_RPC_RESTORE_DETERMINISTIC_WALLET::request& req, wallet_rpc::COMMAND_RPC_RESTORE_DETERMINISTIC_WALLET::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_is_multisig(const wallet_rpc::COMMAND_RPC_IS_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_IS_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_prepare_multisig(const wallet_rpc::COMMAND_RPC_PREPARE_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_PREPARE_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_make_multisig(const wallet_rpc::COMMAND_RPC_MAKE_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_MAKE_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_export_multisig(const wallet_rpc::COMMAND_RPC_EXPORT_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_EXPORT_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_import_multisig(const wallet_rpc::COMMAND_RPC_IMPORT_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_IMPORT_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_finalize_multisig(const wallet_rpc::COMMAND_RPC_FINALIZE_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_FINALIZE_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_exchange_multisig_keys(const wallet_rpc::COMMAND_RPC_EXCHANGE_MULTISIG_KEYS::request& req, wallet_rpc::COMMAND_RPC_EXCHANGE_MULTISIG_KEYS::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_sign_multisig(const wallet_rpc::COMMAND_RPC_SIGN_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_SIGN_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_submit_multisig(const wallet_rpc::COMMAND_RPC_SUBMIT_MULTISIG::request& req, wallet_rpc::COMMAND_RPC_SUBMIT_MULTISIG::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); + bool on_get_version(const wallet_rpc::COMMAND_RPC_GET_VERSION::request& req, wallet_rpc::COMMAND_RPC_GET_VERSION::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); //json rpc v2 - bool on_query_key(const wallet_rpc::COMMAND_RPC_QUERY_KEY::request& req, wallet_rpc::COMMAND_RPC_QUERY_KEY::response& res, epee::json_rpc::error& er); + bool on_query_key(const wallet_rpc::COMMAND_RPC_QUERY_KEY::request& req, wallet_rpc::COMMAND_RPC_QUERY_KEY::response& res, epee::json_rpc::error& er, const connection_context *ctx = NULL); // helpers void fill_transfer_entry(tools::wallet_rpc::transfer_entry &entry, const crypto::hash &txid, const crypto::hash &payment_id, const tools::wallet2::payment_details &pd); @@ -245,6 +244,8 @@ namespace tools bool get_tx_key, Ts& tx_key, Tu &amount, Tu &fee, std::string &multisig_txset, std::string &unsigned_txset, bool do_not_relay, Ts &tx_hash, bool get_tx_hex, Ts &tx_blob, bool get_tx_metadata, Ts &tx_metadata, epee::json_rpc::error &er); + bool validate_transfer(const std::list& destinations, const std::string& payment_id, std::vector& dsts, std::vector& extra, bool at_least_one_destination, epee::json_rpc::error& er); + wallet2 *m_wallet; std::string m_wallet_dir; tools::private_file rpc_login_file;