diff options
author | Dusan Klinec <dusan.klinec@gmail.com> | 2019-06-19 12:07:50 +0200 |
---|---|---|
committer | Dusan Klinec <dusan.klinec@gmail.com> | 2019-06-19 12:09:49 +0200 |
commit | 097cca59c1a9a9a5893174419ee888c66465a1cf (patch) | |
tree | 7e1345bbf5436bc2d0be5931684dd35cfbfdabd9 | |
parent | Merge pull request #5641 (diff) | |
download | monero-097cca59c1a9a9a5893174419ee888c66465a1cf.tar.xz |
wallet_api: catch getTxKey exception
- getTxKey method throws an exception, e.g., when user declines txKey export
-rw-r--r-- | src/wallet/api/wallet.cpp | 25 |
1 files changed, 17 insertions, 8 deletions
diff --git a/src/wallet/api/wallet.cpp b/src/wallet/api/wallet.cpp index 1711db482..96b979136 100644 --- a/src/wallet/api/wallet.cpp +++ b/src/wallet/api/wallet.cpp @@ -1729,18 +1729,27 @@ std::string WalletImpl::getTxKey(const std::string &txid_str) const crypto::secret_key tx_key; std::vector<crypto::secret_key> additional_tx_keys; - if (m_wallet->get_tx_key(txid, tx_key, additional_tx_keys)) + try { clearStatus(); - std::ostringstream oss; - oss << epee::string_tools::pod_to_hex(tx_key); - for (size_t i = 0; i < additional_tx_keys.size(); ++i) - oss << epee::string_tools::pod_to_hex(additional_tx_keys[i]); - return oss.str(); + if (m_wallet->get_tx_key(txid, tx_key, additional_tx_keys)) + { + clearStatus(); + std::ostringstream oss; + oss << epee::string_tools::pod_to_hex(tx_key); + for (size_t i = 0; i < additional_tx_keys.size(); ++i) + oss << epee::string_tools::pod_to_hex(additional_tx_keys[i]); + return oss.str(); + } + else + { + setStatusError(tr("no tx keys found for this txid")); + return ""; + } } - else + catch (const std::exception &e) { - setStatusError(tr("no tx keys found for this txid")); + setStatusError(e.what()); return ""; } } |