Bitcoin Core 28.0.0
P2P Digital Currency
Loading...
Searching...
No Matches
wallet.h
Go to the documentation of this file.
1// Copyright (c) 2009-2010 Satoshi Nakamoto
2// Copyright (c) 2009-2022 The Bitcoin Core developers
3// Distributed under the MIT software license, see the accompanying
4// file COPYING or http://www.opensource.org/licenses/mit-license.php.
5
6#ifndef BITCOIN_WALLET_WALLET_H
7#define BITCOIN_WALLET_WALLET_H
8
9#include <addresstype.h>
10#include <consensus/amount.h>
11#include <interfaces/chain.h>
12#include <interfaces/handler.h>
13#include <kernel/cs_main.h>
14#include <logging.h>
15#include <outputtype.h>
16#include <policy/feerate.h>
18#include <script/interpreter.h>
19#include <script/script.h>
21#include <sync.h>
22#include <tinyformat.h>
23#include <uint256.h>
24#include <util/fs.h>
25#include <util/hasher.h>
26#include <util/result.h>
27#include <util/string.h>
28#include <util/time.h>
29#include <util/ui_change_type.h>
30#include <wallet/crypter.h>
31#include <wallet/db.h>
33#include <wallet/transaction.h>
34#include <wallet/types.h>
35#include <wallet/walletutil.h>
36
37#include <atomic>
38#include <cassert>
39#include <cstddef>
40#include <cstdint>
41#include <functional>
42#include <limits>
43#include <map>
44#include <memory>
45#include <optional>
46#include <set>
47#include <string>
48#include <unordered_map>
49#include <utility>
50#include <vector>
51
52#include <boost/signals2/signal.hpp>
53
54class CKey;
55class CKeyID;
56class CPubKey;
57class Coin;
58class SigningProvider;
59enum class MemPoolRemovalReason;
60enum class SigningResult;
61namespace common {
62enum class PSBTError;
63} // namespace common
64namespace interfaces {
65class Wallet;
66}
67namespace wallet {
68class CWallet;
69class WalletBatch;
70enum class DBErrors : int;
71} // namespace wallet
72struct CBlockLocator;
73struct CExtKey;
75struct KeyOriginInfo;
77struct SignatureData;
78
79using LoadWalletFn = std::function<void(std::unique_ptr<interfaces::Wallet> wallet)>;
80
81struct bilingual_str;
82
83namespace wallet {
84struct WalletContext;
85
88void WaitForDeleteWallet(std::shared_ptr<CWallet>&& wallet);
89
90bool AddWallet(WalletContext& context, const std::shared_ptr<CWallet>& wallet);
91bool RemoveWallet(WalletContext& context, const std::shared_ptr<CWallet>& wallet, std::optional<bool> load_on_start, std::vector<bilingual_str>& warnings);
92bool RemoveWallet(WalletContext& context, const std::shared_ptr<CWallet>& wallet, std::optional<bool> load_on_start);
93std::vector<std::shared_ptr<CWallet>> GetWallets(WalletContext& context);
94std::shared_ptr<CWallet> GetDefaultWallet(WalletContext& context, size_t& count);
95std::shared_ptr<CWallet> GetWallet(WalletContext& context, const std::string& name);
96std::shared_ptr<CWallet> LoadWallet(WalletContext& context, const std::string& name, std::optional<bool> load_on_start, const DatabaseOptions& options, DatabaseStatus& status, bilingual_str& error, std::vector<bilingual_str>& warnings);
97std::shared_ptr<CWallet> CreateWallet(WalletContext& context, const std::string& name, std::optional<bool> load_on_start, DatabaseOptions& options, DatabaseStatus& status, bilingual_str& error, std::vector<bilingual_str>& warnings);
98std::shared_ptr<CWallet> RestoreWallet(WalletContext& context, const fs::path& backup_file, const std::string& wallet_name, std::optional<bool> load_on_start, DatabaseStatus& status, bilingual_str& error, std::vector<bilingual_str>& warnings);
99std::unique_ptr<interfaces::Handler> HandleLoadWallet(WalletContext& context, LoadWalletFn load_wallet);
100void NotifyWalletLoaded(WalletContext& context, const std::shared_ptr<CWallet>& wallet);
101std::unique_ptr<WalletDatabase> MakeWalletDatabase(const std::string& name, const DatabaseOptions& options, DatabaseStatus& status, bilingual_str& error);
102
104constexpr CAmount DEFAULT_PAY_TX_FEE = 0;
108static const CAmount DEFAULT_DISCARD_FEE = 10000;
112static const CAmount DEFAULT_CONSOLIDATE_FEERATE{10000}; // 10 sat/vbyte
122constexpr CAmount HIGH_APS_FEE{COIN / 10000};
126static const bool DEFAULT_SPEND_ZEROCONF_CHANGE = true;
128static const bool DEFAULT_WALLET_REJECT_LONG_CHAINS{true};
130static const unsigned int DEFAULT_TX_CONFIRM_TARGET = 6;
132static const bool DEFAULT_WALLET_RBF = true;
133static const bool DEFAULT_WALLETBROADCAST = true;
134static const bool DEFAULT_DISABLE_WALLET = false;
135static const bool DEFAULT_WALLETCROSSCHAIN = false;
143static constexpr size_t DUMMY_NESTED_P2WPKH_INPUT_SIZE = 91;
144
145class CCoinControl;
146
149
150static constexpr uint64_t KNOWN_WALLET_FLAGS =
152 | WALLET_FLAG_BLANK_WALLET
155 | WALLET_FLAG_DISABLE_PRIVATE_KEYS
156 | WALLET_FLAG_DESCRIPTORS
158
159static constexpr uint64_t MUTABLE_WALLET_FLAGS =
161
162static const std::map<std::string,WalletFlags> WALLET_FLAG_MAP{
163 {"avoid_reuse", WALLET_FLAG_AVOID_REUSE},
164 {"blank", WALLET_FLAG_BLANK_WALLET},
165 {"key_origin_metadata", WALLET_FLAG_KEY_ORIGIN_METADATA},
166 {"last_hardened_xpub_cached", WALLET_FLAG_LAST_HARDENED_XPUB_CACHED},
167 {"disable_private_keys", WALLET_FLAG_DISABLE_PRIVATE_KEYS},
168 {"descriptor_wallet", WALLET_FLAG_DESCRIPTORS},
169 {"external_signer", WALLET_FLAG_EXTERNAL_SIGNER}
170};
171
188{
189protected:
191 const CWallet* const pwallet;
196 int64_t nIndex{-1};
200 bool fInternal{false};
201
202public:
207
210
216
220 void ReturnDestination();
222 void KeepDestination();
223};
224
229{
237 std::optional<std::string> label;
238
244 std::optional<AddressPurpose> purpose;
245
253 bool previously_spent{false};
254
262 std::map<std::string, std::string> receive_requests{};
263
265 bool IsChange() const { return !label.has_value(); }
266 std::string GetLabel() const { return label ? *label : std::string{}; }
267 void SetLabel(std::string name) { label = std::move(name); }
268};
269
270inline std::string PurposeToString(AddressPurpose p)
271{
272 switch(p) {
273 case AddressPurpose::RECEIVE: return "receive";
274 case AddressPurpose::SEND: return "send";
275 case AddressPurpose::REFUND: return "refund";
276 } // no default case so the compiler will warn when a new enum as added
277 assert(false);
278}
279
280inline std::optional<AddressPurpose> PurposeFromString(std::string_view s)
281{
282 if (s == "receive") return AddressPurpose::RECEIVE;
283 else if (s == "send") return AddressPurpose::SEND;
284 else if (s == "refund") return AddressPurpose::REFUND;
285 return {};
286}
287
294
295class WalletRescanReserver; //forward declarations for ScanForWalletTransactions/RescanFromTime
300{
301private:
303
304 bool Unlock(const CKeyingMaterial& vMasterKeyIn);
305
306 std::atomic<bool> fAbortRescan{false};
307 std::atomic<bool> fScanningWallet{false}; // controlled by WalletRescanReserver
308 std::atomic<bool> m_attaching_chain{false};
309 std::atomic<bool> m_scanning_with_passphrase{false};
310 std::atomic<SteadyClock::time_point> m_scanning_start{SteadyClock::time_point{}};
311 std::atomic<double> m_scanning_progress{0};
313
315 int nWalletVersion GUARDED_BY(cs_wallet){FEATURE_BASE};
316
322 // Local time that the tip block was received. Used to schedule wallet rebroadcasts.
323 std::atomic<int64_t> m_best_block_time {0};
324
325 // First created key time. Used to skip blocks prior to this time.
326 // 'std::numeric_limits<int64_t>::max()' if wallet is blank.
327 std::atomic<int64_t> m_birth_time{std::numeric_limits<int64_t>::max()};
328
334 typedef std::unordered_multimap<COutPoint, uint256, SaltedOutpointHasher> TxSpends;
336 void AddToSpends(const COutPoint& outpoint, const uint256& wtxid, WalletBatch* batch = nullptr) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
337 void AddToSpends(const CWalletTx& wtx, WalletBatch* batch = nullptr) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
338
355 bool AddToWalletIfInvolvingMe(const CTransactionRef& tx, const SyncTxState& state, bool fUpdate, bool rescanning_old_block) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
356
358 void MarkConflicted(const uint256& hashBlock, int conflicting_height, const uint256& hashTx);
359
361
362 using TryUpdatingStateFn = std::function<TxUpdate(CWalletTx& wtx)>;
363
365 void RecursiveUpdateTxState(const uint256& tx_hash, const TryUpdatingStateFn& try_updating_state) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
366 void RecursiveUpdateTxState(WalletBatch* batch, const uint256& tx_hash, const TryUpdatingStateFn& try_updating_state) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
367
370
371 void SyncMetaData(std::pair<TxSpends::iterator, TxSpends::iterator>) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
372
373 void SyncTransaction(const CTransactionRef& tx, const SyncTxState& state, bool update_tx = true, bool rescanning_old_block = false) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
374
376 std::atomic<uint64_t> m_wallet_flags{0};
377
378 bool SetAddressBookWithDB(WalletBatch& batch, const CTxDestination& address, const std::string& strName, const std::optional<AddressPurpose>& strPurpose);
379
381 void UnsetWalletFlagWithDB(WalletBatch& batch, uint64_t flag);
382
384 void UnsetBlankWalletFlag(WalletBatch& batch) override;
385
388
390 std::string m_name;
391
393 std::unique_ptr<WalletDatabase> m_database;
394
402 uint256 m_last_block_processed GUARDED_BY(cs_wallet);
403
409 int m_last_block_processed_height GUARDED_BY(cs_wallet) = -1;
410
411 std::map<OutputType, ScriptPubKeyMan*> m_external_spk_managers;
412 std::map<OutputType, ScriptPubKeyMan*> m_internal_spk_managers;
413
414 // Indexed by a unique identifier produced by each ScriptPubKeyMan using
415 // ScriptPubKeyMan::GetID. In many cases it will be the hash of an internal structure
416 std::map<uint256, std::unique_ptr<ScriptPubKeyMan>> m_spk_managers;
417
418 // Appends spk managers into the main 'm_spk_managers'.
419 // Must be the only method adding data to it.
420 void AddScriptPubKeyMan(const uint256& id, std::unique_ptr<ScriptPubKeyMan> spkm_man);
421
422 // Same as 'AddActiveScriptPubKeyMan' but designed for use within a batch transaction context
423 void AddActiveScriptPubKeyManWithDb(WalletBatch& batch, uint256 id, OutputType type, bool internal);
424
426 std::unordered_map<CScript, std::vector<ScriptPubKeyMan*>, SaltedSipHasher> m_cached_spks;
427
433 static bool AttachChain(const std::shared_ptr<CWallet>& wallet, interfaces::Chain& chain, const bool rescan_required, bilingual_str& error, std::vector<bilingual_str>& warnings);
434
436
437public:
443
444 WalletDatabase& GetDatabase() const override
445 {
446 assert(static_cast<bool>(m_database));
447 return *m_database;
448 }
449
452 const std::string& GetName() const { return m_name; }
453
454 typedef std::map<unsigned int, CMasterKey> MasterKeyMap;
456 unsigned int nMasterKeyMaxID = 0;
457
459 CWallet(interfaces::Chain* chain, const std::string& name, std::unique_ptr<WalletDatabase> database)
460 : m_chain(chain),
461 m_name(name),
462 m_database(std::move(database))
463 {
464 }
465
467 {
468 // Should not have slots connected at this point.
469 assert(NotifyUnload.empty());
470 }
471
472 bool IsCrypted() const;
473 bool IsLocked() const override;
474 bool Lock();
475
477 bool HaveChain() const { return m_chain ? true : false; }
478
481 std::unordered_map<uint256, CWalletTx, SaltedTxidHasher> mapWallet GUARDED_BY(cs_wallet);
482
483 typedef std::multimap<int64_t, CWalletTx*> TxItems;
485
486 int64_t nOrderPosNext GUARDED_BY(cs_wallet) = 0;
487
488 std::map<CTxDestination, CAddressBookData> m_address_book GUARDED_BY(cs_wallet);
489 const CAddressBookData* FindAddressBookEntry(const CTxDestination&, bool allow_change = false) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
490
495 std::set<COutPoint> setLockedCoins GUARDED_BY(cs_wallet);
496
499
501 interfaces::Chain& chain() const { assert(m_chain); return *m_chain; }
502
504
505 std::set<uint256> GetTxConflicts(const CWalletTx& wtx) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
506
521
529
532
533 bool IsSpent(const COutPoint& outpoint) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
534
535 // Whether this or any known scriptPubKey with the same single key has been spent.
536 bool IsSpentKey(const CScript& scriptPubKey) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
537 void SetSpentKeyState(WalletBatch& batch, const uint256& hash, unsigned int n, bool used, std::set<CTxDestination>& tx_destinations) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
538
541
542 bool IsLockedCoin(const COutPoint& output) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
543 bool LockCoin(const COutPoint& output, WalletBatch* batch = nullptr) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
544 bool UnlockCoin(const COutPoint& output, WalletBatch* batch = nullptr) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
546 void ListLockedCoins(std::vector<COutPoint>& vOutpts) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
547
548 /*
549 * Rescan abort properties
550 */
551 void AbortRescan() { fAbortRescan = true; }
552 bool IsAbortingRescan() const { return fAbortRescan; }
553 bool IsScanning() const { return fScanningWallet; }
555 SteadyClock::duration ScanningDuration() const { return fScanningWallet ? SteadyClock::now() - m_scanning_start.load() : SteadyClock::duration{}; }
556 double ScanningProgress() const { return fScanningWallet ? (double) m_scanning_progress : 0; }
557
560
563
564 bool LoadMinVersion(int nVersion) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet) { AssertLockHeld(cs_wallet); nWalletVersion = nVersion; return true; }
565
569 void LoadAddressReceiveRequest(const CTxDestination& dest, const std::string& id, const std::string& request) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
570
572 int64_t nRelockTime GUARDED_BY(cs_wallet){0};
573
574 // Used to prevent concurrent calls to walletpassphrase RPC.
576 // Used to prevent deleting the passphrase from memory when it is still in use.
578
579 bool Unlock(const SecureString& strWalletPassphrase);
580 bool ChangeWalletPassphrase(const SecureString& strOldWalletPassphrase, const SecureString& strNewWalletPassphrase);
581 bool EncryptWallet(const SecureString& strWalletPassphrase);
582
583 void GetKeyBirthTimes(std::map<CKeyID, int64_t> &mapKeyBirth) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
584 unsigned int ComputeTimeSmart(const CWalletTx& wtx, bool rescanning_old_block) const;
585
592
593 void MarkDirty();
594
601 using UpdateWalletTxFn = std::function<bool(CWalletTx& wtx, bool new_tx)>;
602
607 CWalletTx* AddToWallet(CTransactionRef tx, const TxState& state, const UpdateWalletTxFn& update_wtx=nullptr, bool fFlushOnClose=true, bool rescanning_old_block = false);
608 bool LoadToWallet(const uint256& hash, const UpdateWalletTxFn& fill_wtx) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
609 void transactionAddedToMempool(const CTransactionRef& tx) override;
610 void blockConnected(ChainstateRole role, const interfaces::BlockInfo& block) override;
611 void blockDisconnected(const interfaces::BlockInfo& block) override;
612 void updatedBlockTip() override;
613 int64_t RescanFromTime(int64_t startTime, const WalletRescanReserver& reserver, bool update);
614
615 struct ScanResult {
616 enum { SUCCESS, FAILURE, USER_ABORT } status = SUCCESS;
617
622 std::optional<int> last_scanned_height;
623
629 };
630 ScanResult ScanForWalletTransactions(const uint256& start_block, int start_height, std::optional<int> max_height, const WalletRescanReserver& reserver, bool fUpdate, const bool save_progress);
635 bool ShouldResend() const;
636 void ResubmitWalletTransactions(bool relay, bool force);
637
638 OutputType TransactionChangeType(const std::optional<OutputType>& change_type, const std::vector<CRecipient>& vecSend) const;
639
643 bool SignTransaction(CMutableTransaction& tx, const std::map<COutPoint, Coin>& coins, int sighash, std::map<int, bilingual_str>& input_errors) const;
644 SigningResult SignMessage(const std::string& message, const PKHash& pkhash, std::string& str_sig) const;
645
661 std::optional<common::PSBTError> FillPSBT(PartiallySignedTransaction& psbtx,
662 bool& complete,
663 int sighash_type = SIGHASH_DEFAULT,
664 bool sign = true,
665 bool bip32derivs = true,
666 size_t* n_signed = nullptr,
667 bool finalize = true) const;
668
678 void CommitTransaction(CTransactionRef tx, mapValue_t mapValue, std::vector<std::pair<std::string, std::string>> orderForm);
679
681 bool SubmitTxMemoryPoolAndRelay(CWalletTx& wtx, std::string& err_string, bool relay) const
683
684 bool ImportScripts(const std::set<CScript> scripts, int64_t timestamp) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
685 bool ImportPrivKeys(const std::map<CKeyID, CKey>& privkey_map, const int64_t timestamp) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
686 bool ImportPubKeys(const std::vector<CKeyID>& ordered_pubkeys, const std::map<CKeyID, CPubKey>& pubkey_map, const std::map<CKeyID, std::pair<CPubKey, KeyOriginInfo>>& key_origins, const bool add_keypool, const bool internal, const int64_t timestamp) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
687 bool ImportScriptPubKeys(const std::string& label, const std::set<CScript>& script_pub_keys, const bool have_solving_data, const bool apply_label, const int64_t timestamp) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
688
690 void MaybeUpdateBirthTime(int64_t time);
691
692 CFeeRate m_pay_tx_fee{DEFAULT_PAY_TX_FEE};
706
710
716
726 std::optional<OutputType> m_default_change_type{};
729
732
735
737 bool TopUpKeyPool(unsigned int kpSize = 0);
738
739 std::optional<int64_t> GetOldestKeyPoolTime() const;
740
741 // Filter struct for 'ListAddrBookAddresses'
743 // Fetch addresses with the provided label
744 std::optional<std::string> m_op_label{std::nullopt};
745 // Don't include change addresses by default
746 bool ignore_change{true};
747 };
748
752 std::vector<CTxDestination> ListAddrBookAddresses(const std::optional<AddrBookFilter>& filter) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
753
757 std::set<std::string> ListAddrBookLabels(const std::optional<AddressPurpose> purpose) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
758
763 using ListAddrBookFunc = std::function<void(const CTxDestination& dest, const std::string& label, bool is_change, const std::optional<AddressPurpose> purpose)>;
765
770 void MarkDestinationsDirty(const std::set<CTxDestination>& destinations) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
771
772 util::Result<CTxDestination> GetNewDestination(const OutputType type, const std::string label);
774
781 CAmount GetDebit(const CTxIn& txin, const isminefilter& filter) const;
786 bool IsFromMe(const CTransaction& tx) const;
787 CAmount GetDebit(const CTransaction& tx, const isminefilter& filter) const;
788 void chainStateFlushed(ChainstateRole role, const CBlockLocator& loc) override;
789
791
793 util::Result<void> RemoveTxs(std::vector<uint256>& txs_to_remove) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
794
795 bool SetAddressBook(const CTxDestination& address, const std::string& strName, const std::optional<AddressPurpose>& purpose);
796
797 bool DelAddressBook(const CTxDestination& address);
798 bool DelAddressBookWithDB(WalletBatch& batch, const CTxDestination& address);
799
802
803 std::vector<std::string> GetAddressReceiveRequests() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
804 bool SetAddressReceiveRequest(WalletBatch& batch, const CTxDestination& dest, const std::string& id, const std::string& value) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
806
808
810 void SetMinVersion(enum WalletFeature, WalletBatch* batch_in = nullptr) override;
811
813 int GetVersion() const { LOCK(cs_wallet); return nWalletVersion; }
814
816 std::set<uint256> GetConflicts(const uint256& txid) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
817
820
822 void Flush();
823
825 void Close();
826
828 boost::signals2::signal<void ()> NotifyUnload;
829
834 boost::signals2::signal<void(const CTxDestination& address,
835 const std::string& label, bool isMine,
836 AddressPurpose purpose, ChangeType status)>
838
843 boost::signals2::signal<void(const uint256& hashTx, ChangeType status)> NotifyTransactionChanged;
844
846 boost::signals2::signal<void (const std::string &title, int nProgress)> ShowProgress;
847
849 boost::signals2::signal<void (bool fHaveWatchOnly)> NotifyWatchonlyChanged;
850
852 boost::signals2::signal<void ()> NotifyCanGetAddressesChanged;
853
858 boost::signals2::signal<void (CWallet* wallet)> NotifyStatusChanged;
859
863 void SetBroadcastTransactions(bool broadcast) { fBroadcastTransactions = broadcast; }
864
866 bool TransactionCanBeAbandoned(const uint256& hashTx) const;
867
868 /* Mark a transaction (and it in-wallet descendants) as abandoned so its inputs may be respent. */
869 bool AbandonTransaction(const uint256& hashTx);
870
872 bool MarkReplaced(const uint256& originalHash, const uint256& newHash);
873
874 /* Initializes the wallet, returns a new CWallet instance or a null pointer in case of an error */
875 static std::shared_ptr<CWallet> Create(WalletContext& context, const std::string& name, std::unique_ptr<WalletDatabase> database, uint64_t wallet_creation_flags, bilingual_str& error, std::vector<bilingual_str>& warnings);
876
881 void postInitProcess();
882
883 bool BackupWallet(const std::string& strDest) const;
884
885 /* Returns true if HD is enabled */
886 bool IsHDEnabled() const;
887
888 /* Returns true if the wallet can give out new addresses. This means it has keys in the keypool or can generate new keys */
889 bool CanGetAddresses(bool internal = false) const;
890
891 /* Returns the time of the first created key or, in case of an import, it could be the time of the first received transaction */
892 int64_t GetBirthTime() const { return m_birth_time; }
893
900 void BlockUntilSyncedToCurrentChain() const LOCKS_EXCLUDED(::cs_main) EXCLUSIVE_LOCKS_REQUIRED(!cs_wallet);
901
903 void SetWalletFlag(uint64_t flags);
904
906 void UnsetWalletFlag(uint64_t flag);
907
909 bool IsWalletFlagSet(uint64_t flag) const override;
910
914 void InitWalletFlags(uint64_t flags);
916 bool LoadWalletFlags(uint64_t flags);
917
919 bool IsLegacy() const;
920
922 std::string GetDisplayName() const override
923 {
924 std::string wallet_name = GetName().length() == 0 ? "default wallet" : GetName();
925 return strprintf("[%s]", wallet_name);
926 };
927
929 template <typename... Params>
930 void WalletLogPrintf(const char* fmt, Params... parameters) const
931 {
932 LogPrintf(("%s " + std::string{fmt}).c_str(), GetDisplayName(), parameters...);
933 };
934
936 bool UpgradeWallet(int version, bilingual_str& error);
937
939 std::set<ScriptPubKeyMan*> GetActiveScriptPubKeyMans() const;
940 bool IsActiveScriptPubKeyMan(const ScriptPubKeyMan& spkm) const;
941
943 std::set<ScriptPubKeyMan*> GetAllScriptPubKeyMans() const;
944
946 ScriptPubKeyMan* GetScriptPubKeyMan(const OutputType& type, bool internal) const;
947
949 std::set<ScriptPubKeyMan*> GetScriptPubKeyMans(const CScript& script) const;
952
954 std::unique_ptr<SigningProvider> GetSolvingProvider(const CScript& script) const;
955 std::unique_ptr<SigningProvider> GetSolvingProvider(const CScript& script, SignatureData& sigdata) const;
956
958 std::vector<WalletDescriptor> GetWalletDescriptors(const CScript& script) const;
959
965
968
969 bool WithEncryptionKey(std::function<bool (const CKeyingMaterial&)> cb) const override;
970
971 bool HasEncryptionKeys() const override;
972
975 {
977 assert(m_last_block_processed_height >= 0);
978 return m_last_block_processed_height;
979 };
981 {
983 assert(m_last_block_processed_height >= 0);
984 return m_last_block_processed;
985 }
988 {
990 m_last_block_processed_height = block_height;
991 m_last_block_processed = block_hash;
992 };
993
996
999
1004 void AddActiveScriptPubKeyMan(uint256 id, OutputType type, bool internal);
1005
1010 void LoadActiveScriptPubKeyMan(uint256 id, OutputType type, bool internal);
1011
1016 void DeactivateScriptPubKeyMan(uint256 id, OutputType type, bool internal);
1017
1023
1026
1030 std::optional<bool> IsInternalScriptPubKeyMan(ScriptPubKeyMan* spk_man) const;
1031
1033 ScriptPubKeyMan* AddWalletDescriptor(WalletDescriptor& desc, const FlatSigningProvider& signing_provider, const std::string& label, bool internal) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
1034
1041
1044
1048
1050 bool CanGrindR() const;
1051
1053 void CacheNewScriptPubKeys(const std::set<CScript>& spks, ScriptPubKeyMan* spkm);
1054
1055 void TopUpCallback(const std::set<CScript>& spks, ScriptPubKeyMan* spkm) override;
1056
1059
1062 std::optional<CKey> GetKey(const CKeyID& keyid) const;
1063};
1064
1069void MaybeResendWalletTxs(WalletContext& context);
1070
1073{
1074private:
1075 using Clock = std::chrono::steady_clock;
1076 using NowFn = std::function<Clock::time_point()>;
1078 bool m_could_reserve{false};
1080public:
1082
1083 bool reserve(bool with_passphrase = false)
1084 {
1085 assert(!m_could_reserve);
1086 if (m_wallet.fScanningWallet.exchange(true)) {
1087 return false;
1088 }
1089 m_wallet.m_scanning_with_passphrase.exchange(with_passphrase);
1090 m_wallet.m_scanning_start = SteadyClock::now();
1091 m_wallet.m_scanning_progress = 0;
1092 m_could_reserve = true;
1093 return true;
1094 }
1095
1096 bool isReserved() const
1097 {
1098 return (m_could_reserve && m_wallet.fScanningWallet);
1099 }
1100
1101 Clock::time_point now() const { return m_now ? m_now() : Clock::now(); };
1102
1103 void setNow(NowFn now) { m_now = std::move(now); }
1104
1106 {
1107 if (m_could_reserve) {
1108 m_wallet.fScanningWallet = false;
1109 m_wallet.m_scanning_with_passphrase = false;
1110 }
1111 }
1112};
1113
1115bool AddWalletSetting(interfaces::Chain& chain, const std::string& wallet_name);
1116
1118bool RemoveWalletSetting(interfaces::Chain& chain, const std::string& wallet_name);
1119
1121 std::string wallet_name;
1122 std::shared_ptr<CWallet> wallet;
1123 std::shared_ptr<CWallet> watchonly_wallet;
1124 std::shared_ptr<CWallet> solvables_wallet;
1126};
1127
1129[[nodiscard]] util::Result<MigrationResult> MigrateLegacyToDescriptor(const std::string& wallet_name, const SecureString& passphrase, WalletContext& context);
1130} // namespace wallet
1131
1132#endif // BITCOIN_WALLET_WALLET_H
std::variant< CNoDestination, PubKeyDestination, PKHash, ScriptHash, WitnessV0ScriptHash, WitnessV0KeyHash, WitnessV1Taproot, PayToAnchor, WitnessUnknown > CTxDestination
A txout script categorized into standard templates.
int64_t CAmount
Amount in satoshis (Can be negative)
Definition amount.h:12
static constexpr CAmount COIN
The amount of satoshis in one BTC.
Definition amount.h:15
int flags
const CChainParams & Params()
Return the currently selected parameters.
Fee rate in satoshis per kilovirtualbyte: CAmount / kvB.
Definition feerate.h:33
An encapsulated private key.
Definition key.h:35
A reference to a CKey: the Hash160 of its serialized public key.
Definition pubkey.h:24
An outpoint - a combination of a transaction hash and an index n into its vout.
Definition transaction.h:29
An encapsulated public key.
Definition pubkey.h:34
Serialized script, used inside transaction inputs and outputs.
Definition script.h:414
The basic transaction that is broadcasted on the network and contained in blocks.
An input of a transaction.
Definition transaction.h:67
An output of a transaction.
A UTXO entry.
Definition coins.h:33
An interface to be implemented by keystores that support signing.
Path class wrapper to block calls to the fs::path(std::string) implicit constructor and the fs::path:...
Definition fs.h:33
Chain notifications.
Definition chain.h:321
Interface giving clients (wallet processes, maybe other analysis tools in the future) ability to acce...
Definition chain.h:135
256-bit opaque blob.
Definition uint256.h:178
Coin Control Features.
Definition coincontrol.h:81
A CWallet maintains a set of transactions and balances, and provides the ability to create new transa...
Definition wallet.h:300
std::atomic< bool > fAbortRescan
Definition wallet.h:306
bool HaveChain() const
Interface to assert chain access.
Definition wallet.h:477
bool GetBroadcastTransactions() const
Inquire whether this wallet broadcasts transactions.
Definition wallet.h:861
bool m_signal_rbf
Definition wallet.h:697
int64_t GetBirthTime() const
Definition wallet.h:892
bool IsCrypted() const
Definition wallet.cpp:3465
std::atomic< SteadyClock::time_point > m_scanning_start
Definition wallet.h:310
std::function< bool(CWalletTx &wtx, bool new_tx)> UpdateWalletTxFn
Callback for updating transaction metadata in mapWallet.
Definition wallet.h:601
boost::signals2::signal< void()> NotifyUnload
Wallet is about to be unloaded.
Definition wallet.h:828
CAmount m_default_max_tx_fee
Absolute maximum transaction fee (in satoshis) used by default for the wallet.
Definition wallet.h:728
bool IsActiveScriptPubKeyMan(const ScriptPubKeyMan &spkm) const
Definition wallet.cpp:3525
OutputType m_default_address_type
Definition wallet.h:719
int m_last_block_processed_height GUARDED_BY(cs_wallet)
Height of last block processed is used by wallet to know depth of transactions without relying on Cha...
CFeeRate m_discard_rate
If the cost to spend a change output at this feerate is greater than the value of the output itself,...
Definition wallet.h:709
LegacyScriptPubKeyMan * GetLegacyScriptPubKeyMan() const
Get the LegacyScriptPubKeyMan which is used for all types, internal, and external.
Definition wallet.cpp:3617
void AddActiveScriptPubKeyMan(uint256 id, OutputType type, bool internal)
Adds the active ScriptPubKeyMan for the specified type and internal.
Definition wallet.cpp:3804
void LoadActiveScriptPubKeyMan(uint256 id, OutputType type, bool internal)
Loads an active ScriptPubKeyMan for the specified type and internal.
Definition wallet.cpp:3818
std::unique_ptr< WalletDatabase > m_database
Internal database handle.
Definition wallet.h:393
CWallet(interfaces::Chain *chain, const std::string &name, std::unique_ptr< WalletDatabase > database)
Construct wallet with specified name and database implementation.
Definition wallet.h:459
std::function< void(const CTxDestination &dest, const std::string &label, bool is_change, const std::optional< AddressPurpose > purpose)> ListAddrBookFunc
Walk-through the address book entries.
Definition wallet.h:763
std::unique_ptr< SigningProvider > GetSolvingProvider(const CScript &script) const
Get the SigningProvider for a script.
Definition wallet.cpp:3582
bool IsTxImmatureCoinBase(const CWalletTx &wtx) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:3457
void AddActiveScriptPubKeyManWithDb(WalletBatch &batch, uint256 id, OutputType type, bool internal)
Definition wallet.cpp:3810
void TopUpCallback(const std::set< CScript > &spks, ScriptPubKeyMan *spkm) override
Callback function for after TopUp completes containing any scripts that were added by a SPKMan.
Definition wallet.cpp:4576
std::set< ScriptPubKeyMan * > GetActiveScriptPubKeyMans() const
Returns all unique ScriptPubKeyMans in m_internal_spk_managers and m_external_spk_managers.
Definition wallet.cpp:3511
const CAddressBookData * FindAddressBookEntry(const CTxDestination &, bool allow_change=false) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:3358
CFeeRate m_pay_tx_fee
Definition wallet.h:692
void postInitProcess()
Wallet post-init setup Gives the wallet a chance to register repetitive tasks and complete post-init ...
Definition wallet.cpp:3401
int GetTxDepthInMainChain(const CWalletTx &wtx) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Return depth of transaction in blockchain: <0 : conflicts with a transaction this deep in the blockch...
Definition wallet.cpp:3431
unsigned int nMasterKeyMaxID
Definition wallet.h:456
bool IsScanning() const
Definition wallet.h:553
std::multimap< int64_t, CWalletTx * > TxItems
Definition wallet.h:483
bool SetAddressReceiveRequest(WalletBatch &batch, const CTxDestination &dest, const std::string &id, const std::string &value) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2925
int GetLastBlockHeight() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Get last block processed height.
Definition wallet.h:974
std::atomic< double > m_scanning_progress
Definition wallet.h:311
LegacyDataSPKM * GetLegacyDataSPKM() const
Definition wallet.cpp:3629
boost::signals2::signal< void(bool fHaveWatchOnly)> NotifyWatchonlyChanged
Watch-only address added.
Definition wallet.h:849
CAmount m_max_aps_fee
The maximum fee amount we're willing to pay to prioritize partial spend avoidance.
Definition wallet.h:718
DescriptorScriptPubKeyMan * GetDescriptorScriptPubKeyMan(const WalletDescriptor &desc) const
Return the DescriptorScriptPubKeyMan for a WalletDescriptor if it is already in the wallet.
Definition wallet.cpp:3860
std::map< OutputType, ScriptPubKeyMan * > m_external_spk_managers
Definition wallet.h:411
uint256 m_last_block_processed GUARDED_BY(cs_wallet)
The following is used to keep track of how far behind the wallet is from the chain sync,...
DescriptorScriptPubKeyMan & LoadDescriptorScriptPubKeyMan(uint256 id, WalletDescriptor &desc)
Instantiate a descriptor ScriptPubKeyMan from the WalletDescriptor and load it.
Definition wallet.cpp:3699
bool IsLegacy() const
Determine if we are a legacy wallet.
Definition wallet.cpp:3855
CKeyingMaterial vMasterKey GUARDED_BY(cs_wallet)
void SetBroadcastTransactions(bool broadcast)
Set whether this wallet broadcasts transactions.
Definition wallet.h:863
std::optional< MigrationData > GetDescriptorsForLegacy(bilingual_str &error) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Get all of the descriptors from a legacy wallet.
Definition wallet.cpp:4030
std::optional< OutputType > m_default_change_type
Default output type for change outputs.
Definition wallet.h:726
int64_t nOrderPosNext GUARDED_BY(cs_wallet)=0
LegacyDataSPKM * GetOrCreateLegacyDataSPKM()
Definition wallet.cpp:3655
interfaces::Chain & chain() const
Interface for accessing chain state.
Definition wallet.h:501
const std::string & GetName() const
Get a name for this wallet for logging/debugging purposes.
Definition wallet.h:452
bool Unlock(const CKeyingMaterial &vMasterKeyIn)
Definition wallet.cpp:3496
bool MigrateToSQLite(bilingual_str &error) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Move all records from the BDB database to a new SQLite database for storage.
Definition wallet.cpp:3956
bool BackupWallet(const std::string &strDest) const
Definition wallet.cpp:3411
std::unique_ptr< interfaces::Handler > m_chain_notifications_handler
Registered interfaces::Chain::Notifications handler.
Definition wallet.h:498
std::map< OutputType, ScriptPubKeyMan * > m_internal_spk_managers
Definition wallet.h:412
std::string m_name
Wallet name: relative directory name or "" for default wallet.
Definition wallet.h:390
bool SetAddressPreviouslySpent(WalletBatch &batch, const CTxDestination &dest, bool used) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2884
double ScanningProgress() const
Definition wallet.h:556
SteadyClock::duration ScanningDuration() const
Definition wallet.h:555
RecursiveMutex m_relock_mutex
Definition wallet.h:577
std::string m_notify_tx_changed_script
Notify external script when a wallet transaction comes in or is updated (handled by -walletnotify)
Definition wallet.h:734
std::string GetDisplayName() const override
Returns a bracketed wallet name for displaying in logs, will return [default wallet] if the wallet ha...
Definition wallet.h:922
std::vector< std::string > GetAddressReceiveRequests() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2914
bool LoadMinVersion(int nVersion) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.h:564
std::vector< WalletDescriptor > GetWalletDescriptors(const CScript &script) const
Get the wallet descriptors for a script.
Definition wallet.cpp:3605
std::atomic< bool > m_attaching_chain
Definition wallet.h:308
bool fBroadcastTransactions
Whether this wallet will submit newly created transactions to the node's mempool and prompt rebroadca...
Definition wallet.h:321
void CacheNewScriptPubKeys(const std::set< CScript > &spks, ScriptPubKeyMan *spkm)
Add scriptPubKeys for this ScriptPubKeyMan into the scriptPubKey cache.
Definition wallet.cpp:4569
int GetTxBlocksToMaturity(const CWalletTx &wtx) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:3445
bool HasEncryptionKeys() const override
Definition wallet.cpp:3685
static std::shared_ptr< CWallet > Create(WalletContext &context, const std::string &name, std::unique_ptr< WalletDatabase > database, uint64_t wallet_creation_flags, bilingual_str &error, std::vector< bilingual_str > &warnings)
Definition wallet.cpp:2972
int GetVersion() const
get the current wallet format (the oldest client version guaranteed to understand this wallet)
Definition wallet.h:813
bool CanGrindR() const
Whether the (external) signer performs R-value signature grinding.
Definition wallet.cpp:4265
std::map< CTxDestination, CAddressBookData > m_address_book GUARDED_BY(cs_wallet)
std::optional< bool > IsInternalScriptPubKeyMan(ScriptPubKeyMan *spk_man) const
Returns whether the provided ScriptPubKeyMan is internal.
Definition wallet.cpp:3873
void SetNextResend()
Set the next time this wallet should resend transactions to 12-36 hours from now, ~1 day on average.
Definition wallet.h:633
TxItems wtxOrdered
Definition wallet.h:484
std::atomic< bool > m_scanning_with_passphrase
Definition wallet.h:309
bool CanSupportFeature(enum WalletFeature wf) const override EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
check whether we support the named feature
Definition wallet.h:531
bool m_spend_zero_conf_change
Allow Coin Selection to pick unconfirmed UTXOs that were sent from our own wallet if it cannot fund t...
Definition wallet.h:696
MasterKeyMap mapMasterKeys
Definition wallet.h:455
std::map< unsigned int, CMasterKey > MasterKeyMap
Definition wallet.h:454
unsigned int m_confirm_target
Definition wallet.h:693
CFeeRate m_consolidate_feerate
When the actual feerate is less than the consolidate feerate, we will tend to make transactions which...
Definition wallet.h:715
NodeClock::time_point m_next_resend
The next scheduled rebroadcast of wallet transactions.
Definition wallet.h:318
void WalletLogPrintf(const char *fmt, Params... parameters) const
Prepends the wallet name in logging output to ease debugging in multi-wallet use cases.
Definition wallet.h:930
WalletDatabase & GetDatabase() const override
Definition wallet.h:444
std::optional< CKey > GetKey(const CKeyID &keyid) const
Find the private key for the given key id from the wallet's descriptors, if available Returns nullopt...
Definition wallet.cpp:4603
int64_t nRelockTime GUARDED_BY(cs_wallet)
Holds a timestamp at which point the wallet is scheduled (externally) to be relocked....
Definition wallet.h:572
std::unordered_multimap< COutPoint, uint256, SaltedOutpointHasher > TxSpends
Used to keep track of spent outpoints, and detect and report conflicts (double-spends or mutated tran...
Definition wallet.h:334
bool EraseAddressReceiveRequest(WalletBatch &batch, const CTxDestination &dest, const std::string &id) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2932
void AbortRescan()
Definition wallet.h:551
boost::signals2::signal< void(const std::string &title, int nProgress)> ShowProgress
Show progress e.g.
Definition wallet.h:846
void LoadAddressReceiveRequest(const CTxDestination &dest, const std::string &id, const std::string &request) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Appends payment request to destination.
Definition wallet.cpp:2903
Mutex m_unlock_mutex
Definition wallet.h:575
void AddScriptPubKeyMan(const uint256 &id, std::unique_ptr< ScriptPubKeyMan > spkm_man)
Definition wallet.cpp:3645
void DeactivateScriptPubKeyMan(uint256 id, OutputType type, bool internal)
Remove specified ScriptPubKeyMan from set of active SPK managers.
Definition wallet.cpp:3838
bool UpgradeWallet(int version, bilingual_str &error)
Upgrade the wallet.
Definition wallet.cpp:3368
std::atomic< uint64_t > m_wallet_flags
WalletFlags set on this wallet.
Definition wallet.h:376
interfaces::Chain * m_chain
Interface for accessing chain state.
Definition wallet.h:387
CFeeRate m_fallback_fee
If fee estimation does not have enough data to provide estimates, use this fee instead.
Definition wallet.h:705
std::set< CExtPubKey > GetActiveHDPubKeys() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Retrieve the xpubs in use by the active descriptors.
Definition wallet.cpp:4582
bool IsLocked() const override
Definition wallet.cpp:3470
boost::signals2::signal< void(const uint256 &hashTx, ChangeType status)> NotifyTransactionChanged
Wallet transaction added, removed or updated.
Definition wallet.h:843
boost::signals2::signal< void()> NotifyCanGetAddressesChanged
Keypool has new keys.
Definition wallet.h:852
std::set< ScriptPubKeyMan * > GetAllScriptPubKeyMans() const
Returns all unique ScriptPubKeyMans.
Definition wallet.cpp:3536
unsigned int ComputeTimeSmart(const CWalletTx &wtx, bool rescanning_old_block) const
Compute smart timestamp for a transaction being added to the wallet.
Definition wallet.cpp:2833
TxSpends mapTxSpends GUARDED_BY(cs_wallet)
std::unordered_map< uint256, CWalletTx, SaltedTxidHasher > mapWallet GUARDED_BY(cs_wallet)
Map from txid to CWalletTx for all transactions this wallet is interested in, including received and ...
int nWalletVersion GUARDED_BY(cs_wallet)
the current wallet version: clients below this version are not able to load the wallet
Definition wallet.h:315
ScriptPubKeyMan * AddWalletDescriptor(WalletDescriptor &desc, const FlatSigningProvider &signing_provider, const std::string &label, bool internal) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Add a descriptor to the wallet, return a ScriptPubKeyMan & associated output type.
Definition wallet.cpp:3897
bool IsAbortingRescan() const
Definition wallet.h:552
void SetLastBlockProcessed(int block_height, uint256 block_hash) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Set last block processed height, currently only use in unit test.
Definition wallet.h:987
ScriptPubKeyMan * GetScriptPubKeyMan(const OutputType &type, bool internal) const
Get the ScriptPubKeyMan for the given OutputType and internal/external chain.
Definition wallet.cpp:3545
bool IsAddressPreviouslySpent(const CTxDestination &dest) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2908
bool WithEncryptionKey(std::function< bool(const CKeyingMaterial &)> cb) const override
Pass the encryption key to cb().
Definition wallet.cpp:3679
void GetKeyBirthTimes(std::map< CKeyID, int64_t > &mapKeyBirth) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2750
uint256 GetLastBlockHash() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.h:980
bool m_allow_fallback_fee
will be false if -fallbackfee=0
Definition wallet.h:698
int64_t m_keypool_size
Number of pre-generated keys/scripts by each spkm (part of the look-ahead process,...
Definition wallet.h:731
RecursiveMutex cs_wallet
Main wallet lock.
Definition wallet.h:442
void ConnectScriptPubKeyManNotifiers()
Connect the signals from ScriptPubKeyMans to the signals in CWallet.
Definition wallet.cpp:3690
CFeeRate m_min_fee
Override with -mintxfee.
Definition wallet.h:699
std::atomic< int64_t > m_best_block_time
Definition wallet.h:323
std::unordered_map< CScript, std::vector< ScriptPubKeyMan * >, SaltedSipHasher > m_cached_spks
Cache of descriptor ScriptPubKeys used for IsMine. Maps ScriptPubKey to set of spkms.
Definition wallet.h:426
void SetupLegacyScriptPubKeyMan()
Make a Legacy(Data)SPKM and set it for all types, internal, and external.
Definition wallet.cpp:3661
static bool AttachChain(const std::shared_ptr< CWallet > &wallet, interfaces::Chain &chain, const bool rescan_required, bilingual_str &error, std::vector< bilingual_str > &warnings)
Catch wallet up to current chain, scanning new blocks, updating the best block locator and m_last_blo...
Definition wallet.cpp:3236
boost::signals2::signal< void(const CTxDestination &address, const std::string &label, bool isMine, AddressPurpose purpose, ChangeType status)> NotifyAddressBookChanged
Address book entry changed.
Definition wallet.h:837
LegacyScriptPubKeyMan * GetOrCreateLegacyScriptPubKeyMan()
Definition wallet.cpp:3639
boost::signals2::signal< void(CWallet *wallet)> NotifyStatusChanged
Wallet status (encrypted, locked) changed.
Definition wallet.h:858
void SetupDescriptorScriptPubKeyMans() EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:3749
DescriptorScriptPubKeyMan & SetupDescriptorScriptPubKeyMan(WalletBatch &batch, const CExtKey &master_key, const OutputType &output_type, bool internal) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Create new DescriptorScriptPubKeyMan and add it to the wallet.
Definition wallet.cpp:3711
bool ApplyMigrationData(MigrationData &data, bilingual_str &error) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Adds the ScriptPubKeyMans given in MigrationData to this wallet, removes LegacyScriptPubKeyMan,...
Definition wallet.cpp:4049
std::map< uint256, std::unique_ptr< ScriptPubKeyMan > > m_spk_managers
Definition wallet.h:416
std::function< TxUpdate(CWalletTx &wtx)> TryUpdatingStateFn
Definition wallet.h:362
std::atomic< int64_t > m_birth_time
Definition wallet.h:327
void LoadAddressPreviouslySpent(const CTxDestination &dest) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Marks destination as previously spent.
Definition wallet.cpp:2898
std::atomic< bool > fScanningWallet
Definition wallet.h:307
std::set< ScriptPubKeyMan * > GetScriptPubKeyMans(const CScript &script) const
Get all the ScriptPubKeyMans for a script.
Definition wallet.cpp:3555
bool IsScanningWithPassphrase() const
Definition wallet.h:554
A transaction with a bunch of additional info that only the owner cares about.
A wrapper to reserve an address from a wallet.
Definition wallet.h:188
const CWallet *const pwallet
The wallet to reserve from.
Definition wallet.h:191
CTxDestination address
The destination.
Definition wallet.h:198
bool fInternal
Whether this is from the internal (change output) keypool.
Definition wallet.h:200
~ReserveDestination()
Destructor. If a key has been reserved and not KeepKey'ed, it will be returned to the keypool.
Definition wallet.h:212
ReserveDestination(CWallet *pwallet, OutputType type)
Construct a ReserveDestination object. This does NOT reserve an address yet.
Definition wallet.h:204
ScriptPubKeyMan * m_spk_man
The ScriptPubKeyMan to reserve from. Based on type when GetReservedDestination is called.
Definition wallet.h:193
ReserveDestination & operator=(const ReserveDestination &)=delete
int64_t nIndex
The index of the address's key in the keypool.
Definition wallet.h:196
OutputType const type
Definition wallet.h:194
ReserveDestination(const ReserveDestination &)=delete
Access to the wallet database.
Definition walletdb.h:191
An instance of this class represents one database.
Definition db.h:130
Descriptor with some wallet metadata.
Definition walletutil.h:85
RAII object to check and reserve a wallet rescan.
Definition wallet.h:1073
std::function< Clock::time_point()> NowFn
Definition wallet.h:1076
std::chrono::steady_clock Clock
Definition wallet.h:1075
WalletRescanReserver(CWallet &w)
Definition wallet.h:1081
Clock::time_point now() const
Definition wallet.h:1101
void setNow(NowFn now)
Definition wallet.h:1103
bool reserve(bool with_passphrase=false)
Definition wallet.h:1083
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate.
Definition cs_main.cpp:8
void MarkDestinationsDirty(const std::set< CTxDestination > &destinations) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Marks all outputs in each one of the destinations dirty, so their cache is reset and does not return ...
Definition wallet.cpp:2596
bool SetAddressBook(const CTxDestination &address, const std::string &strName, const std::optional< AddressPurpose > &purpose)
Definition wallet.cpp:2465
bool TopUpKeyPool(unsigned int kpSize=0)
Definition wallet.cpp:2545
std::optional< common::PSBTError > FillPSBT(PartiallySignedTransaction &psbtx, bool &complete, int sighash_type=SIGHASH_DEFAULT, bool sign=true, bool bip32derivs=true, size_t *n_signed=nullptr, bool finalize=true) const
Fills out a PSBT with information from the wallet.
Definition wallet.cpp:2188
bool UnlockCoin(const COutPoint &output, WalletBatch *batch=nullptr) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2710
unsigned int GetKeyPoolSize() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2534
void KeepDestination()
Keep the address. Do not return its key to the keypool when this object goes out of scope.
Definition wallet.cpp:2668
bool IsLockedCoin(const COutPoint &output) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2732
bool SignTransaction(CMutableTransaction &tx) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Fetch the inputs and sign with SIGHASH_ALL.
Definition wallet.cpp:2154
DBErrors LoadWallet()
Definition wallet.cpp:2357
std::vector< CTxDestination > ListAddrBookAddresses(const std::optional< AddrBookFilter > &filter) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Filter and retrieve destinations stored in the addressbook.
Definition wallet.cpp:2619
void ReturnDestination()
Return reserved address.
Definition wallet.cpp:2677
util::Result< CTxDestination > GetNewDestination(const OutputType type, const std::string label)
Definition wallet.cpp:2555
util::Result< void > RemoveTxs(std::vector< uint256 > &txs_to_remove) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Erases the provided transactions from the wallet.
Definition wallet.cpp:2382
size_t KeypoolCountExternalKeys() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2517
bool LockCoin(const COutPoint &output, WalletBatch *batch=nullptr) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2700
std::optional< int64_t > GetOldestKeyPoolTime() const
Definition wallet.cpp:2582
SigningResult SignMessage(const std::string &message, const PKHash &pkhash, std::string &str_sig) const
Definition wallet.cpp:2242
bool SetAddressBookWithDB(WalletBatch &batch, const CTxDestination &address, const std::string &strName, const std::optional< AddressPurpose > &strPurpose)
Definition wallet.cpp:2429
bool DelAddressBookWithDB(WalletBatch &batch, const CTxDestination &address)
Definition wallet.cpp:2478
std::set< std::string > ListAddrBookLabels(const std::optional< AddressPurpose > purpose) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Retrieve all the known labels in the address book.
Definition wallet.cpp:2635
OutputType TransactionChangeType(const std::optional< OutputType > &change_type, const std::vector< CRecipient > &vecSend) const
Definition wallet.cpp:2255
void ListLockedCoins(std::vector< COutPoint > &vOutpts) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2738
void CommitTransaction(CTransactionRef tx, mapValue_t mapValue, std::vector< std::pair< std::string, std::string > > orderForm)
Submit the transaction to the node's mempool and then relay to peers.
Definition wallet.cpp:2316
bool UnlockAllCoins() EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2720
util::Result< CTxDestination > GetNewChangeDestination(const OutputType type)
Definition wallet.cpp:2571
void ForEachAddrBookEntry(const ListAddrBookFunc &func) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2610
bool DelAddressBook(const CTxDestination &address)
Definition wallet.cpp:2471
util::Result< CTxDestination > GetReservedDestination(bool internal)
Reserve an address.
Definition wallet.cpp:2649
util::Result< void > DisplayAddress(const CTxDestination &dest) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Display address on an external signer.
Definition wallet.cpp:2686
bool IsSpentKey(const CScript &scriptPubKey) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:1036
void SyncTransaction(const CTransactionRef &tx, const SyncTxState &state, bool update_tx=true, bool rescanning_old_block=false) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:1419
bool LoadToWallet(const uint256 &hash, const UpdateWalletTxFn &fill_wtx) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:1194
int64_t IncOrderPosNext(WalletBatch *batch=nullptr) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Increment the next transaction order id.
Definition wallet.cpp:964
void MarkInputsDirty(const CTransactionRef &tx) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Mark a transaction's inputs dirty, thus forcing the outputs to be recomputed.
Definition wallet.cpp:1299
bool HasWalletSpend(const CTransactionRef &tx) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Check if a given transaction has any of its outputs spent by another transaction in the wallet.
Definition wallet.cpp:696
void SetMinVersion(enum WalletFeature, WalletBatch *batch_in=nullptr) override
signify that a particular wallet feature is now used.
Definition wallet.cpp:656
bool ChangeWalletPassphrase(const SecureString &strOldWalletPassphrase, const SecureString &strNewWalletPassphrase)
Definition wallet.cpp:598
void SyncMetaData(std::pair< TxSpends::iterator, TxSpends::iterator >) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:718
bool ImportPubKeys(const std::vector< CKeyID > &ordered_pubkeys, const std::map< CKeyID, CPubKey > &pubkey_map, const std::map< CKeyID, std::pair< CPubKey, KeyOriginInfo > > &key_origins, const bool add_keypool, const bool internal, const int64_t timestamp) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:1783
bool ImportScriptPubKeys(const std::string &label, const std::set< CScript > &script_pub_keys, const bool have_solving_data, const bool apply_label, const int64_t timestamp) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:1793
void MarkConflicted(const uint256 &hashBlock, int conflicting_height, const uint256 &hashTx)
Mark a transaction (and its in-wallet descendants) as conflicting with a particular block.
Definition wallet.cpp:1344
void updatedBlockTip() override
Definition wallet.cpp:1572
bool TransactionCanBeAbandoned(const uint256 &hashTx) const
Return whether transaction can be abandoned.
Definition wallet.cpp:1292
bool ImportScripts(const std::set< CScript > scripts, int64_t timestamp) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:1763
void BlockUntilSyncedToCurrentChain() const LOCKS_EXCLUDED(void SetWalletFlag(uint64_t flags)
Blocks until the wallet state is up-to-date to /at least/ the current chain at the time this function...
Definition wallet.cpp:1703
void blockConnected(ChainstateRole role, const interfaces::BlockInfo &block) override
Definition wallet.cpp:1506
void MaybeUpdateBirthTime(int64_t time)
Updates wallet birth time if 'time' is below it.
Definition wallet.cpp:1816
void Flush()
Flush wallet (bitdb flush)
Definition wallet.cpp:708
void blockDisconnected(const interfaces::BlockInfo &block) override
Definition wallet.cpp:1528
bool IsWalletFlagSet(uint64_t flag) const override
check if a certain wallet flag is set
Definition wallet.cpp:1730
std::set< uint256 > GetConflicts(const uint256 &txid) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Get wallet transactions that conflict with given transaction (spend same outputs)
Definition wallet.cpp:673
void UnsetWalletFlagWithDB(WalletBatch &batch, uint64_t flag)
Unsets a wallet flag and saves it to disk.
Definition wallet.cpp:1717
bool IsSpent(const COutPoint &outpoint) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Outpoint is spent if any non-conflicted transaction spends it:
Definition wallet.cpp:761
void UnsetBlankWalletFlag(WalletBatch &batch) override
Unset the blank wallet flag and saves it to disk.
Definition wallet.cpp:1725
void ResubmitWalletTransactions(bool relay, bool force)
Definition wallet.cpp:2102
void SetSpentKeyState(WalletBatch &batch, const uint256 &hash, unsigned int n, bool used, std::set< CTxDestination > &tx_destinations) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:1017
void RecursiveUpdateTxState(const uint256 &tx_hash, const TryUpdatingStateFn &try_updating_state) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Mark a transaction (and its in-wallet descendants) as a particular tx state.
Definition wallet.cpp:1374
bool CanGetAddresses(bool internal=false) const
Definition wallet.cpp:1690
void MarkDirty()
Definition wallet.cpp:976
ScanResult ScanForWalletTransactions(const uint256 &start_block, int start_height, std::optional< int > max_height, const WalletRescanReserver &reserver, bool fUpdate, const bool save_progress)
Scan the block chain (starting in start_block) for transactions from or to us.
Definition wallet.cpp:1876
bool LoadWalletFlags(uint64_t flags)
Loads the flags into the wallet.
Definition wallet.cpp:1735
std::set< uint256 > GetTxConflicts(const CWalletTx &wtx) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:2049
void UpgradeKeyMetadata() EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Upgrade stored CKeyMetadata objects to store key origin info as KeyOriginInfo.
Definition wallet.cpp:545
bool IsHDEnabled() const
Definition wallet.cpp:1679
void transactionRemovedFromMempool(const CTransactionRef &tx, MemPoolRemovalReason reason) override
Definition wallet.cpp:1454
static NodeClock::time_point GetDefaultNextResend()
Definition wallet.cpp:2076
bool ShouldResend() const
Return true if all conditions for periodically resending transactions are met.
Definition wallet.cpp:2059
void InitWalletFlags(uint64_t flags)
overwrite all flags by the given uint64_t flags must be uninitialised (or 0) only known flags may be ...
Definition wallet.cpp:1747
void UnsetWalletFlag(uint64_t flag)
Unsets a single wallet flag.
Definition wallet.cpp:1711
bool AbandonTransaction(const uint256 &hashTx)
Definition wallet.cpp:1309
CAmount GetDebit(const CTxIn &txin, const isminefilter &filter) const
Returns amount of debit if the input matches the filter, otherwise returns 0.
Definition wallet.cpp:1589
bool EncryptWallet(const SecureString &strWalletPassphrase)
Definition wallet.cpp:804
CWalletTx * AddToWallet(CTransactionRef tx, const TxState &state, const UpdateWalletTxFn &update_wtx=nullptr, bool fFlushOnClose=true, bool rescanning_old_block=false)
Add the transaction to the wallet, wrapping it up inside a CWalletTx.
Definition wallet.cpp:1066
void AddToSpends(const COutPoint &outpoint, const uint256 &wtxid, WalletBatch *batch=nullptr) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:778
bool MarkReplaced(const uint256 &originalHash, const uint256 &newHash)
Mark a transaction as replaced by another transaction.
Definition wallet.cpp:985
bool ImportPrivKeys(const std::map< CKeyID, CKey > &privkey_map, const int64_t timestamp) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:1773
int64_t RescanFromTime(int64_t startTime, const WalletRescanReserver &reserver, bool update)
Scan active chain for relevant transactions after importing keys.
Definition wallet.cpp:1832
isminetype IsMine(const CTxDestination &dest) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:1611
bool IsFromMe(const CTransaction &tx) const
should probably be renamed to IsRelevantToMe
Definition wallet.cpp:1662
DBErrors ReorderTransactions()
Definition wallet.cpp:907
bool AddToWalletIfInvolvingMe(const CTransactionRef &tx, const SyncTxState &state, bool fUpdate, bool rescanning_old_block) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Add a transaction to the wallet, or update it.
Definition wallet.cpp:1226
void chainStateFlushed(ChainstateRole role, const CBlockLocator &loc) override
Definition wallet.cpp:645
void UpgradeDescriptorCache() EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Upgrade DescriptorCaches.
Definition wallet.cpp:560
const CWalletTx * GetWalletTx(const uint256 &hash) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition wallet.cpp:536
void transactionAddedToMempool(const CTransactionRef &tx) override
Definition wallet.cpp:1430
void Close()
Close wallet database.
Definition wallet.cpp:713
bool SubmitTxMemoryPoolAndRelay(CWalletTx &wtx, std::string &err_string, bool relay) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Pass this transaction to node for mempool insertion and relay to peers if flag set to true.
Definition wallet.cpp:2019
@ SIGHASH_DEFAULT
Taproot only; implied when sighash byte is missing, and equivalent to SIGHASH_ALL.
Definition interpreter.h:35
ChainstateRole
This enum describes the various roles a specific Chainstate instance can take.
Definition chain.h:25
#define LogPrintf(...)
Definition logging.h:274
MemPoolRemovalReason
Reason why a transaction was removed from the mempool, this is passed to the notification signal.
PSBTError
Definition types.h:17
static constexpr size_t DUMMY_NESTED_P2WPKH_INPUT_SIZE
Pre-calculated constants for input size estimation in virtual size
Definition wallet.h:143
std::variant< TxStateConfirmed, TxStateInMempool, TxStateInactive > SyncTxState
Subset of states transaction sync logic is implemented to handle.
Definition transaction.h:81
constexpr CAmount HIGH_APS_FEE
discourage APS fee higher than this amount
Definition wallet.h:122
std::shared_ptr< CWallet > LoadWallet(WalletContext &context, const std::string &name, std::optional< bool > load_on_start, const DatabaseOptions &options, DatabaseStatus &status, bilingual_str &error, std::vector< bilingual_str > &warnings)
Definition wallet.cpp:370
static const CAmount DEFAULT_FALLBACK_FEE
-fallbackfee default
Definition wallet.h:106
void MaybeResendWalletTxs(WalletContext &context)
Called periodically by the schedule thread.
Definition wallet.cpp:2139
std::vector< std::shared_ptr< CWallet > > GetWallets(WalletContext &context)
Definition wallet.cpp:191
constexpr CAmount DEFAULT_TRANSACTION_MAXFEE
-maxtxfee default
Definition wallet.h:137
std::map< std::string, std::string > mapValue_t
std::vector< unsigned char, secure_allocator< unsigned char > > CKeyingMaterial
Definition crypter.h:62
static const CAmount DEFAULT_DISCARD_FEE
-discardfee default
Definition wallet.h:108
DBErrors
Error statuses for the wallet database.
Definition walletdb.h:48
bool AddWalletSetting(interfaces::Chain &chain, const std::string &wallet_name)
Add wallet name to persistent configuration so it will be loaded on startup.
Definition wallet.cpp:94
bool RemoveWalletSetting(interfaces::Chain &chain, const std::string &wallet_name)
Remove wallet name from persistent configuration so it will not be loaded on startup.
Definition wallet.cpp:107
static const bool DEFAULT_WALLETCROSSCHAIN
Definition wallet.h:135
std::unique_ptr< interfaces::Handler > HandleLoadWallet(WalletContext &context, LoadWalletFn load_wallet)
Definition wallet.cpp:213
static const CAmount DEFAULT_TRANSACTION_MINFEE
-mintxfee default
Definition wallet.h:110
static const unsigned int DEFAULT_KEYPOOL_SIZE
Default for -keypool.
util::Result< MigrationResult > MigrateLegacyToDescriptor(const std::string &wallet_name, const SecureString &passphrase, WalletContext &context)
Do all steps to migrate a legacy wallet to a descriptor wallet.
Definition wallet.cpp:4379
static const bool DEFAULT_WALLET_RBF
-walletrbf default
Definition wallet.h:132
constexpr CAmount HIGH_TX_FEE_PER_KB
Discourage users to set fees higher than this amount (in satoshis) per kB.
Definition wallet.h:139
constexpr OutputType DEFAULT_ADDRESS_TYPE
Default for -addresstype.
Definition wallet.h:148
std::unique_ptr< WalletDatabase > MakeWalletDatabase(const std::string &name, const DatabaseOptions &options, DatabaseStatus &status, bilingual_str &error_string)
Definition wallet.cpp:2961
void NotifyWalletLoaded(WalletContext &context, const std::shared_ptr< CWallet > &wallet)
Definition wallet.cpp:220
constexpr CAmount HIGH_MAX_TX_FEE
-maxtxfee will warn if called with a higher fee than this amount (in satoshis)
Definition wallet.h:141
static const std::map< std::string, WalletFlags > WALLET_FLAG_MAP
Definition wallet.h:162
static const CAmount DEFAULT_MAX_AVOIDPARTIALSPEND_FEE
maximum fee increase allowed to do partial spend avoidance, even for nodes with this feature disabled...
Definition wallet.h:120
static const unsigned int DEFAULT_TX_CONFIRM_TARGET
-txconfirmtarget default
Definition wallet.h:130
isminetype
IsMine() return codes, which depend on ScriptPubKeyMan implementation.
Definition types.h:41
std::string PurposeToString(AddressPurpose p)
Definition wallet.h:270
AddressPurpose
Address purpose field that has been been stored with wallet sending and receiving addresses since BIP...
Definition types.h:61
@ REFUND
Never set in current code may be present in older wallet databases.
static const bool DEFAULT_WALLETBROADCAST
Definition wallet.h:133
std::shared_ptr< CWallet > RestoreWallet(WalletContext &context, const fs::path &backup_file, const std::string &wallet_name, std::optional< bool > load_on_start, DatabaseStatus &status, bilingual_str &error, std::vector< bilingual_str > &warnings)
Definition wallet.cpp:493
bool AddWallet(WalletContext &context, const std::shared_ptr< CWallet > &wallet)
Definition wallet.cpp:149
static const CAmount WALLET_INCREMENTAL_RELAY_FEE
minimum recommended increment for replacement txs
Definition wallet.h:124
WalletFeature
(client) version numbers for particular wallet features
Definition walletutil.h:16
@ FEATURE_BASE
Definition walletutil.h:17
static constexpr uint64_t KNOWN_WALLET_FLAGS
Definition wallet.h:150
std::variant< TxStateConfirmed, TxStateInMempool, TxStateBlockConflicted, TxStateInactive, TxStateUnrecognized > TxState
All possible CWalletTx states.
Definition transaction.h:78
static const CAmount DEFAULT_CONSOLIDATE_FEERATE
-consolidatefeerate default
Definition wallet.h:112
std::shared_ptr< CWallet > CreateWallet(WalletContext &context, const std::string &name, std::optional< bool > load_on_start, DatabaseOptions &options, DatabaseStatus &status, bilingual_str &error, std::vector< bilingual_str > &warnings)
Definition wallet.cpp:383
bool IsFeatureSupported(int wallet_version, int feature_version)
@ WALLET_FLAG_EXTERNAL_SIGNER
Indicates that the wallet needs an external signer.
Definition walletutil.h:77
@ WALLET_FLAG_LAST_HARDENED_XPUB_CACHED
Definition walletutil.h:48
@ WALLET_FLAG_KEY_ORIGIN_METADATA
Definition walletutil.h:45
@ WALLET_FLAG_AVOID_REUSE
Definition walletutil.h:42
std::optional< AddressPurpose > PurposeFromString(std::string_view s)
Definition wallet.h:280
void WaitForDeleteWallet(std::shared_ptr< CWallet > &&wallet)
Explicitly delete the wallet.
Definition wallet.cpp:252
static constexpr uint64_t MUTABLE_WALLET_FLAGS
Definition wallet.h:159
std::shared_ptr< CWallet > GetWallet(WalletContext &context, const std::string &name)
Definition wallet.cpp:204
static const bool DEFAULT_SPEND_ZEROCONF_CHANGE
Default for -spendzeroconfchange.
Definition wallet.h:126
std::underlying_type< isminetype >::type isminefilter
used for bitflags of isminetype
Definition wallet.h:48
static const bool DEFAULT_WALLET_REJECT_LONG_CHAINS
Default for -walletrejectlongchains.
Definition wallet.h:128
DatabaseStatus
Definition db.h:204
bool RemoveWallet(WalletContext &context, const std::shared_ptr< CWallet > &wallet, std::optional< bool > load_on_start, std::vector< bilingual_str > &warnings)
Definition wallet.cpp:161
std::shared_ptr< CWallet > GetDefaultWallet(WalletContext &context, size_t &count)
Definition wallet.cpp:197
OutputType
Definition outputtype.h:17
std::shared_ptr< const CTransaction > CTransactionRef
const char * name
Definition rest.cpp:49
std::basic_string< char, std::char_traits< char >, secure_allocator< char > > SecureString
Definition secure.h:58
SigningResult
Definition signmessage.h:43
Describes a place in the block chain to another node such that if the other node doesn't have the sam...
Definition block.h:124
Definition key.h:227
A mutable version of CTransaction.
std::chrono::time_point< NodeClock > time_point
Definition time.h:17
A version of CTransaction with the PSBT format.
Definition psbt.h:951
Bilingual messages:
Definition translation.h:18
Address book data.
Definition wallet.h:229
std::optional< AddressPurpose > purpose
Address purpose which was originally recorded for payment protocol support but now serves as a cached...
Definition wallet.h:244
void SetLabel(std::string name)
Definition wallet.h:267
std::string GetLabel() const
Definition wallet.h:266
bool previously_spent
Whether coins with this address have previously been spent.
Definition wallet.h:253
std::map< std::string, std::string > receive_requests
Map containing data about previously generated receive requests requesting funds to be sent to this a...
Definition wallet.h:262
std::optional< std::string > label
Address label which is always nullopt for change addresses.
Definition wallet.h:237
bool IsChange() const
Accessor methods.
Definition wallet.h:265
CAmount nAmount
Definition wallet.h:291
bool fSubtractFeeFromAmount
Definition wallet.h:292
CTxDestination dest
Definition wallet.h:290
std::optional< int > last_scanned_height
Definition wallet.h:622
uint256 last_scanned_block
Hash and height of most recent block that was successfully scanned.
Definition wallet.h:621
uint256 last_failed_block
Height of the most recent block that could not be scanned due to read errors or pruning.
Definition wallet.h:628
struct containing information needed for migrating legacy wallets to descriptor wallets
std::shared_ptr< CWallet > watchonly_wallet
Definition wallet.h:1123
std::string wallet_name
Definition wallet.h:1121
std::shared_ptr< CWallet > solvables_wallet
Definition wallet.h:1124
std::shared_ptr< CWallet > wallet
Definition wallet.h:1122
WalletContext struct containing references to state shared between CWallet instances,...
Definition context.h:36
#define LOCK(cs)
Definition sync.h:257
#define AssertLockHeld(cs)
Definition sync.h:142
static int count
#define EXCLUSIVE_LOCKS_REQUIRED(...)
#define GUARDED_BY(x)
#define LOCKS_EXCLUDED(...)
#define strprintf
Format arguments and return the string or write to given std::ostream (see tinyformat::format doc for...
ChangeType
General change type (added, updated, removed).
assert(!tx.IsCoinBase())
std::shared_ptr< CWallet > m_wallet
is a home for public enum and struct type definitions that are used by internally by wallet code,...
std::function< void(std::unique_ptr< interfaces::Wallet > wallet)> LoadWalletFn
Definition wallet.h:79