monero/src/simplewallet/simplewallet.h

150 lines
5.7 KiB
C
Raw Normal View History

2014-03-04 00:07:58 +02:00
// Copyright (c) 2012-2013 The Cryptonote developers
// Distributed under the MIT/X11 software license, see the accompanying
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
#pragma once
#include <memory>
#include <boost/program_options/variables_map.hpp>
#include "cryptonote_core/account.h"
#include "cryptonote_core/cryptonote_basic_impl.h"
#include "wallet/wallet2.h"
#include "console_handler.h"
#include "password_container.h"
#include "crypto/crypto.h" // for definition of crypto::secret_key
2014-03-04 00:07:58 +02:00
namespace cryptonote
{
/************************************************************************/
/* */
/************************************************************************/
2014-04-02 19:00:17 +03:00
class simple_wallet : public tools::i_wallet2_callback
2014-03-04 00:07:58 +02:00
{
public:
typedef std::vector<std::string> command_type;
simple_wallet();
bool init(const boost::program_options::variables_map& vm);
bool deinit();
bool run();
2014-03-20 13:46:11 +02:00
void stop();
2014-03-04 00:07:58 +02:00
//wallet *create_wallet();
bool process_command(const std::vector<std::string> &args);
std::string get_commands_str();
private:
2014-04-02 19:00:17 +03:00
void handle_command_line(const boost::program_options::variables_map& vm);
2014-03-04 00:07:58 +02:00
bool run_console_handler();
bool new_wallet(const std::string &wallet_file, const std::string& password, const crypto::secret_key& recovery_key = crypto::secret_key(), bool recover = false, bool two_random = false);
2014-03-04 00:07:58 +02:00
bool open_wallet(const std::string &wallet_file, const std::string& password);
bool close_wallet();
2014-03-20 13:46:11 +02:00
bool help(const std::vector<std::string> &args = std::vector<std::string>());
2014-03-04 00:07:58 +02:00
bool start_mining(const std::vector<std::string> &args);
bool stop_mining(const std::vector<std::string> &args);
bool save_bc(const std::vector<std::string>& args);
2014-03-04 00:07:58 +02:00
bool refresh(const std::vector<std::string> &args);
2014-03-20 13:46:11 +02:00
bool show_balance(const std::vector<std::string> &args = std::vector<std::string>());
2014-03-04 00:07:58 +02:00
bool show_incoming_transfers(const std::vector<std::string> &args);
2014-05-03 19:19:43 +03:00
bool show_payments(const std::vector<std::string> &args);
2014-03-04 00:07:58 +02:00
bool show_blockchain_height(const std::vector<std::string> &args);
bool transfer(const std::vector<std::string> &args);
std::vector<std::vector<cryptonote::tx_destination_entry>> split_amounts(
std::vector<cryptonote::tx_destination_entry> dsts, size_t num_splits
);
void create_transactions(std::vector<cryptonote::tx_destination_entry> dsts, const size_t fake_outs_count, const uint64_t unlock_time, const uint64_t fee, const std::vector<uint8_t> extra);
2014-04-02 19:00:17 +03:00
bool print_address(const std::vector<std::string> &args = std::vector<std::string>());
2014-03-04 00:07:58 +02:00
bool save(const std::vector<std::string> &args);
bool set_log(const std::vector<std::string> &args);
2014-03-20 13:46:11 +02:00
uint64_t get_daemon_blockchain_height(std::string& err);
bool try_connect_to_daemon();
2014-05-03 19:19:43 +03:00
bool ask_wallet_create_if_needed();
2014-03-04 00:07:58 +02:00
2014-04-02 19:00:17 +03:00
//----------------- i_wallet2_callback ---------------------
virtual void on_new_block(uint64_t height, const cryptonote::block& block);
virtual void on_money_received(uint64_t height, const cryptonote::transaction& tx, size_t out_index);
virtual void on_money_spent(uint64_t height, const cryptonote::transaction& in_tx, size_t out_index, const cryptonote::transaction& spend_tx);
2014-05-03 19:19:43 +03:00
virtual void on_skip_transaction(uint64_t height, const cryptonote::transaction& tx);
2014-04-02 19:00:17 +03:00
//----------------------------------------------------------
friend class refresh_progress_reporter_t;
class refresh_progress_reporter_t
{
public:
refresh_progress_reporter_t(cryptonote::simple_wallet& simple_wallet)
: m_simple_wallet(simple_wallet)
, m_blockchain_height(0)
, m_blockchain_height_update_time()
, m_print_time()
{
}
void update(uint64_t height, bool force = false)
{
auto current_time = std::chrono::system_clock::now();
if (std::chrono::seconds(DIFFICULTY_TARGET / 2) < current_time - m_blockchain_height_update_time || m_blockchain_height <= height)
{
update_blockchain_height();
m_blockchain_height = (std::max)(m_blockchain_height, height);
}
if (std::chrono::milliseconds(1) < current_time - m_print_time || force)
{
std::cout << "Height " << height << " of " << m_blockchain_height << '\r';
m_print_time = current_time;
}
}
private:
void update_blockchain_height()
{
std::string err;
uint64_t blockchain_height = m_simple_wallet.get_daemon_blockchain_height(err);
if (err.empty())
{
m_blockchain_height = blockchain_height;
m_blockchain_height_update_time = std::chrono::system_clock::now();
}
else
{
LOG_ERROR("Failed to get current blockchain height: " << err);
}
}
private:
cryptonote::simple_wallet& m_simple_wallet;
uint64_t m_blockchain_height;
std::chrono::system_clock::time_point m_blockchain_height_update_time;
std::chrono::system_clock::time_point m_print_time;
};
private:
2014-03-04 00:07:58 +02:00
std::string m_wallet_file;
std::string m_generate_new;
std::string m_import_path;
std::string m_electrum_seed; // electrum-style seed parameter
crypto::secret_key m_recovery_key; // recovery key (used as random for wallet gen)
bool m_restore_deterministic_wallet; // recover flag
bool m_non_deterministic; // old 2-random generation
2014-03-04 00:07:58 +02:00
std::string m_daemon_address;
std::string m_daemon_host;
int m_daemon_port;
epee::console_handlers_binder m_cmd_binder;
2014-03-20 13:46:11 +02:00
std::unique_ptr<tools::wallet2> m_wallet;
2014-05-25 20:06:40 +03:00
epee::net_utils::http::http_simple_client m_http_client;
2014-04-02 19:00:17 +03:00
refresh_progress_reporter_t m_refresh_progress_reporter;
2014-03-04 00:07:58 +02:00
};
}