Monero
wallet.h
Go to the documentation of this file.
1 // Copyright (c) 2014-2020, The Monero Project
2 //
3 // All rights reserved.
4 //
5 // Redistribution and use in source and binary forms, with or without modification, are
6 // permitted provided that the following conditions are met:
7 //
8 // 1. Redistributions of source code must retain the above copyright notice, this list of
9 // conditions and the following disclaimer.
10 //
11 // 2. Redistributions in binary form must reproduce the above copyright notice, this list
12 // of conditions and the following disclaimer in the documentation and/or other
13 // materials provided with the distribution.
14 //
15 // 3. Neither the name of the copyright holder nor the names of its contributors may be
16 // used to endorse or promote products derived from this software without specific
17 // prior written permission.
18 //
19 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
20 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21 // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
22 // THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
24 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 // INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
26 // STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
27 // THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 //
29 // Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers
30 
31 #ifndef WALLET_IMPL_H
32 #define WALLET_IMPL_H
33 
34 #include "wallet/api/wallet2_api.h"
35 #include "wallet/wallet2.h"
36 
37 #include <string>
38 #include <boost/thread/mutex.hpp>
39 #include <boost/thread/thread.hpp>
40 #include <boost/thread/condition_variable.hpp>
41 
42 
43 namespace Monero {
44 class TransactionHistoryImpl;
45 class PendingTransactionImpl;
46 class UnsignedTransactionImpl;
47 class AddressBookImpl;
48 class SubaddressImpl;
49 class SubaddressAccountImpl;
50 struct Wallet2CallbackImpl;
51 
52 class WalletImpl : public Wallet
53 {
54 public:
55  WalletImpl(NetworkType nettype = MAINNET, uint64_t kdf_rounds = 1);
56  ~WalletImpl();
57  bool create(const std::string &path, const std::string &password,
58  const std::string &language);
59  bool createWatchOnly(const std::string &path, const std::string &password,
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, const std::string &seed_offset = {});
64  bool recoverFromKeysWithPassword(const std::string &path,
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 = "");
70  // following two methods are deprecated since they create passwordless wallets
71  // use the two equivalent methods above
72  bool recover(const std::string &path, const std::string &seed);
73  // deprecated: use recoverFromKeysWithPassword() instead
74  bool recoverFromKeys(const std::string &path,
75  const std::string &language,
76  const std::string &address_string,
77  const std::string &viewkey_string,
78  const std::string &spendkey_string = "");
79  bool recoverFromDevice(const std::string &path,
80  const std::string &password,
81  const std::string &device_name);
82  Device getDeviceType() const override;
83  bool close(bool store = true);
84  std::string seed() const override;
85  std::string getSeedLanguage() const override;
86  void setSeedLanguage(const std::string &arg) override;
87  // void setListener(Listener *) {}
88  int status() const override;
89  std::string errorString() const override;
90  void statusWithErrorString(int& status, std::string& errorString) const override;
91  bool setPassword(const std::string &password) override;
92  bool setDevicePin(const std::string &password) override;
93  bool setDevicePassphrase(const std::string &password) override;
94  std::string address(uint32_t accountIndex = 0, uint32_t addressIndex = 0) const override;
95  std::string integratedAddress(const std::string &payment_id) const override;
96  std::string secretViewKey() const override;
97  std::string publicViewKey() const override;
98  std::string secretSpendKey() const override;
99  std::string publicSpendKey() const override;
100  std::string publicMultisigSignerKey() const override;
101  std::string path() const override;
102  void stop() override;
103  bool store(const std::string &path) override;
104  std::string filename() const override;
105  std::string keysFilename() const override;
106  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, const std::string &proxy_address = "") override;
107  bool connectToDaemon() override;
108  ConnectionStatus connected() const override;
109  void setTrustedDaemon(bool arg) override;
110  bool trustedDaemon() const override;
111  bool setProxy(const std::string &address) override;
112  uint64_t balance(uint32_t accountIndex = 0) const override;
113  uint64_t unlockedBalance(uint32_t accountIndex = 0) const override;
114  uint64_t blockChainHeight() const override;
115  uint64_t approximateBlockChainHeight() const override;
116  uint64_t estimateBlockChainHeight() const override;
117  uint64_t daemonBlockChainHeight() const override;
118  uint64_t daemonBlockChainTargetHeight() const override;
119  bool synchronized() const override;
120  bool refresh() override;
121  void refreshAsync() override;
122  bool rescanBlockchain() override;
123  void rescanBlockchainAsync() override;
124  void setAutoRefreshInterval(int millis) override;
125  int autoRefreshInterval() const override;
126  void setRefreshFromBlockHeight(uint64_t refresh_from_block_height) override;
127  uint64_t getRefreshFromBlockHeight() const override { return m_wallet->get_refresh_from_block_height(); };
128  void setRecoveringFromSeed(bool recoveringFromSeed) override;
129  void setRecoveringFromDevice(bool recoveringFromDevice) override;
130  void setSubaddressLookahead(uint32_t major, uint32_t minor) override;
131  bool watchOnly() const override;
132  bool rescanSpent() override;
133  NetworkType nettype() const override {return static_cast<NetworkType>(m_wallet->nettype());}
134  void hardForkInfo(uint8_t &version, uint64_t &earliest_height) const override;
135  bool useForkRules(uint8_t version, int64_t early_blocks) const override;
136 
137  void addSubaddressAccount(const std::string& label) override;
138  size_t numSubaddressAccounts() const override;
139  size_t numSubaddresses(uint32_t accountIndex) const override;
140  void addSubaddress(uint32_t accountIndex, const std::string& label) override;
141  std::string getSubaddressLabel(uint32_t accountIndex, uint32_t addressIndex) const override;
142  void setSubaddressLabel(uint32_t accountIndex, uint32_t addressIndex, const std::string &label) override;
143 
144  MultisigState multisig() const override;
145  std::string getMultisigInfo() const override;
146  std::string makeMultisig(const std::vector<std::string>& info, uint32_t threshold) override;
147  std::string exchangeMultisigKeys(const std::vector<std::string> &info) override;
148  bool finalizeMultisig(const std::vector<std::string>& extraMultisigInfo) override;
149  bool exportMultisigImages(std::string& images) override;
150  size_t importMultisigImages(const std::vector<std::string>& images) override;
151  bool hasMultisigPartialKeyImages() const override;
152  PendingTransaction* restoreMultisigTransaction(const std::string& signData) override;
153 
154  PendingTransaction * createTransactionMultDest(const std::vector<std::string> &dst_addr, const std::string &payment_id,
155  optional<std::vector<uint64_t>> amount, uint32_t mixin_count,
157  uint32_t subaddr_account = 0,
158  std::set<uint32_t> subaddr_indices = {}) override;
159  PendingTransaction * createTransaction(const std::string &dst_addr, const std::string &payment_id,
160  optional<uint64_t> amount, uint32_t mixin_count,
162  uint32_t subaddr_account = 0,
163  std::set<uint32_t> subaddr_indices = {}) override;
164  virtual PendingTransaction * createSweepUnmixableTransaction() override;
165  bool submitTransaction(const std::string &fileName) override;
166  virtual UnsignedTransaction * loadUnsignedTx(const std::string &unsigned_filename) override;
167  bool exportKeyImages(const std::string &filename) override;
168  bool importKeyImages(const std::string &filename) override;
169 
170  virtual void disposeTransaction(PendingTransaction * t) override;
171  virtual uint64_t estimateTransactionFee(const std::vector<std::pair<std::string, uint64_t>> &destinations,
172  PendingTransaction::Priority priority) const override;
173  virtual TransactionHistory * history() override;
174  virtual AddressBook * addressBook() override;
175  virtual Subaddress * subaddress() override;
176  virtual SubaddressAccount * subaddressAccount() override;
177  virtual void setListener(WalletListener * l) override;
178  virtual uint32_t defaultMixin() const override;
179  virtual void setDefaultMixin(uint32_t arg) override;
180 
181  virtual bool setCacheAttribute(const std::string &key, const std::string &val) override;
182  virtual std::string getCacheAttribute(const std::string &key) const override;
183 
184  virtual bool setUserNote(const std::string &txid, const std::string &note) override;
185  virtual std::string getUserNote(const std::string &txid) const override;
186  virtual std::string getTxKey(const std::string &txid) const override;
187  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;
188  virtual std::string getTxProof(const std::string &txid, const std::string &address, const std::string &message) const override;
189  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;
190  virtual std::string getSpendProof(const std::string &txid, const std::string &message) const override;
191  virtual bool checkSpendProof(const std::string &txid, const std::string &message, const std::string &signature, bool &good) const override;
192  virtual std::string getReserveProof(bool all, uint32_t account_index, uint64_t amount, const std::string &message) const override;
193  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;
194  virtual std::string signMessage(const std::string &message) override;
195  virtual bool verifySignedMessage(const std::string &message, const std::string &address, const std::string &signature) const override;
196  virtual std::string signMultisigParticipant(const std::string &message) const override;
197  virtual bool verifyMessageWithPublicKey(const std::string &message, const std::string &publicKey, const std::string &signature) const override;
198  virtual void startRefresh() override;
199  virtual void pauseRefresh() override;
200  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;
201  virtual std::string getDefaultDataDir() const override;
202  virtual bool lightWalletLogin(bool &isNewWallet) const override;
203  virtual bool lightWalletImportWalletRequest(std::string &payment_id, uint64_t &fee, bool &new_request, bool &request_fulfilled, std::string &payment_address, std::string &status) override;
204  virtual bool blackballOutputs(const std::vector<std::string> &outputs, bool add) override;
205  virtual bool blackballOutput(const std::string &amount, const std::string &offset) override;
206  virtual bool unblackballOutput(const std::string &amount, const std::string &offset) override;
207  virtual bool getRing(const std::string &key_image, std::vector<uint64_t> &ring) const override;
208  virtual bool getRings(const std::string &txid, std::vector<std::pair<std::string, std::vector<uint64_t>>> &rings) const override;
209  virtual bool setRing(const std::string &key_image, const std::vector<uint64_t> &ring, bool relative) override;
210  virtual void segregatePreForkOutputs(bool segregate) override;
211  virtual void segregationHeight(uint64_t height) override;
212  virtual void keyReuseMitigation2(bool mitigation) override;
213  virtual bool lockKeysFile() override;
214  virtual bool unlockKeysFile() override;
215  virtual bool isKeysFileLocked() override;
216  virtual uint64_t coldKeyImageSync(uint64_t &spent, uint64_t &unspent) override;
217  virtual void deviceShowAddress(uint32_t accountIndex, uint32_t addressIndex, const std::string &paymentId) override;
218 
219 private:
220  void clearStatus() const;
221  void setStatusError(const std::string& message) const;
222  void setStatusCritical(const std::string& message) const;
223  void setStatus(int status, const std::string& message) const;
224  void refreshThreadFunc();
225  void doRefresh();
226  bool daemonSynced() const;
227  void stopRefresh();
228  bool isNewWallet() const;
230  bool doInit(const std::string &daemon_address, const std::string &proxy_address, uint64_t upper_transaction_size_limit = 0, bool ssl = false);
231 
232 private:
234  friend class UnsignedTransactionImpl;
236  friend struct Wallet2CallbackImpl;
237  friend class AddressBookImpl;
238  friend class SubaddressImpl;
239  friend class SubaddressAccountImpl;
240 
241  std::unique_ptr<tools::wallet2> m_wallet;
242  mutable boost::mutex m_statusMutex;
243  mutable int m_status;
244  mutable std::string m_errorString;
245  std::string m_password;
246  std::unique_ptr<TransactionHistoryImpl> m_history;
247  std::unique_ptr<Wallet2CallbackImpl> m_wallet2Callback;
248  std::unique_ptr<AddressBookImpl> m_addressBook;
249  std::unique_ptr<SubaddressImpl> m_subaddress;
250  std::unique_ptr<SubaddressAccountImpl> m_subaddressAccount;
251 
252  // multi-threaded refresh stuff
253  std::atomic<bool> m_refreshEnabled;
254  std::atomic<bool> m_refreshThreadDone;
255  std::atomic<int> m_refreshIntervalMillis;
256  std::atomic<bool> m_refreshShouldRescan;
257  // synchronizing refresh loop;
258  boost::mutex m_refreshMutex;
259 
260  // synchronizing sync and async refresh
261  boost::mutex m_refreshMutex2;
262  boost::condition_variable m_refreshCV;
263  boost::thread m_refreshThread;
264  // flag indicating wallet is recovering from seed
265  // so it shouldn't be considered as new and pull blocks (slow-refresh)
266  // instead of pulling hashes (fast-refresh)
267  std::atomic<bool> m_recoveringFromSeed;
268  std::atomic<bool> m_recoveringFromDevice;
269  std::atomic<bool> m_synchronized;
270  std::atomic<bool> m_rebuildWalletCache;
271  // cache connection status to avoid unnecessary RPC calls
272  mutable std::atomic<bool> m_is_connected;
273  boost::optional<epee::net_utils::http::login> m_daemon_login{};
274 };
275 
276 
277 } // namespace
278 
279 namespace Bitmonero = Monero;
280 
281 #endif
282 
Definition: address_book.h:39
Definition: pending_transaction.h:42
Definition: subaddress_account.h:37
Definition: subaddress.h:37
Definition: transaction_history.h:39
Definition: unsigned_transaction.h:42
Definition: wallet.h:53
virtual uint32_t defaultMixin() const override
defaultMixin - returns number of mixins used in transactions
Definition: wallet.cpp:1732
void setAutoRefreshInterval(int millis) override
setAutoRefreshInterval - setup interval for automatic refresh.
Definition: wallet.cpp:1116
void rescanBlockchainAsync() override
rescanBlockchainAsync - rescans wallet asynchronously, starting from genesys
Definition: wallet.cpp:1110
std::atomic< bool > m_is_connected
Definition: wallet.h:272
bool create(const std::string &path, const std::string &password, const std::string &language)
Definition: wallet.cpp:469
virtual std::string getUserNote(const std::string &txid) const override
getUserNote - return an arbitrary string note attached to a txid
Definition: wallet.cpp:1766
void refreshAsync() override
refreshAsync - refreshes wallet asynchronously.
Definition: wallet.cpp:1095
std::atomic< bool > m_refreshThreadDone
Definition: wallet.h:254
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:1959
virtual void deviceShowAddress(uint32_t accountIndex, uint32_t addressIndex, const std::string &paymentId) override
shows address on device display
Definition: wallet.cpp:2492
bool importKeyImages(const std::string &filename) override
importKeyImages - imports key images from file
Definition: wallet.cpp:1196
virtual bool isKeysFileLocked() override
returns true if the keys file is locked
Definition: wallet.cpp:2482
bool setDevicePassphrase(const std::string &password) override
Definition: wallet.cpp:853
virtual void startRefresh() override
StartRefresh - Start/resume refresh thread (refresh every 10 seconds)
Definition: wallet.cpp:2199
bool isNewWallet() const
Definition: wallet.cpp:2230
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:1591
bool watchOnly() const override
watchOnly - checks if wallet is watch only
Definition: wallet.cpp:2102
std::unique_ptr< SubaddressAccountImpl > m_subaddressAccount
Definition: wallet.h:250
std::string filename() const override
filename - returns wallet filename
Definition: wallet.cpp:936
virtual SubaddressAccount * subaddressAccount() override
Definition: wallet.cpp:1721
std::atomic< bool > m_recoveringFromSeed
Definition: wallet.h:267
uint64_t daemonBlockChainTargetHeight() const override
daemonBlockChainTargetHeight - returns daemon blockchain target height
Definition: wallet.cpp:1051
std::atomic< bool > m_refreshEnabled
Definition: wallet.h:253
std::atomic< bool > m_recoveringFromDevice
Definition: wallet.h:268
virtual bool unblackballOutput(const std::string &amount, const std::string &offset) override
unblackballs an output
Definition: wallet.cpp:2379
std::atomic< bool > m_refreshShouldRescan
Definition: wallet.h:256
void stopRefresh()
Definition: wallet.cpp:2210
std::string m_errorString
Definition: wallet.h:244
size_t numSubaddresses(uint32_t accountIndex) const override
numSubaddresses - returns the number of existing subaddresses associated with the specified subaddres...
Definition: wallet.cpp:1227
void setTrustedDaemon(bool arg) override
Definition: wallet.cpp:2087
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:1977
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:1888
bool setPassword(const std::string &password) override
Definition: wallet.cpp:830
uint64_t blockChainHeight() const override
blockChainHeight - returns current blockchain height
Definition: wallet.cpp:1015
bool rescanSpent() override
Definition: wallet.cpp:2291
std::unique_ptr< SubaddressImpl > m_subaddress
Definition: wallet.h:249
virtual void segregatePreForkOutputs(bool segregate) override
sets whether pre-fork outs are to be segregated
Definition: wallet.cpp:2457
virtual void pauseRefresh() override
pauseRefresh - pause refresh thread
Definition: wallet.cpp:2220
void stop() override
stop - interrupts wallet refresh() loop once (doesn't stop background refresh thread)
Definition: wallet.cpp:913
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:2401
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:581
size_t importMultisigImages(const std::vector< std::string > &images) override
importMultisigImages - imports other participants' multisig images
Definition: wallet.cpp:1345
virtual bool unlockKeysFile() override
Definition: wallet.cpp:2477
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:869
virtual bool setCacheAttribute(const std::string &key, const std::string &val) override
setCacheAttribute - attach an arbitrary string to a wallet cache attribute
Definition: wallet.cpp:1742
int status() const override
returns wallet status (Status_Ok | Status_Error)
Definition: wallet.cpp:812
void setSubaddressLookahead(uint32_t major, uint32_t minor) override
setSubaddressLookahead - set size of subaddress lookahead
Definition: wallet.cpp:1000
virtual uint64_t coldKeyImageSync(uint64_t &spent, uint64_t &unspent) override
cold-device protocol key image sync
Definition: wallet.cpp:2487
Device getDeviceType() const override
Queries backing device for wallet keys.
Definition: wallet.cpp:694
virtual std::string getTxKey(const std::string &txid) const override
Definition: wallet.cpp:1776
virtual std::string signMultisigParticipant(const std::string &message) const override
signMultisigParticipant signs given message with the multisig public signer key
Definition: wallet.cpp:2019
virtual std::string getSpendProof(const std::string &txid, const std::string &message) const override
Definition: wallet.cpp:1917
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:1231
bool daemonSynced() const
Definition: wallet.cpp:1073
boost::mutex m_refreshMutex2
Definition: wallet.h:261
std::string publicMultisigSignerKey() const override
publicMultisigSignerKey - returns public signer key
Definition: wallet.cpp:898
PendingTransaction * restoreMultisigTransaction(const std::string &signData) override
restoreMultisigTransaction creates PendingTransaction from signData
Definition: wallet.cpp:1387
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:2009
boost::mutex m_statusMutex
Definition: wallet.h:242
bool store(const std::string &path) override
store - stores wallet to file.
Definition: wallet.cpp:918
virtual uint64_t estimateTransactionFee(const std::vector< std::pair< std::string, uint64_t >> &destinations, PendingTransaction::Priority priority) const override
Estimates transaction fee.
Definition: wallet.cpp:1685
std::string seed() const override
Definition: wallet.cpp:794
std::string publicViewKey() const override
publicViewKey - returns public view key
Definition: wallet.cpp:883
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:2040
bool refresh() override
refresh - refreshes the wallet, updating transactions from daemon
Definition: wallet.cpp:1086
uint64_t estimateBlockChainHeight() const override
estimateBlockChainHeight - returns estimate blockchain height. More accurate than approximateBlockCha...
Definition: wallet.cpp:1027
uint64_t getRefreshFromBlockHeight() const override
getRestoreHeight - get wallet creation height
Definition: wallet.h:127
bool open(const std::string &path, const std::string &password)
Definition: wallet.cpp:699
NetworkType nettype() const override
Definition: wallet.h:133
void setSubaddressLabel(uint32_t accountIndex, uint32_t addressIndex, const std::string &label) override
setSubaddressLabel - sets the label of the specified subaddress
Definition: wallet.cpp:1248
MultisigState multisig() const override
multisig - returns current state of multisig wallet creation process
Definition: wallet.cpp:1261
std::string secretSpendKey() const override
secretSpendKey - returns secret spend key
Definition: wallet.cpp:888
virtual bool setUserNote(const std::string &txid, const std::string &note) override
setUserNote - attach an arbitrary string note to a txid
Definition: wallet.cpp:1755
virtual TransactionHistory * history() override
Definition: wallet.cpp:1706
bool setDevicePin(const std::string &password) override
Definition: wallet.cpp:842
virtual void setDefaultMixin(uint32_t arg) override
setDefaultMixin - setum number of mixins to be used for new transactions
Definition: wallet.cpp:1737
virtual bool blackballOutputs(const std::vector< std::string > &outputs, bool add) override
blackballs a set of outputs
Definition: wallet.cpp:2319
virtual void segregationHeight(uint64_t height) override
sets the height where segregation should occur
Definition: wallet.cpp:2462
std::string keysFilename() const override
keysFilename - returns keys filename. usually this formed as "wallet_filename".keys
Definition: wallet.cpp:941
virtual std::string getDefaultDataDir() const override
Definition: wallet.cpp:2286
PendingTransaction * createTransactionMultDest(const std::vector< std::string > &dst_addr, const std::string &payment_id, optional< std::vector< 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
createTransactionMultDest creates transaction with multiple destinations. if dst_addr is an integrate...
Definition: wallet.cpp:1425
virtual bool lockKeysFile() override
locks/unlocks the keys file; returns true on success
Definition: wallet.cpp:2472
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:960
virtual void keyReuseMitigation2(bool mitigation) override
secondary key reuse mitigation
Definition: wallet.cpp:2467
void doRefresh()
Definition: wallet.cpp:2162
WalletImpl(NetworkType nettype=MAINNET, uint64_t kdf_rounds=1)
Definition: wallet.cpp:420
std::string secretViewKey() const override
secretViewKey - returns secret view key
Definition: wallet.cpp:878
void refreshThreadFunc()
Definition: wallet.cpp:2131
bool finalizeMultisig(const std::vector< std::string > &extraMultisigInfo) override
finalizeMultisig - finalizes N - 1 / N multisig wallets creation
Definition: wallet.cpp:1311
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:1280
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, const std::string &proxy_address="") override
init - initializes wallet with daemon connection params. if daemon_address is local address,...
Definition: wallet.cpp:946
bool trustedDaemon() const override
Definition: wallet.cpp:2092
friend class PendingTransactionImpl
Definition: wallet.h:233
bool recover(const std::string &path, const std::string &password, const std::string &seed, const std::string &seed_offset={})
Definition: wallet.cpp:730
void setStatus(int status, const std::string &message) const
Definition: wallet.cpp:2124
std::string getSubaddressLabel(uint32_t accountIndex, uint32_t addressIndex) const override
getSubaddressLabel - gets the label of the specified subaddress
Definition: wallet.cpp:1235
void setRecoveringFromSeed(bool recoveringFromSeed) override
setRecoveringFromSeed - set state recover form seed
Definition: wallet.cpp:990
bool useForkRules(uint8_t version, int64_t early_blocks) const override
check if hard fork rules should be used
Definition: wallet.cpp:2314
uint64_t approximateBlockChainHeight() const override
approximateBlockChainHeight - returns approximate blockchain height calculated from date/time
Definition: wallet.cpp:1022
void setStatusCritical(const std::string &message) const
Definition: wallet.cpp:2119
bool exportKeyImages(const std::string &filename) override
exportKeyImages - exports key images to file
Definition: wallet.cpp:1171
int autoRefreshInterval() const override
autoRefreshInterval - returns automatic refresh interval in millis
Definition: wallet.cpp:1127
virtual bool blackballOutput(const std::string &amount, const std::string &offset) override
blackballs an output
Definition: wallet.cpp:2357
std::string errorString() const override
in case error status, returns error string
Definition: wallet.cpp:818
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:2281
virtual UnsignedTransaction * loadUnsignedTx(const std::string &unsigned_filename) override
loadUnsignedTx - creates transaction from unsigned tx file
Definition: wallet.cpp:1132
void clearStatus() const
Definition: wallet.cpp:2107
std::atomic< int > m_refreshIntervalMillis
Definition: wallet.h:255
bool hasMultisigPartialKeyImages() const override
hasMultisigPartialKeyImages - checks if wallet needs to import multisig key images from other partici...
Definition: wallet.cpp:1373
std::atomic< bool > m_rebuildWalletCache
Definition: wallet.h:270
void setRecoveringFromDevice(bool recoveringFromDevice) override
setRecoveringFromDevice - set state to recovering from device
Definition: wallet.cpp:995
size_t numSubaddressAccounts() const override
numSubaddressAccounts - returns the number of existing subaddress accounts
Definition: wallet.cpp:1223
std::unique_ptr< TransactionHistoryImpl > m_history
Definition: wallet.h:246
bool setProxy(const std::string &address) override
Definition: wallet.cpp:2097
std::string path() const override
Definition: wallet.cpp:908
virtual std::string signMessage(const std::string &message) override
Definition: wallet.cpp:2004
virtual void disposeTransaction(PendingTransaction *t) override
disposeTransaction - destroys transaction object
Definition: wallet.cpp:1680
bool close(bool store=true)
Definition: wallet.cpp:766
boost::optional< epee::net_utils::http::login > m_daemon_login
Definition: wallet.h:273
bool submitTransaction(const std::string &fileName) override
submitTransaction - submits transaction in signed tx file
Definition: wallet.cpp:1153
std::atomic< bool > m_synchronized
Definition: wallet.h:269
std::string getSeedLanguage() const override
Definition: wallet.cpp:802
bool connectToDaemon() override
connectToDaemon - connects to the daemon. TODO: check if it can be removed
Definition: wallet.cpp:2063
std::string getMultisigInfo() const override
getMultisigInfo
Definition: wallet.cpp:1268
bool exportMultisigImages(std::string &images) override
exportMultisigImages - exports transfers' key images
Definition: wallet.cpp:1329
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:2418
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:1219
void setRefreshFromBlockHeight(uint64_t refresh_from_block_height) override
setRefreshFromBlockHeight - start refresh from block height on recover
Definition: wallet.cpp:985
uint64_t balance(uint32_t accountIndex=0) const override
Definition: wallet.cpp:1005
void hardForkInfo(uint8_t &version, uint64_t &earliest_height) const override
returns current hard fork info
Definition: wallet.cpp:2309
void setSeedLanguage(const std::string &arg) override
Definition: wallet.cpp:807
virtual bool lightWalletLogin(bool &isNewWallet) const override
Light wallet authenticate and login.
Definition: wallet.cpp:955
boost::condition_variable m_refreshCV
Definition: wallet.h:262
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:2440
uint64_t daemonBlockChainHeight() const override
daemonBlockChainHeight - returns daemon blockchain height
Definition: wallet.cpp:1032
boost::mutex m_refreshMutex
Definition: wallet.h:258
int m_status
Definition: wallet.h:243
bool recoverFromDevice(const std::string &path, const std::string &password, const std::string &device_name)
Definition: wallet.cpp:677
ConnectionStatus connected() const override
connected - checks if the wallet connected to the daemon
Definition: wallet.cpp:2075
std::string exchangeMultisigKeys(const std::vector< std::string > &info) override
exchange_multisig_keys - provides additional key exchange round for arbitrary multisig schemes (like ...
Definition: wallet.cpp:1297
std::unique_ptr< AddressBookImpl > m_addressBook
Definition: wallet.h:248
std::string publicSpendKey() const override
publicSpendKey - returns public spend key
Definition: wallet.cpp:893
void pendingTxPostProcess(PendingTransactionImpl *pending)
Definition: wallet.cpp:2240
bool rescanBlockchain() override
rescanBlockchain - rescans the wallet, updating transactions from daemon
Definition: wallet.cpp:1102
std::string address(uint32_t accountIndex=0, uint32_t addressIndex=0) const override
Definition: wallet.cpp:864
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:1812
virtual AddressBook * addressBook() override
Definition: wallet.cpp:1711
boost::thread m_refreshThread
Definition: wallet.h:263
uint64_t unlockedBalance(uint32_t accountIndex=0) const override
Definition: wallet.cpp:1010
virtual Subaddress * subaddress() override
Definition: wallet.cpp:1716
void setStatusError(const std::string &message) const
Definition: wallet.cpp:2114
bool doInit(const std::string &daemon_address, const std::string &proxy_address, uint64_t upper_transaction_size_limit=0, bool ssl=false)
Definition: wallet.cpp:2255
~WalletImpl()
Definition: wallet.cpp:450
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:506
std::string m_password
Definition: wallet.h:245
virtual void setListener(WalletListener *l) override
Definition: wallet.cpp:1726
std::unique_ptr< tools::wallet2 > m_wallet
Definition: wallet.h:241
virtual PendingTransaction * createSweepUnmixableTransaction() override
createSweepUnmixableTransaction creates transaction with unmixable outputs.
Definition: wallet.cpp:1598
virtual std::string getTxProof(const std::string &txid, const std::string &address, const std::string &message) const override
Definition: wallet.cpp:1860
virtual bool checkSpendProof(const std::string &txid, const std::string &message, const std::string &signature, bool &good) const override
Definition: wallet.cpp:1937
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:572
virtual std::string getCacheAttribute(const std::string &key) const override
getCacheAttribute - return an arbitrary string attached to a wallet cache attribute
Definition: wallet.cpp:1748
std::unique_ptr< Wallet2CallbackImpl > m_wallet2Callback
Definition: wallet.h:247
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:824
Definition: wallet2_api.h:57
Definition: address_book.cpp:40
NetworkType
Definition: wallet2_api.h:45
@ MAINNET
Definition: wallet2_api.h:46
int l
Definition: base.py:3
POD_CLASS signature
Definition: crypto.h:93
POD_CLASS key_image
Definition: crypto.h:87
version
Supported socks variants.
Definition: socks.h:58
static void add(ge_p3 &p3, const ge_cached &other)
Definition: multiexp.cc:143
Definition: wallet2_api.h:319
Transaction-like interface for sending money.
Definition: wallet2_api.h:73
Priority
Definition: wallet2_api.h:80
@ Priority_Low
Definition: wallet2_api.h:82
Definition: wallet.cpp:123
Interface for wallet operations. TODO: check if /include/IWallet.h is still actual.
Definition: wallet2_api.h:425
ConnectionStatus
Definition: wallet2_api.h:438
Device
Definition: wallet2_api.h:426
static void error(const std::string &category, const std::string &str)
Definition: wallet.cpp:415
static void info(const std::string &category, const std::string &str)
Definition: wallet.cpp:407