From f6abc5324f602ded6a0424445c033f5a8622ab22 Mon Sep 17 00:00:00 2001 From: moneromooo-monero Date: Fri, 5 Feb 2016 22:41:45 +0000 Subject: [PATCH] simplewallet: check watch-only view key matches standard address --- src/simplewallet/simplewallet.cpp | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/src/simplewallet/simplewallet.cpp b/src/simplewallet/simplewallet.cpp index 9e82d29de..f4dcb6a35 100644 --- a/src/simplewallet/simplewallet.cpp +++ b/src/simplewallet/simplewallet.cpp @@ -897,6 +897,17 @@ bool simple_wallet::init(const boost::program_options::variables_map& vm) for (size_t n = 3; n < parts.size(); ++n) m_wallet_file += std::string(":") + parts[n]; + // check the view key matches the given address + crypto::public_key pkey; + if (!crypto::secret_key_to_public_key(viewkey, pkey)) { + fail_msg_writer() << tr("failed to verify view key secret key"); + return false; + } + if (address.m_view_public_key != pkey) { + fail_msg_writer() << tr("view key does not match standard address"); + return false; + } + bool r = new_wallet(m_wallet_file, pwd_container.password(), address, viewkey, testnet); CHECK_AND_ASSERT_MES(r, false, tr("account creation failed")); }