diff options
author | artyomsol <2406155+artyomsol@users.noreply.github.com> | 2018-08-16 20:24:50 +0300 |
---|---|---|
committer | artyomsol <2406155+artyomsol@users.noreply.github.com> | 2018-08-17 09:54:26 +0300 |
commit | 3d5abbe86b7bc109be1ea4b946d454ff29a9a600 (patch) | |
tree | c457cb3e6789b75838620f65afa12501f3b40b86 /src/wallet/wallet_rpc_server.cpp | |
parent | Merge pull request #4191 (diff) | |
download | monero-3d5abbe86b7bc109be1ea4b946d454ff29a9a600.tar.xz |
[#4027] add change_wallet_password wallet rpc command
Diffstat (limited to '')
-rw-r--r-- | src/wallet/wallet_rpc_server.cpp | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/src/wallet/wallet_rpc_server.cpp b/src/wallet/wallet_rpc_server.cpp index 510cb3e58..b372b1a85 100644 --- a/src/wallet/wallet_rpc_server.cpp +++ b/src/wallet/wallet_rpc_server.cpp @@ -2728,6 +2728,38 @@ 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) + { + if (!m_wallet) return not_open(er); + if (m_restricted) + { + er.code = WALLET_RPC_ERROR_CODE_DENIED; + er.message = "Command unavailable in restricted mode."; + return false; + } + if (m_wallet->verify_password(req.old_password)) + { + try + { + m_wallet->rewrite(m_wallet->get_wallet_file(), req.new_password); + m_wallet->store(); + LOG_PRINT_L0("Wallet password changed."); + } + catch (const std::exception& e) + { + handle_rpc_exception(std::current_exception(), er, WALLET_RPC_ERROR_CODE_UNKNOWN_ERROR); + return false; + } + } + else + { + er.code = WALLET_RPC_ERROR_CODE_INVALID_PASSWORD; + er.message = "Invalid original password."; + return false; + } + return true; + } + //------------------------------------------------------------------------------------------------------------------------------ void wallet_rpc_server::handle_rpc_exception(const std::exception_ptr& e, epee::json_rpc::error& er, int default_error_code) { try { |