aboutsummaryrefslogtreecommitdiff
path: root/src/simplewallet
diff options
context:
space:
mode:
authorRiccardo Spagni <ric@spagni.net>2014-12-08 20:39:26 +0200
committerRiccardo Spagni <ric@spagni.net>2014-12-08 21:29:28 +0200
commitebb117c7b6b0bf04afc169e93db71b1d87becaeb (patch)
tree567bac1d893e76d4b4ebb19d69ef0961bdc9da0b /src/simplewallet
parentMerge pull request #183 (diff)
parentwallet JSON update for non-deterministic wallet data (diff)
downloadmonero-ebb117c7b6b0bf04afc169e93db71b1d87becaeb.tar.xz
Merge pull request #196
f9822c4 wallet JSON update for non-deterministic wallet data (warptangent) 4c6230d Checking and handling for deterministic vs non-deterministic wallet (warptangent) 1beedb9 Extract check for deterministic keys to wallet2::is_deterministic() (warptangent) 359ede3 indentation (warptangent) 2290eff replace lines with call to recently added print_seed() (warptangent)
Diffstat (limited to 'src/simplewallet')
-rw-r--r--src/simplewallet/simplewallet.cpp61
1 files changed, 37 insertions, 24 deletions
diff --git a/src/simplewallet/simplewallet.cpp b/src/simplewallet/simplewallet.cpp
index e1e2a198b..4f7df2d3a 100644
--- a/src/simplewallet/simplewallet.cpp
+++ b/src/simplewallet/simplewallet.cpp
@@ -206,26 +206,27 @@ bool simple_wallet::viewkey(const std::vector<std::string> &args/* = std::vector
bool simple_wallet::seed(const std::vector<std::string> &args/* = std::vector<std::string>()*/)
{
+ bool success = false;
std::string electrum_words;
- if (m_wallet->get_seed_language().empty())
+ if (m_wallet->is_deterministic())
{
- std::string mnemonic_language = get_mnemonic_language();
- m_wallet->set_seed_language(mnemonic_language);
+ if (m_wallet->get_seed_language().empty())
+ {
+ std::string mnemonic_language = get_mnemonic_language();
+ m_wallet->set_seed_language(mnemonic_language);
+ }
+
+ success = m_wallet->get_seed(electrum_words);
}
- bool success = m_wallet->get_seed(electrum_words);
-
if (success)
{
- success_msg_writer(true) << "\nPLEASE NOTE: the following 25 words can be used to recover access to your wallet. Please 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.\n";
- boost::replace_nth(electrum_words, " ", 15, "\n");
- boost::replace_nth(electrum_words, " ", 7, "\n");
- std::cout << electrum_words << std::endl;
+ print_seed(electrum_words);
}
else
{
- fail_msg_writer() << "The wallet is non-deterministic. Cannot display seed.";
+ fail_msg_writer() << "The wallet is non-deterministic. Cannot display seed.";
}
return true;
}
@@ -511,9 +512,11 @@ bool simple_wallet::new_wallet(const std::string &wallet_file, const std::string
crypto::ElectrumWords::get_is_old_style_seed(m_electrum_seed));
std::string mnemonic_language = old_language;
- // Ask for seed language if it is not a wallet restore or if it was a deprecated wallet
- // that was earlier used before this restore.
- if (!m_restore_deterministic_wallet || was_deprecated_wallet)
+ // Ask for seed language if:
+ // it's a deterministic wallet AND
+ // (it is not a wallet restore OR if it was a deprecated wallet
+ // that was earlier used before this restore)
+ if ((!two_random) && (!m_restore_deterministic_wallet || was_deprecated_wallet))
{
if (was_deprecated_wallet)
{
@@ -583,18 +586,28 @@ bool simple_wallet::open_wallet(const string &wallet_file, const std::string& pa
<< m_wallet->get_account().get_public_address_str(m_wallet->testnet());
// If the wallet file is deprecated, we should ask for mnemonic language again and store
// everything in the new format.
- if (!m_non_deterministic && m_wallet->is_deprecated())
+ // NOTE: this is_deprecated() refers to the wallet file format before becoming JSON. It does not refer to the "old english" seed words form of "deprecated" used elsewhere.
+ if (m_wallet->is_deprecated())
{
- message_writer(epee::log_space::console_color_green, false) << "\nYou had been using " <<
- "a deprecated version of the wallet. Please proceed to upgrade your wallet.\n";
- std::string mnemonic_language = get_mnemonic_language();
- m_wallet->set_seed_language(mnemonic_language);
- m_wallet->rewrite(m_wallet_file, password);
-
- // Display the seed
- std::string seed;
- m_wallet->get_seed(seed);
- print_seed(seed);
+ if (m_wallet->is_deterministic())
+ {
+ message_writer(epee::log_space::console_color_green, false) << "\nYou had been using " <<
+ "a deprecated version of the wallet. Please proceed to upgrade your wallet.\n";
+ std::string mnemonic_language = get_mnemonic_language();
+ m_wallet->set_seed_language(mnemonic_language);
+ m_wallet->rewrite(m_wallet_file, password);
+
+ // Display the seed
+ std::string seed;
+ m_wallet->get_seed(seed);
+ print_seed(seed);
+ }
+ else
+ {
+ message_writer(epee::log_space::console_color_green, false) << "\nYou had been using " <<
+ "a deprecated version of the wallet. Your wallet file format is being upgraded now.\n";
+ m_wallet->rewrite(m_wallet_file, password);
+ }
}
}
catch (const std::exception& e)