diff options
author | Lee Clagett <code@leeclagett.com> | 2016-12-17 18:07:15 -0500 |
---|---|---|
committer | Lee Clagett <code@leeclagett.com> | 2016-12-19 20:00:43 -0500 |
commit | 2bddb8ebee4b25f2f73e6476dd1019459d8a1aca (patch) | |
tree | cc1edfe5d2b0ff388f68db03ce82bcec71ee201a /src/wallet/password_container.h | |
parent | Merge pull request #1464 (diff) | |
download | monero-2bddb8ebee4b25f2f73e6476dd1019459d8a1aca.tar.xz |
Refactored password prompting for wallets
Diffstat (limited to 'src/wallet/password_container.h')
-rw-r--r-- | src/wallet/password_container.h | 41 |
1 files changed, 22 insertions, 19 deletions
diff --git a/src/wallet/password_container.h b/src/wallet/password_container.h index 866d170f2..9c6faf9c8 100644 --- a/src/wallet/password_container.h +++ b/src/wallet/password_container.h @@ -31,34 +31,37 @@ #pragma once #include <string> -#include <boost/program_options/variables_map.hpp> +#include <boost/optional/optional.hpp> namespace tools { class password_container { public: - static const size_t max_password_size = 1024; - password_container(bool verify); - password_container(password_container&& rhs); - password_container(std::string&& password); - ~password_container(); + static constexpr const size_t max_password_size = 1024; - void clear(); - bool empty() const { return m_empty; } - const std::string& password() const { return m_password; } - void password(std::string&& val) { m_password = std::move(val); m_empty = false; } - bool read_password(const char *message = "Password"); + //! Empty password + password_container() noexcept; - private: - //delete constructor with no parameters - password_container(); - bool read_from_file(); - bool read_from_tty(std::string & pass); - bool read_from_tty_double_check(const char *message); + //! `password` is used as password + password_container(std::string&& password) noexcept; + + //! \return A password from stdin TTY prompt or `std::cin` pipe. + static boost::optional<password_container> prompt(bool verify, const char *mesage = "Password"); + + password_container(const password_container&) = delete; + password_container(password_container&& rhs) = default; + + //! Wipes internal password + ~password_container() noexcept; - bool m_empty; + password_container& operator=(const password_container&) = delete; + password_container& operator=(password_container&&) = default; + + const std::string& password() const noexcept { return m_password; } + + private: + //! TODO Custom allocator that locks to RAM? std::string m_password; - bool m_verify; }; } |