38 #include <boost/thread/mutex.hpp> 39 #include <boost/thread/thread.hpp> 40 #include <boost/thread/condition_variable.hpp> 44 class TransactionHistoryImpl;
45 class PendingTransactionImpl;
46 class UnsignedTransactionImpl;
47 class AddressBookImpl;
49 class SubaddressAccountImpl;
50 struct Wallet2CallbackImpl;
57 bool create(
const std::string &
path,
const std::string &password,
58 const std::string &language);
60 const std::string &language)
const override;
61 bool open(
const std::string &
path,
const std::string &password);
62 bool recover(
const std::string &
path,
const std::string &password,
63 const std::string &
seed);
65 const std::string &password,
66 const std::string &language,
67 const std::string &address_string,
68 const std::string &viewkey_string,
69 const std::string &spendkey_string =
"");
75 const std::string &language,
76 const std::string &address_string,
77 const std::string &viewkey_string,
78 const std::string &spendkey_string =
"");
80 const std::string &password,
81 const std::string &device_name);
84 std::string
seed()
const override;
88 int status()
const override;
91 bool setPassword(
const std::string &password)
override;
92 std::string
address(uint32_t accountIndex = 0, uint32_t addressIndex = 0)
const override;
99 std::string
path()
const override;
100 bool store(
const std::string &
path)
override;
101 std::string
filename()
const override;
103 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)
override;
108 uint64_t
balance(uint32_t accountIndex = 0)
const override;
114 bool synchronized()
const override;
133 void addSubaddress(uint32_t accountIndex,
const std::string& label)
override;
134 std::string
getSubaddressLabel(uint32_t accountIndex, uint32_t addressIndex)
const override;
135 void setSubaddressLabel(uint32_t accountIndex, uint32_t addressIndex,
const std::string &label)
override;
140 bool finalizeMultisig(
const std::vector<std::string>& extraMultisigInfo)
override;
149 uint32_t subaddr_account = 0,
150 std::set<uint32_t> subaddr_indices = {})
override;
153 virtual UnsignedTransaction *
loadUnsignedTx(
const std::string &unsigned_filename)
override;
158 virtual TransactionHistory *
history()
override;
165 virtual bool setUserNote(
const std::string &txid,
const std::string ¬e)
override;
166 virtual std::string
getUserNote(
const std::string &txid)
const override;
167 virtual std::string
getTxKey(
const std::string &txid)
const override;
168 virtual bool checkTxKey(
const std::string &txid, std::string tx_key,
const std::string &
address, uint64_t &received,
bool &in_pool, uint64_t &confirmations)
override;
169 virtual std::string
getTxProof(
const std::string &txid,
const std::string &
address,
const std::string &message)
const override;
170 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)
override;
171 virtual std::string
getSpendProof(
const std::string &txid,
const std::string &message)
const override;
172 virtual bool checkSpendProof(
const std::string &txid,
const std::string &message,
const std::string &
signature,
bool &good)
const override;
173 virtual std::string
getReserveProof(
bool all, uint32_t account_index, uint64_t amount,
const std::string &message)
const override;
174 virtual bool checkReserveProof(
const std::string &
address,
const std::string &message,
const std::string &
signature,
bool &good, uint64_t &total, uint64_t &spent)
const override;
175 virtual std::string
signMessage(
const std::string &message)
override;
181 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)
override;
184 virtual bool lightWalletImportWalletRequest(std::string &payment_id, uint64_t &fee,
bool &new_request,
bool &request_fulfilled, std::string &payment_address, std::string &
status)
override;
186 virtual bool unblackballOutput(
const std::string &amount,
const std::string &offset)
override;
187 virtual bool getRing(
const std::string &
key_image, std::vector<uint64_t> &ring)
const override;
188 virtual bool getRings(
const std::string &txid, std::vector<std::pair<std::string, std::vector<uint64_t>>> &rings)
const override;
189 virtual bool setRing(
const std::string &
key_image,
const std::vector<uint64_t> &ring,
bool relative)
override;
207 bool doInit(
const std::string &daemon_address, uint64_t upper_transaction_size_limit = 0,
bool ssl =
false);
virtual bool lightWalletLogin(bool &isNewWallet) const override
Light wallet authenticate and login.
Definition: wallet.cpp:872
WalletImpl(NetworkType nettype=MAINNET, uint64_t kdf_rounds=1)
Definition: wallet.cpp:369
virtual Subaddress * subaddress() override
Definition: wallet.cpp:1562
uint64_t daemonBlockChainHeight() const override
daemonBlockChainHeight - returns daemon blockchain height
Definition: wallet.cpp:943
size_t importMultisigImages(const std::vector< std::string > &images) override
importMultisigImages - imports other participants' multisig images
Definition: wallet.cpp:1224
SubaddressAccountImpl * m_subaddressAccount
Definition: wallet.h:227
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="")
Definition: wallet.cpp:529
virtual UnsignedTransaction * loadUnsignedTx(const std::string &unsigned_filename) override
loadUnsignedTx - creates transaction from unsigned tx file
Definition: wallet.cpp:1029
std::string secretViewKey() const override
secretViewKey - returns secret view key
Definition: wallet.cpp:800
std::string getSubaddressLabel(uint32_t accountIndex, uint32_t addressIndex) const override
getSubaddressLabel - gets the label of the specified subaddress
Definition: wallet.cpp:1128
virtual void segregationHeight(uint64_t height) override
sets the height where segregation should occur
Definition: wallet.cpp:2238
void refreshAsync() override
refreshAsync - refreshes wallet asynchronously.
Definition: wallet.cpp:1006
void statusWithErrorString(int &status, std::string &errorString) const override
returns both error and error string atomically. suggested to use in instead of status() and errorStri...
Definition: wallet.cpp:768
virtual std::string getTxProof(const std::string &txid, const std::string &address, const std::string &message) const override
Definition: wallet.cpp:1684
boost::optional< epee::net_utils::http::login > m_daemon_login
Definition: wallet.h:249
Device
Definition: wallet2_api.h:376
std::string errorString() const override
in case error status, returns error string
Definition: wallet.cpp:762
bool exportMultisigImages(std::string &images) override
exportMultisigImages - exports transfers' key images
Definition: wallet.cpp:1208
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) override
Definition: wallet.cpp:2079
void setRecoveringFromSeed(bool recoveringFromSeed) override
setRecoveringFromSeed - set state recover form seed
Definition: wallet.cpp:907
Wallet2CallbackImpl * m_wallet2Callback
Definition: wallet.h:224
bool finalizeMultisig(const std::vector< std::string > &extraMultisigInfo) override
finalizeMultisig - finalizes N - 1 / N multisig wallets creation
Definition: wallet.cpp:1190
void doRefresh()
Definition: wallet.cpp:1980
virtual bool lightWalletImportWalletRequest(std::string &payment_id, uint64_t &fee, bool &new_request, bool &request_fulfilled, std::string &payment_address, std::string &status) override
Initiates a light wallet import wallet request.
Definition: wallet.cpp:877
int m_status
Definition: wallet.h:220
void setRecoveringFromDevice(bool recoveringFromDevice) override
setRecoveringFromDevice - set state to recovering from device
Definition: wallet.cpp:912
void setAutoRefreshInterval(int millis) override
setAutoRefreshInterval - setup interval for automatic refresh.
Definition: wallet.cpp:1013
uint64_t height
Definition: blockchain.cpp:88
void refreshThreadFunc()
Definition: wallet.cpp:1950
std::atomic< bool > m_recoveringFromSeed
Definition: wallet.h:243
void setStatus(int status, const std::string &message) const
Definition: wallet.cpp:1943
std::atomic< bool > m_rebuildWalletCache
Definition: wallet.h:246
bool createWatchOnly(const std::string &path, const std::string &password, const std::string &language) const override
createWatchOnly - Creates a watch only wallet
Definition: wallet.cpp:454
std::string publicMultisigSignerKey() const override
publicMultisigSignerKey - returns public signer key
Definition: wallet.cpp:820
std::string path() const override
Definition: wallet.cpp:830
virtual uint32_t defaultMixin() const override
defaultMixin - returns number of mixins used in transactions
Definition: wallet.cpp:1578
bool recoverFromDevice(const std::string &path, const std::string &password, const std::string &device_name)
Definition: wallet.cpp:625
bool hasMultisigPartialKeyImages() const override
hasMultisigPartialKeyImages - checks if wallet needs to import multisig key images from other partici...
Definition: wallet.cpp:1252
Definition: wallet2_api.h:56
bool daemonSynced() const
Definition: wallet.cpp:984
uint64_t approximateBlockChainHeight() const override
approximateBlockChainHeight - returns approximate blockchain height calculated from date/time ...
Definition: wallet.cpp:939
bool create(const std::string &path, const std::string &password, const std::string &language)
Definition: wallet.cpp:417
virtual bool unblackballOutput(const std::string &amount, const std::string &offset) override
unblackballs an output
Definition: wallet.cpp:2155
int status() const override
returns wallet status (Status_Ok | Status_Error)
Definition: wallet.cpp:756
std::atomic< bool > m_is_connected
Definition: wallet.h:248
TransactionHistoryImpl * m_history
Definition: wallet.h:223
virtual PendingTransaction * createSweepUnmixableTransaction() override
createSweepUnmixableTransaction creates transaction with unmixable outputs.
Definition: wallet.cpp:1465
std::string publicViewKey() const override
publicViewKey - returns public view key
Definition: wallet.cpp:805
void setStatusCritical(const std::string &message) const
Definition: wallet.cpp:1938
Interface for wallet operations. TODO: check if /include/IWallet.h is still actual.
Definition: wallet2_api.h:374
virtual void pauseRefresh() override
pauseRefresh - pause refresh thread
Definition: wallet.cpp:2032
Definition: address_book.cpp:40
bool watchOnly() const override
watchOnly - checks if wallet is watch only
Definition: wallet.cpp:1921
void setStatusError(const std::string &message) const
Definition: wallet.cpp:1933
boost::condition_variable m_refreshCV
Definition: wallet.h:238
Definition: wallet2_api.h:45
virtual bool verifySignedMessage(const std::string &message, const std::string &address, const std::string &signature) const override
verifySignedMessage - verify a signature matches a given message
Definition: wallet.cpp:1833
bool exportKeyImages(const std::string &filename) override
exportKeyImages - exports key images to file
Definition: wallet.cpp:1064
boost::thread m_refreshThread
Definition: wallet.h:239
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) override
Definition: wallet.cpp:1712
bool recover(const std::string &path, const std::string &password, const std::string &seed)
Definition: wallet.cpp:678
virtual std::string getSpendProof(const std::string &txid, const std::string &message) const override
Definition: wallet.cpp:1741
virtual SubaddressAccount * subaddressAccount() override
Definition: wallet.cpp:1567
std::string address(uint32_t accountIndex=0, uint32_t addressIndex=0) const override
Definition: wallet.cpp:786
bool setPassword(const std::string &password) override
Definition: wallet.cpp:774
std::string secretSpendKey() const override
secretSpendKey - returns secret spend key
Definition: wallet.cpp:810
bool importKeyImages(const std::string &filename) override
importKeyImages - imports key images from file
Definition: wallet.cpp:1089
virtual std::string getTxKey(const std::string &txid) const override
Definition: wallet.cpp:1609
virtual void keyReuseMitigation2(bool mitigation) override
secondary key reuse mitigation
Definition: wallet.cpp:2243
std::string seed() const override
Definition: wallet.cpp:738
boost::mutex m_refreshMutex2
Definition: wallet.h:237
virtual void startRefresh() override
StartRefresh - Start/resume refresh thread (refresh every 10 seconds)
Definition: wallet.cpp:2011
Priority
Definition: wallet2_api.h:79
void setSeedLanguage(const std::string &arg) override
Definition: wallet.cpp:751
bool trustedDaemon() const override
Definition: wallet.cpp:1916
Device getDeviceType() const override
Queries backing device for wallet keys.
Definition: wallet.cpp:642
size_t numSubaddressAccounts() const override
numSubaddressAccounts - returns the number of existing subaddress accounts
Definition: wallet.cpp:1116
Definition: wallet2_api.h:81
virtual bool verifyMessageWithPublicKey(const std::string &message, const std::string &publicKey, const std::string &signature) const override
verifyMessageWithPublicKey verifies that message was signed with the given public key ...
Definition: wallet.cpp:1864
uint64_t balance(uint32_t accountIndex=0) const override
Definition: wallet.cpp:922
MultisigState multisig() const override
multisig - returns current state of multisig wallet creation process
Definition: wallet.cpp:1154
Definition: subaddress.h:36
std::string publicSpendKey() const override
publicSpendKey - returns public spend key
Definition: wallet.cpp:815
virtual bool setUserNote(const std::string &txid, const std::string ¬e) override
setUserNote - attach an arbitrary string note to a txid
Definition: wallet.cpp:1588
std::atomic< int > m_refreshIntervalMillis
Definition: wallet.h:232
void setRefreshFromBlockHeight(uint64_t refresh_from_block_height) override
setRefreshFromBlockHeight - start refresh from block height on recover
Definition: wallet.cpp:902
std::string m_password
Definition: wallet.h:222
static void add(ge_p3 &p3, const ge_cached &other)
Definition: multiexp.cc:124
std::string m_errorString
Definition: wallet.h:221
int autoRefreshInterval() const override
autoRefreshInterval - returns automatic refresh interval in millis
Definition: wallet.cpp:1024
static void error(const std::string &category, const std::string &str)
Definition: wallet.cpp:364
ConnectionStatus
Definition: wallet2_api.h:387
bool store(const std::string &path) override
store - stores wallet to file.
Definition: wallet.cpp:835
Definition: transaction_history.h:38
virtual bool getRings(const std::string &txid, std::vector< std::pair< std::string, std::vector< uint64_t >>> &rings) const override
gets the rings used for a txid, if any
Definition: wallet.cpp:2194
bool close(bool store=true)
Definition: wallet.cpp:710
bool useForkRules(uint8_t version, int64_t early_blocks) const override
check if hard fork rules should be used
Definition: wallet.cpp:2112
std::string filename() const override
filename - returns wallet filename
Definition: wallet.cpp:853
~WalletImpl()
Definition: wallet.cpp:398
virtual std::string signMultisigParticipant(const std::string &message) const override
signMultisigParticipant signs given message with the multisig public signer key
Definition: wallet.cpp:1843
virtual bool checkTxKey(const std::string &txid, std::string tx_key, const std::string &address, uint64_t &received, bool &in_pool, uint64_t &confirmations) override
Definition: wallet.cpp:1636
virtual bool checkReserveProof(const std::string &address, const std::string &message, const std::string &signature, bool &good, uint64_t &total, uint64_t &spent) const override
Definition: wallet.cpp:1801
NetworkType
Definition: wallet2_api.h:44
void setSubaddressLookahead(uint32_t major, uint32_t minor) override
setSubaddressLookahead - set size of subaddress lookahead
Definition: wallet.cpp:917
AddressBookImpl * m_addressBook
Definition: wallet.h:225
virtual bool getRing(const std::string &key_image, std::vector< uint64_t > &ring) const override
gets the ring used for a key image, if any
Definition: wallet.cpp:2177
int l
Definition: base.py:3
uint64_t blockChainHeight() const override
blockChainHeight - returns current blockchain height
Definition: wallet.cpp:932
bool refresh() override
refresh - refreshes the wallet, updating transactions from daemon
Definition: wallet.cpp:997
virtual bool lockKeysFile() override
locks/unlocks the keys file; returns true on success
Definition: wallet.cpp:2248
boost::mutex m_statusMutex
Definition: wallet.h:219
bool open(const std::string &path, const std::string &password)
Definition: wallet.cpp:647
std::string getSeedLanguage() const override
Definition: wallet.cpp:746
bool connectToDaemon() override
connectToDaemon - connects to the daemon. TODO: check if it can be removed
Definition: wallet.cpp:1887
Definition: pending_transaction.h:41
uint8_t version
Definition: blockchain.cpp:87
virtual std::string getReserveProof(bool all, uint32_t account_index, uint64_t amount, const std::string &message) const override
getReserveProof - Generates a proof that proves the reserve of unspent funds Parameters account_index...
Definition: wallet.cpp:1783
ConnectionStatus connected() const override
connected - checks if the wallet connected to the daemon
Definition: wallet.cpp:1899
virtual void disposeTransaction(PendingTransaction *t) override
disposeTransaction - destroys transaction object
Definition: wallet.cpp:1547
NetworkType nettype() const override
Definition: wallet.h:126
PendingTransaction * restoreMultisigTransaction(const std::string &signData) override
restoreMultisigTransaction creates PendingTransaction from signData
Definition: wallet.cpp:1266
std::string getMultisigInfo() const override
getMultisigInfo
Definition: wallet.cpp:1161
POD_CLASS signature
Definition: crypto.h:95
virtual std::string signMessage(const std::string &message) override
Definition: wallet.cpp:1828
Definition: subaddress_account.h:36
virtual void setListener(WalletListener *l) override
Definition: wallet.cpp:1572
std::atomic< bool > m_refreshThreadDone
Definition: wallet.h:231
bool doInit(const std::string &daemon_address, uint64_t upper_transaction_size_limit=0, bool ssl=false)
Definition: wallet.cpp:2052
virtual void setDefaultMixin(uint32_t arg) override
setDefaultMixin - setum number of mixins to be used for new transactions
Definition: wallet.cpp:1583
std::string keysFilename() const override
keysFilename - returns keys filename. usually this formed as "wallet_filename".keys ...
Definition: wallet.cpp:858
POD_CLASS key_image
Definition: crypto.h:89
virtual TransactionHistory * history() override
Definition: wallet.cpp:1552
Definition: address_book.h:38
void addSubaddressAccount(const std::string &label) override
addSubaddressAccount - appends a new subaddress account at the end of the last major index of existin...
Definition: wallet.cpp:1112
virtual std::string getDefaultDataDir() const override
Definition: wallet.cpp:2084
virtual AddressBook * addressBook() override
Definition: wallet.cpp:1557
SubaddressImpl * m_subaddress
Definition: wallet.h:226
void setSubaddressLabel(uint32_t accountIndex, uint32_t addressIndex, const std::string &label) override
setSubaddressLabel - sets the label of the specified subaddress
Definition: wallet.cpp:1141
std::string integratedAddress(const std::string &payment_id) const override
integratedAddress - returns integrated address for current wallet address and given payment_id...
Definition: wallet.cpp:791
virtual bool setRing(const std::string &key_image, const std::vector< uint64_t > &ring, bool relative) override
sets the ring used for a key image
Definition: wallet.cpp:2216
uint64_t unlockedBalance(uint32_t accountIndex=0) const override
Definition: wallet.cpp:927
void hardForkInfo(uint8_t &version, uint64_t &earliest_height) const override
returns current hard fork info
Definition: wallet.cpp:2107
Transaction-like interface for sending money.
Definition: wallet2_api.h:71
Definition: wallet2_api.h:318
Definition: wallet.cpp:116
virtual void segregatePreForkOutputs(bool segregate) override
sets whether pre-fork outs are to be segregated
Definition: wallet.cpp:2233
PendingTransaction * createTransaction(const std::string &dst_addr, const std::string &payment_id, optional< uint64_t > amount, uint32_t mixin_count, PendingTransaction::Priority priority=PendingTransaction::Priority_Low, uint32_t subaddr_account=0, std::set< uint32_t > subaddr_indices={}) override
createTransaction creates transaction. if dst_addr is an integrated address, payment_id is ignored ...
Definition: wallet.cpp:1304
uint64_t daemonBlockChainTargetHeight() const override
daemonBlockChainTargetHeight - returns daemon blockchain target height
Definition: wallet.cpp:962
virtual bool isKeysFileLocked() override
returns true if the keys file is locked
Definition: wallet.cpp:2258
Definition: unsigned_transaction.h:41
static void info(const std::string &category, const std::string &str)
Definition: wallet.cpp:356
virtual bool blackballOutputs(const std::vector< std::string > &pubkeys, bool add) override
blackballs a set of outputs
Definition: wallet.cpp:2117
virtual bool unlockKeysFile() override
Definition: wallet.cpp:2253
virtual std::string getUserNote(const std::string &txid) const override
getUserNote - return an arbitrary string note attached to a txid
Definition: wallet.cpp:1599
std::atomic< bool > m_refreshEnabled
Definition: wallet.h:230
void clearStatus() const
Definition: wallet.cpp:1926
void stopRefresh()
Definition: wallet.cpp:2022
tools::wallet2 * m_wallet
Definition: wallet.h:218
std::string makeMultisig(const std::vector< std::string > &info, uint32_t threshold) override
makeMultisig - switches wallet in multisig state. The one and only creation phase for N / N wallets ...
Definition: wallet.cpp:1173
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) override
init - initializes wallet with daemon connection params. if daemon_address is local address...
Definition: wallet.cpp:863
std::atomic< bool > m_synchronized
Definition: wallet.h:245
bool rescanSpent() override
Definition: wallet.cpp:2089
bool submitTransaction(const std::string &fileName) override
submitTransaction - submits transaction in signed tx file
Definition: wallet.cpp:1046
boost::mutex m_refreshMutex
Definition: wallet.h:234
void addSubaddress(uint32_t accountIndex, const std::string &label) override
addSubaddress - appends a new subaddress at the end of the last minor index of the specified subaddre...
Definition: wallet.cpp:1124
virtual bool checkSpendProof(const std::string &txid, const std::string &message, const std::string &signature, bool &good) const override
Definition: wallet.cpp:1761
void setTrustedDaemon(bool arg) override
Definition: wallet.cpp:1911
bool isNewWallet() const
Definition: wallet.cpp:2042
std::atomic< bool > m_recoveringFromDevice
Definition: wallet.h:244
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="")
Definition: wallet.cpp:520
uint64_t getRefreshFromBlockHeight() const override
getRestoreHeight - get wallet creation height
Definition: wallet.h:120
size_t numSubaddresses(uint32_t accountIndex) const override
numSubaddresses - returns the number of existing subaddresses associated with the specified subaddres...
Definition: wallet.cpp:1120
uint8_t threshold
Definition: blockchain.cpp:89