2018-01-07 07:05:16 +02:00
|
|
|
// Copyright (c) 2014-2018, The Monero Project
|
2016-04-20 13:01:00 +03:00
|
|
|
//
|
|
|
|
// All rights reserved.
|
|
|
|
//
|
|
|
|
// Redistribution and use in source and binary forms, with or without modification, are
|
|
|
|
// permitted provided that the following conditions are met:
|
|
|
|
//
|
|
|
|
// 1. Redistributions of source code must retain the above copyright notice, this list of
|
|
|
|
// conditions and the following disclaimer.
|
|
|
|
//
|
|
|
|
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
|
|
|
// of conditions and the following disclaimer in the documentation and/or other
|
|
|
|
// materials provided with the distribution.
|
|
|
|
//
|
|
|
|
// 3. Neither the name of the copyright holder nor the names of its contributors may be
|
|
|
|
// used to endorse or promote products derived from this software without specific
|
|
|
|
// prior written permission.
|
|
|
|
//
|
|
|
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
|
|
|
|
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
|
|
|
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
|
|
|
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
|
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
|
|
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
|
|
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
|
|
|
|
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
//
|
|
|
|
// Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers
|
|
|
|
|
|
|
|
#ifndef WALLET_IMPL_H
|
|
|
|
#define WALLET_IMPL_H
|
|
|
|
|
2017-11-15 18:37:07 +02:00
|
|
|
#include "wallet/api/wallet2_api.h"
|
2016-04-20 13:01:00 +03:00
|
|
|
#include "wallet/wallet2.h"
|
|
|
|
|
|
|
|
#include <string>
|
2016-09-18 18:21:44 +03:00
|
|
|
#include <boost/thread/mutex.hpp>
|
|
|
|
#include <boost/thread/thread.hpp>
|
|
|
|
#include <boost/thread/condition_variable.hpp>
|
2016-04-20 13:01:00 +03:00
|
|
|
|
|
|
|
|
2016-12-13 17:21:38 +02:00
|
|
|
namespace Monero {
|
2016-04-20 13:17:27 +03:00
|
|
|
class TransactionHistoryImpl;
|
|
|
|
class PendingTransactionImpl;
|
2017-01-08 14:17:09 +02:00
|
|
|
class UnsignedTransactionImpl;
|
2016-12-12 01:42:46 +02:00
|
|
|
class AddressBookImpl;
|
2017-02-19 04:42:10 +02:00
|
|
|
class SubaddressImpl;
|
|
|
|
class SubaddressAccountImpl;
|
2016-05-05 22:24:00 +03:00
|
|
|
struct Wallet2CallbackImpl;
|
2016-04-20 13:01:00 +03:00
|
|
|
|
|
|
|
class WalletImpl : public Wallet
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
WalletImpl(bool testnet = false);
|
|
|
|
~WalletImpl();
|
|
|
|
bool create(const std::string &path, const std::string &password,
|
|
|
|
const std::string &language);
|
2017-01-10 23:34:15 +02:00
|
|
|
bool createWatchOnly(const std::string &path, const std::string &password,
|
|
|
|
const std::string &language) const;
|
2016-04-20 13:01:00 +03:00
|
|
|
bool open(const std::string &path, const std::string &password);
|
2018-01-11 17:12:27 +02:00
|
|
|
bool recover(const std::string &path,const std::string &password,
|
|
|
|
const std::string &seed);
|
|
|
|
bool recoverFromKeysWithPassword(const std::string &path,
|
|
|
|
const std::string &password,
|
|
|
|
const std::string &language,
|
|
|
|
const std::string &address_string,
|
|
|
|
const std::string &viewkey_string,
|
|
|
|
const std::string &spendkey_string = "");
|
|
|
|
// following two methods are deprecated since they create passwordless wallets
|
|
|
|
// use the two equivalent methods above
|
2016-04-20 13:01:00 +03:00
|
|
|
bool recover(const std::string &path, const std::string &seed);
|
2018-01-11 17:12:27 +02:00
|
|
|
// deprecated: use recoverFromKeysWithPassword() instead
|
2017-01-26 22:33:36 +02:00
|
|
|
bool recoverFromKeys(const std::string &path,
|
|
|
|
const std::string &language,
|
|
|
|
const std::string &address_string,
|
|
|
|
const std::string &viewkey_string,
|
|
|
|
const std::string &spendkey_string = "");
|
2017-09-23 01:52:09 +03:00
|
|
|
bool close(bool store = true);
|
2016-04-20 13:01:00 +03:00
|
|
|
std::string seed() const;
|
|
|
|
std::string getSeedLanguage() const;
|
|
|
|
void setSeedLanguage(const std::string &arg);
|
|
|
|
// void setListener(Listener *) {}
|
|
|
|
int status() const;
|
|
|
|
std::string errorString() const;
|
|
|
|
bool setPassword(const std::string &password);
|
2017-10-22 16:13:35 +03:00
|
|
|
std::string address(uint32_t accountIndex = 0, uint32_t addressIndex = 0) const;
|
2016-06-23 14:38:22 +03:00
|
|
|
std::string integratedAddress(const std::string &payment_id) const;
|
2017-05-02 17:48:38 +03:00
|
|
|
std::string secretViewKey() const;
|
|
|
|
std::string publicViewKey() const;
|
|
|
|
std::string secretSpendKey() const;
|
|
|
|
std::string publicSpendKey() const;
|
2016-11-26 16:19:57 +02:00
|
|
|
std::string path() const;
|
2016-04-20 13:01:00 +03:00
|
|
|
bool store(const std::string &path);
|
2016-06-10 12:51:09 +03:00
|
|
|
std::string filename() const;
|
|
|
|
std::string keysFilename() const;
|
2017-08-05 00:28:38 +03:00
|
|
|
bool init(const std::string &daemon_address, uint64_t upper_transaction_size_limit = 0, const std::string &daemon_username = "", const std::string &daemon_password = "", bool use_ssl = false, bool lightWallet = false);
|
2016-04-20 13:01:00 +03:00
|
|
|
bool connectToDaemon();
|
2016-11-07 14:00:29 +02:00
|
|
|
ConnectionStatus connected() const;
|
2016-04-26 13:46:20 +03:00
|
|
|
void setTrustedDaemon(bool arg);
|
|
|
|
bool trustedDaemon() const;
|
2017-10-22 16:13:35 +03:00
|
|
|
uint64_t balance(uint32_t accountIndex = 0) const;
|
|
|
|
uint64_t unlockedBalance(uint32_t accountIndex = 0) const;
|
2016-09-23 22:36:37 +03:00
|
|
|
uint64_t blockChainHeight() const;
|
2016-11-10 16:36:16 +02:00
|
|
|
uint64_t approximateBlockChainHeight() const;
|
2016-09-26 21:35:00 +03:00
|
|
|
uint64_t daemonBlockChainHeight() const;
|
2016-10-03 21:47:41 +03:00
|
|
|
uint64_t daemonBlockChainTargetHeight() const;
|
2016-10-07 00:29:13 +03:00
|
|
|
bool synchronized() const;
|
2016-04-20 13:01:00 +03:00
|
|
|
bool refresh();
|
2016-07-10 17:17:23 +03:00
|
|
|
void refreshAsync();
|
2016-09-26 22:50:10 +03:00
|
|
|
void setAutoRefreshInterval(int millis);
|
2016-09-20 20:40:58 +03:00
|
|
|
int autoRefreshInterval() const;
|
2016-10-08 01:57:09 +03:00
|
|
|
void setRefreshFromBlockHeight(uint64_t refresh_from_block_height);
|
2017-08-05 01:09:06 +03:00
|
|
|
uint64_t getRefreshFromBlockHeight() const { return m_wallet->get_refresh_from_block_height(); };
|
2016-10-10 20:34:25 +03:00
|
|
|
void setRecoveringFromSeed(bool recoveringFromSeed);
|
2017-01-10 23:34:15 +02:00
|
|
|
bool watchOnly() const;
|
2017-01-12 23:10:38 +02:00
|
|
|
bool rescanSpent();
|
2017-01-23 00:02:01 +02:00
|
|
|
bool testnet() const {return m_wallet->testnet();}
|
2017-03-24 10:59:26 +02:00
|
|
|
void hardForkInfo(uint8_t &version, uint64_t &earliest_height) const;
|
|
|
|
bool useForkRules(uint8_t version, int64_t early_blocks) const;
|
2016-09-20 20:40:58 +03:00
|
|
|
|
2017-02-19 04:42:10 +02:00
|
|
|
void addSubaddressAccount(const std::string& label);
|
|
|
|
size_t numSubaddressAccounts() const;
|
|
|
|
size_t numSubaddresses(uint32_t accountIndex) const;
|
|
|
|
void addSubaddress(uint32_t accountIndex, const std::string& label);
|
|
|
|
std::string getSubaddressLabel(uint32_t accountIndex, uint32_t addressIndex) const;
|
|
|
|
void setSubaddressLabel(uint32_t accountIndex, uint32_t addressIndex, const std::string &label);
|
|
|
|
|
2016-06-23 14:38:22 +03:00
|
|
|
PendingTransaction * createTransaction(const std::string &dst_addr, const std::string &payment_id,
|
2016-11-09 14:19:22 +02:00
|
|
|
optional<uint64_t> amount, uint32_t mixin_count,
|
2017-10-22 16:13:35 +03:00
|
|
|
PendingTransaction::Priority priority = PendingTransaction::Priority_Low,
|
|
|
|
uint32_t subaddr_account = 0,
|
|
|
|
std::set<uint32_t> subaddr_indices = {});
|
2016-11-08 22:03:07 +02:00
|
|
|
virtual PendingTransaction * createSweepUnmixableTransaction();
|
2017-01-08 14:17:09 +02:00
|
|
|
bool submitTransaction(const std::string &fileName);
|
|
|
|
virtual UnsignedTransaction * loadUnsignedTx(const std::string &unsigned_filename);
|
2017-01-14 00:00:03 +02:00
|
|
|
bool exportKeyImages(const std::string &filename);
|
|
|
|
bool importKeyImages(const std::string &filename);
|
2016-06-27 14:55:13 +03:00
|
|
|
|
2016-04-20 13:01:00 +03:00
|
|
|
virtual void disposeTransaction(PendingTransaction * t);
|
2017-02-19 04:42:10 +02:00
|
|
|
virtual TransactionHistory * history();
|
|
|
|
virtual AddressBook * addressBook();
|
|
|
|
virtual Subaddress * subaddress();
|
|
|
|
virtual SubaddressAccount * subaddressAccount();
|
2016-05-05 22:24:00 +03:00
|
|
|
virtual void setListener(WalletListener * l);
|
2016-06-10 13:52:10 +03:00
|
|
|
virtual uint32_t defaultMixin() const;
|
|
|
|
virtual void setDefaultMixin(uint32_t arg);
|
2016-11-05 22:53:45 +02:00
|
|
|
virtual bool setUserNote(const std::string &txid, const std::string ¬e);
|
|
|
|
virtual std::string getUserNote(const std::string &txid) const;
|
2016-11-06 20:04:59 +02:00
|
|
|
virtual std::string getTxKey(const std::string &txid) const;
|
2017-09-12 04:05:41 +03:00
|
|
|
virtual bool checkTxKey(const std::string &txid, std::string tx_key, const std::string &address, uint64_t &received, bool &in_pool, uint64_t &confirmations);
|
2017-11-20 11:10:58 +02:00
|
|
|
virtual std::string getTxProof(const std::string &txid, const std::string &address, const std::string &message) const;
|
2017-09-12 04:05:41 +03:00
|
|
|
virtual bool checkTxProof(const std::string &txid, const std::string &address, const std::string &message, const std::string &signature, bool &good, uint64_t &received, bool &in_pool, uint64_t &confirmations);
|
2017-08-28 18:34:17 +03:00
|
|
|
virtual std::string getSpendProof(const std::string &txid, const std::string &message) const;
|
|
|
|
virtual bool checkSpendProof(const std::string &txid, const std::string &message, const std::string &signature, bool &good) const;
|
2017-12-28 15:50:10 +02:00
|
|
|
virtual std::string getReserveProof(bool all, uint32_t account_index, uint64_t amount, const std::string &message) const;
|
|
|
|
virtual bool checkReserveProof(const std::string &address, const std::string &message, const std::string &signature, bool &good, uint64_t &total, uint64_t &spent) const;
|
2016-11-08 11:58:46 +02:00
|
|
|
virtual std::string signMessage(const std::string &message);
|
|
|
|
virtual bool verifySignedMessage(const std::string &message, const std::string &address, const std::string &signature) const;
|
2016-12-14 13:18:52 +02:00
|
|
|
virtual void startRefresh();
|
|
|
|
virtual void pauseRefresh();
|
2017-01-09 00:53:24 +02:00
|
|
|
virtual bool parse_uri(const std::string &uri, std::string &address, std::string &payment_id, uint64_t &amount, std::string &tx_description, std::string &recipient_name, std::vector<std::string> &unknown_parameters, std::string &error);
|
2017-08-09 13:38:29 +03:00
|
|
|
virtual std::string getDefaultDataDir() const;
|
2017-08-05 00:31:33 +03:00
|
|
|
virtual bool lightWalletLogin(bool &isNewWallet) const;
|
|
|
|
virtual bool lightWalletImportWalletRequest(std::string &payment_id, uint64_t &fee, bool &new_request, bool &request_fulfilled, std::string &payment_address, std::string &status);
|
2016-11-08 11:58:46 +02:00
|
|
|
|
2016-04-20 13:01:00 +03:00
|
|
|
private:
|
2017-01-10 23:34:15 +02:00
|
|
|
void clearStatus() const;
|
2016-07-10 17:17:23 +03:00
|
|
|
void refreshThreadFunc();
|
|
|
|
void doRefresh();
|
2016-12-14 13:18:52 +02:00
|
|
|
bool daemonSynced() const;
|
2016-07-10 17:17:23 +03:00
|
|
|
void stopRefresh();
|
2016-09-30 02:11:28 +03:00
|
|
|
bool isNewWallet() const;
|
2017-08-05 00:28:38 +03:00
|
|
|
bool doInit(const std::string &daemon_address, uint64_t upper_transaction_size_limit = 0, bool ssl = false);
|
2016-04-20 13:01:00 +03:00
|
|
|
|
|
|
|
private:
|
2016-04-20 13:17:27 +03:00
|
|
|
friend class PendingTransactionImpl;
|
2017-01-08 14:17:09 +02:00
|
|
|
friend class UnsignedTransactionImpl;
|
2016-04-20 13:17:27 +03:00
|
|
|
friend class TransactionHistoryImpl;
|
2017-01-14 12:41:56 +02:00
|
|
|
friend struct Wallet2CallbackImpl;
|
2016-12-12 01:42:46 +02:00
|
|
|
friend class AddressBookImpl;
|
2017-02-19 04:42:10 +02:00
|
|
|
friend class SubaddressImpl;
|
|
|
|
friend class SubaddressAccountImpl;
|
2016-04-20 13:17:27 +03:00
|
|
|
|
2016-04-20 13:01:00 +03:00
|
|
|
tools::wallet2 * m_wallet;
|
2016-09-26 21:35:00 +03:00
|
|
|
mutable std::atomic<int> m_status;
|
|
|
|
mutable std::string m_errorString;
|
2016-04-20 13:01:00 +03:00
|
|
|
std::string m_password;
|
2016-04-22 13:21:08 +03:00
|
|
|
TransactionHistoryImpl * m_history;
|
2016-04-26 13:46:20 +03:00
|
|
|
bool m_trustedDaemon;
|
2016-05-05 22:24:00 +03:00
|
|
|
Wallet2CallbackImpl * m_wallet2Callback;
|
2016-12-12 01:42:46 +02:00
|
|
|
AddressBookImpl * m_addressBook;
|
2017-02-19 04:42:10 +02:00
|
|
|
SubaddressImpl * m_subaddress;
|
|
|
|
SubaddressAccountImpl * m_subaddressAccount;
|
2016-07-10 17:17:23 +03:00
|
|
|
|
|
|
|
// multi-threaded refresh stuff
|
|
|
|
std::atomic<bool> m_refreshEnabled;
|
|
|
|
std::atomic<bool> m_refreshThreadDone;
|
2016-09-26 22:50:10 +03:00
|
|
|
std::atomic<int> m_refreshIntervalMillis;
|
2016-07-14 13:33:49 +03:00
|
|
|
// synchronizing refresh loop;
|
2016-09-18 18:21:44 +03:00
|
|
|
boost::mutex m_refreshMutex;
|
2016-07-14 13:33:49 +03:00
|
|
|
|
|
|
|
// synchronizing sync and async refresh
|
2016-09-18 18:21:44 +03:00
|
|
|
boost::mutex m_refreshMutex2;
|
|
|
|
boost::condition_variable m_refreshCV;
|
|
|
|
boost::thread m_refreshThread;
|
2016-10-01 21:04:49 +03:00
|
|
|
// flag indicating wallet is recovering from seed
|
|
|
|
// so it shouldn't be considered as new and pull blocks (slow-refresh)
|
|
|
|
// instead of pulling hashes (fast-refresh)
|
2016-12-14 13:18:52 +02:00
|
|
|
std::atomic<bool> m_recoveringFromSeed;
|
2016-10-07 00:29:13 +03:00
|
|
|
std::atomic<bool> m_synchronized;
|
2016-12-14 13:18:52 +02:00
|
|
|
std::atomic<bool> m_rebuildWalletCache;
|
|
|
|
// cache connection status to avoid unnecessary RPC calls
|
|
|
|
mutable std::atomic<bool> m_is_connected;
|
2017-02-25 23:08:50 +02:00
|
|
|
boost::optional<epee::net_utils::http::login> m_daemon_login{};
|
2016-04-20 13:01:00 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
} // namespace
|
|
|
|
|
2016-12-13 17:21:38 +02:00
|
|
|
namespace Bitmonero = Monero;
|
|
|
|
|
2016-04-20 13:01:00 +03:00
|
|
|
#endif
|
|
|
|
|