Bitcoin Core 31.99.0
P2P Digital Currency
wallet.h
Go to the documentation of this file.
1// Copyright (c) 2009-2010 Satoshi Nakamoto
2// Copyright (c) 2009-present 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 <btcsignals.h>
11#include <consensus/amount.h>
12#include <interfaces/chain.h>
13#include <interfaces/handler.h>
14#include <kernel/cs_main.h>
15#include <logging.h>
16#include <node/types.h>
17#include <outputtype.h>
18#include <policy/feerate.h>
21#include <script/interpreter.h>
22#include <script/script.h>
24#include <sync.h>
25#include <tinyformat.h>
26#include <uint256.h>
27#include <util/fs.h>
28#include <util/hasher.h>
29#include <util/result.h>
30#include <util/string.h>
31#include <util/time.h>
32#include <util/ui_change_type.h>
33#include <wallet/crypter.h>
34#include <wallet/db.h>
36#include <wallet/transaction.h>
37#include <wallet/types.h>
38#include <wallet/walletutil.h>
39
40#include <atomic>
41#include <cassert>
42#include <cstddef>
43#include <cstdint>
44#include <functional>
45#include <limits>
46#include <map>
47#include <memory>
48#include <optional>
49#include <set>
50#include <string>
51#include <unordered_map>
52#include <utility>
53#include <vector>
54
55class CKey;
56class CKeyID;
57class CPubKey;
58class Coin;
59class SigningProvider;
60enum class MemPoolRemovalReason;
61enum class SigningResult;
62namespace common {
63enum class PSBTError;
64} // namespace common
65namespace interfaces {
66class Wallet;
67}
68namespace wallet {
69class CWallet;
70class WalletBatch;
71enum class DBErrors : int;
72} // namespace wallet
73struct CBlockLocator;
74struct CExtKey;
76struct KeyOriginInfo;
78struct SignatureData;
79
80using LoadWalletFn = std::function<void(std::unique_ptr<interfaces::Wallet> wallet)>;
81
82struct bilingual_str;
83
84namespace wallet {
85struct WalletContext;
86
89void WaitForDeleteWallet(std::shared_ptr<CWallet>&& wallet);
90
91bool AddWallet(WalletContext& context, const std::shared_ptr<CWallet>& wallet);
92bool RemoveWallet(WalletContext& context, const std::shared_ptr<CWallet>& wallet, std::optional<bool> load_on_start, std::vector<bilingual_str>& warnings);
93bool RemoveWallet(WalletContext& context, const std::shared_ptr<CWallet>& wallet, std::optional<bool> load_on_start);
94std::vector<std::shared_ptr<CWallet>> GetWallets(WalletContext& context);
95std::shared_ptr<CWallet> GetDefaultWallet(WalletContext& context, size_t& count);
96std::shared_ptr<CWallet> GetWallet(WalletContext& context, const std::string& name);
97std::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);
98std::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);
99std::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, bool load_after_restore = true, bool allow_unnamed = false);
100std::unique_ptr<interfaces::Handler> HandleLoadWallet(WalletContext& context, LoadWalletFn load_wallet);
101void NotifyWalletLoaded(WalletContext& context, const std::shared_ptr<CWallet>& wallet);
102std::unique_ptr<WalletDatabase> MakeWalletDatabase(const std::string& name, const DatabaseOptions& options, DatabaseStatus& status, bilingual_str& error);
103
107static const CAmount DEFAULT_DISCARD_FEE = 10000;
111static const CAmount DEFAULT_CONSOLIDATE_FEERATE{10000}; // 10 sat/vbyte
121constexpr CAmount HIGH_APS_FEE{COIN / 10000};
125static const bool DEFAULT_SPEND_ZEROCONF_CHANGE = true;
127static const bool DEFAULT_WALLET_REJECT_LONG_CHAINS{true};
129static const unsigned int DEFAULT_TX_CONFIRM_TARGET = 6;
131static const bool DEFAULT_WALLET_RBF = true;
132static const bool DEFAULT_WALLETBROADCAST = true;
133static const bool DEFAULT_DISABLE_WALLET = false;
134static const bool DEFAULT_WALLETCROSSCHAIN = false;
142static constexpr size_t DUMMY_NESTED_P2WPKH_INPUT_SIZE = 91;
143
144class CCoinControl;
145
148
149static constexpr uint64_t KNOWN_WALLET_FLAGS =
157
158static constexpr uint64_t MUTABLE_WALLET_FLAGS =
160
161static const std::map<WalletFlags, std::string> WALLET_FLAG_TO_STRING{
162 {WALLET_FLAG_AVOID_REUSE, "avoid_reuse"},
163 {WALLET_FLAG_BLANK_WALLET, "blank"},
164 {WALLET_FLAG_KEY_ORIGIN_METADATA, "key_origin_metadata"},
165 {WALLET_FLAG_LAST_HARDENED_XPUB_CACHED, "last_hardened_xpub_cached"},
166 {WALLET_FLAG_DISABLE_PRIVATE_KEYS, "disable_private_keys"},
167 {WALLET_FLAG_DESCRIPTORS, "descriptor_wallet"},
168 {WALLET_FLAG_EXTERNAL_SIGNER, "external_signer"}
169};
170
171static const std::map<std::string, WalletFlags> STRING_TO_WALLET_FLAG{
179};
180
197{
198protected:
200 const CWallet* const pwallet;
205 int64_t nIndex{-1};
209 bool fInternal{false};
210
211public:
215 , type(type) { }
216
219
222 {
224 }
225
229 void ReturnDestination();
231 void KeepDestination();
232};
233
238{
246 std::optional<std::string> label;
247
253 std::optional<AddressPurpose> purpose;
254
262 bool previously_spent{false};
263
271 std::map<std::string, std::string> receive_requests{};
272
274 bool IsChange() const { return !label.has_value(); }
275 std::string GetLabel() const { return label ? *label : std::string{}; }
276 void SetLabel(std::string name) { label = std::move(name); }
277};
278
279inline std::string PurposeToString(AddressPurpose p)
280{
281 switch(p) {
282 case AddressPurpose::RECEIVE: return "receive";
283 case AddressPurpose::SEND: return "send";
284 case AddressPurpose::REFUND: return "refund";
285 } // no default case, so the compiler can warn about missing cases
286 assert(false);
287}
288
289inline std::optional<AddressPurpose> PurposeFromString(std::string_view s)
290{
291 if (s == "receive") return AddressPurpose::RECEIVE;
292 else if (s == "send") return AddressPurpose::SEND;
293 else if (s == "refund") return AddressPurpose::REFUND;
294 return {};
295}
296
298{
302};
303
304class WalletRescanReserver; //forward declarations for ScanForWalletTransactions/RescanFromTime
309{
310private:
312
313 bool Unlock(const CKeyingMaterial& vMasterKeyIn);
314
315 std::atomic<bool> fAbortRescan{false};
316 std::atomic<bool> fScanningWallet{false}; // controlled by WalletRescanReserver
317 std::atomic<bool> m_scanning_with_passphrase{false};
318 std::atomic<SteadyClock::time_point> m_scanning_start{SteadyClock::time_point{}};
319 std::atomic<double> m_scanning_progress{0};
321
327 // Local time that the tip block was received. Used to schedule wallet rebroadcasts.
328 std::atomic<int64_t> m_best_block_time {0};
329
330 // First created key time. Used to skip blocks prior to this time.
331 // 'std::numeric_limits<int64_t>::max()' if wallet is blank.
332 std::atomic<int64_t> m_birth_time{std::numeric_limits<int64_t>::max()};
333
339 typedef std::unordered_multimap<COutPoint, Txid, SaltedOutpointHasher> TxSpends;
341 void AddToSpends(const COutPoint& outpoint, const Txid& txid) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
343
360 bool AddToWalletIfInvolvingMe(const CTransactionRef& tx, const SyncTxState& state, bool fUpdate, bool rescanning_old_block) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
361
363 void MarkConflicted(const uint256& hashBlock, int conflicting_height, const Txid& hashTx);
364
365 enum class TxUpdate { UNCHANGED, CHANGED, NOTIFY_CHANGED };
366
367 using TryUpdatingStateFn = std::function<TxUpdate(CWalletTx& wtx)>;
368
370 void RecursiveUpdateTxState(const Txid& tx_hash, const TryUpdatingStateFn& try_updating_state) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
371 void RecursiveUpdateTxState(WalletBatch* batch, const Txid& tx_hash, const TryUpdatingStateFn& try_updating_state) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
372
375
376 void SyncMetaData(std::pair<TxSpends::iterator, TxSpends::iterator>) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
377
378 bool SyncTransaction(const CTransactionRef& tx, const SyncTxState& state, bool update_tx = true, bool rescanning_old_block = false) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
379
381 std::atomic<uint64_t> m_wallet_flags{0};
382
383 bool SetAddressBookWithDB(WalletBatch& batch, const CTxDestination& address, const std::string& strName, const std::optional<AddressPurpose>& strPurpose);
384
386 void UnsetWalletFlagWithDB(WalletBatch& batch, uint64_t flag);
387
389 void UnsetBlankWalletFlag(WalletBatch& batch) override;
390
393
395 std::string m_name;
396
398 std::unique_ptr<WalletDatabase> m_database;
399
407 uint256 m_last_block_processed GUARDED_BY(cs_wallet);
408
414 int m_last_block_processed_height GUARDED_BY(cs_wallet) = -1;
415
416 std::map<OutputType, ScriptPubKeyMan*> m_external_spk_managers;
417 std::map<OutputType, ScriptPubKeyMan*> m_internal_spk_managers;
418
419 // Indexed by a unique identifier produced by each ScriptPubKeyMan using
420 // ScriptPubKeyMan::GetID. In many cases it will be the hash of an internal structure
421 std::map<uint256, std::unique_ptr<ScriptPubKeyMan>> m_spk_managers;
422
423 // Appends spk managers into the main 'm_spk_managers'.
424 // Must be the only method adding data to it.
425 void AddScriptPubKeyMan(const uint256& id, std::unique_ptr<ScriptPubKeyMan> spkm_man);
426
427 // Same as 'AddActiveScriptPubKeyMan' but designed for use within a batch transaction context
428 void AddActiveScriptPubKeyManWithDb(WalletBatch& batch, uint256 id, OutputType type, bool internal);
429
431 void SetWalletFlagWithDB(WalletBatch& batch, uint64_t flags);
432
434 std::unordered_map<CScript, std::vector<ScriptPubKeyMan*>, SaltedSipHasher> m_cached_spks;
435
437 std::unordered_map<COutPoint, WalletTXO, SaltedOutpointHasher> m_txos GUARDED_BY(cs_wallet);
438
444 static bool AttachChain(const std::shared_ptr<CWallet>& wallet, interfaces::Chain& chain, bool rescan_required, bilingual_str& error, std::vector<bilingual_str>& warnings);
445
447
448 // Update last block processed in memory only
449 void SetLastBlockProcessedInMem(int block_height, uint256 block_hash) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
450
452 void UpdateTrucSiblingConflicts(const CWalletTx& parent_wtx, const Txid& child_txid, bool add_conflict) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
453
454public:
460
461 WalletDatabase& GetDatabase() const override
462 {
463 assert(static_cast<bool>(m_database));
464 return *m_database;
465 }
466
469 const std::string& GetName() const { return m_name; }
470
471 typedef std::map<unsigned int, CMasterKey> MasterKeyMap;
473 unsigned int nMasterKeyMaxID = 0;
474
476 CWallet(interfaces::Chain* chain, const std::string& name, std::unique_ptr<WalletDatabase> database)
477 : m_chain(chain),
478 m_name(name),
479 m_database(std::move(database))
480 {
481 }
482
484 {
485 // Should not have slots connected at this point.
487 }
488
489 bool IsLocked() const override;
490 bool Lock();
491
493 bool HaveChain() const { return m_chain ? true : false; }
494
497 std::unordered_map<Txid, CWalletTx, SaltedTxidHasher> mapWallet GUARDED_BY(cs_wallet);
498
499 typedef std::multimap<int64_t, CWalletTx*> TxItems;
501
502 int64_t nOrderPosNext GUARDED_BY(cs_wallet) = 0;
503
504 std::map<CTxDestination, CAddressBookData> m_address_book GUARDED_BY(cs_wallet);
505 const CAddressBookData* FindAddressBookEntry(const CTxDestination&, bool allow_change = false) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
506
513 std::map<COutPoint, bool> m_locked_coins GUARDED_BY(cs_wallet);
514
517
519 interfaces::Chain& chain() const { assert(m_chain); return *m_chain; }
520
522
523 std::set<Txid> GetTxConflicts(const CWalletTx& wtx) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
524
525 const std::unordered_map<COutPoint, WalletTXO, SaltedOutpointHasher>& GetTXOs() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet) { AssertLockHeld(cs_wallet); return m_txos; };
526 std::optional<WalletTXO> GetTXO(const COutPoint& outpoint) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
527
532
547
555
556 bool IsSpent(const COutPoint& outpoint) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
557
558 // Whether this or any known scriptPubKey with the same single key has been spent.
559 bool IsSpentKey(const CScript& scriptPubKey) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
560 void SetSpentKeyState(WalletBatch& batch, const Txid& hash, unsigned int n, bool used, std::set<CTxDestination>& tx_destinations) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
561
564
565 bool IsLockedCoin(const COutPoint& output) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
566 void LoadLockedCoin(const COutPoint& coin, bool persistent) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
567 bool LockCoin(const COutPoint& output, bool persist) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
570 void ListLockedCoins(std::vector<COutPoint>& vOutpts) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
571
572 /*
573 * Rescan abort properties
574 */
575 void AbortRescan() { fAbortRescan = true; }
576 bool IsAbortingRescan() const { return fAbortRescan; }
577 bool IsScanning() const { return fScanningWallet; }
579 SteadyClock::duration ScanningDuration() const { return fScanningWallet ? SteadyClock::now() - m_scanning_start.load() : SteadyClock::duration{}; }
580 double ScanningProgress() const { return fScanningWallet ? (double) m_scanning_progress : 0; }
581
584
588 void LoadAddressReceiveRequest(const CTxDestination& dest, const std::string& id, const std::string& request) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
589
591 int64_t nRelockTime GUARDED_BY(cs_wallet){0};
592
593 // Used to prevent concurrent calls to walletpassphrase RPC.
595 // Used to prevent deleting the passphrase from memory when it is still in use.
597
598 bool Unlock(const SecureString& strWalletPassphrase);
599 bool ChangeWalletPassphrase(const SecureString& strOldWalletPassphrase, const SecureString& strNewWalletPassphrase);
600 bool EncryptWallet(const SecureString& strWalletPassphrase);
601
602 unsigned int ComputeTimeSmart(const CWalletTx& wtx, bool rescanning_old_block) const;
603
610
611 void MarkDirty();
612
619 using UpdateWalletTxFn = std::function<bool(CWalletTx& wtx, bool new_tx)>;
620
625 CWalletTx* AddToWallet(CTransactionRef tx, const TxState& state, const UpdateWalletTxFn& update_wtx=nullptr, bool rescanning_old_block = false);
626 bool LoadToWallet(const Txid& hash, const UpdateWalletTxFn& fill_wtx) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
627 void transactionAddedToMempool(const CTransactionRef& tx) override;
628 void blockConnected(const kernel::ChainstateRole& role, const interfaces::BlockInfo& block) override;
629 void blockDisconnected(const interfaces::BlockInfo& block) override;
630 void updatedBlockTip() override;
631 int64_t RescanFromTime(int64_t startTime, const WalletRescanReserver& reserver, bool update);
632
633 struct ScanResult {
634 enum { SUCCESS, FAILURE, USER_ABORT } status = SUCCESS;
635
640 std::optional<int> last_scanned_height;
641
647 };
648 ScanResult ScanForWalletTransactions(const uint256& start_block, int start_height, std::optional<int> max_height, const WalletRescanReserver& reserver, bool fUpdate, bool save_progress);
653 bool ShouldResend() const;
654 void ResubmitWalletTransactions(node::TxBroadcast broadcast_method, bool force);
655
656 OutputType TransactionChangeType(const std::optional<OutputType>& change_type, const std::vector<CRecipient>& vecSend) const;
657
661 bool SignTransaction(CMutableTransaction& tx, const std::map<COutPoint, Coin>& coins, int sighash, std::map<int, bilingual_str>& input_errors) const;
662 SigningResult SignMessage(const std::string& message, const PKHash& pkhash, std::string& str_sig) const;
663
679 std::optional<common::PSBTError> FillPSBT(PartiallySignedTransaction& psbtx,
680 bool& complete,
681 std::optional<int> sighash_type = std::nullopt,
682 bool sign = true,
683 bool bip32derivs = true,
684 size_t* n_signed = nullptr,
685 bool finalize = true) const;
686
696 void CommitTransaction(CTransactionRef tx, mapValue_t mapValue, std::vector<std::pair<std::string, std::string>> orderForm);
697
699 bool SubmitTxMemoryPoolAndRelay(CWalletTx& wtx, std::string& err_string, node::TxBroadcast broadcast_method) const
701
703 void MaybeUpdateBirthTime(int64_t time);
704
718
722
728
738 std::optional<OutputType> m_default_change_type{};
741
744
747
749 bool TopUpKeyPool(unsigned int kpSize = 0);
750
751 // Filter struct for 'ListAddrBookAddresses'
753 // Fetch addresses with the provided label
754 std::optional<std::string> m_op_label{std::nullopt};
755 // Don't include change addresses by default
756 bool ignore_change{true};
757 };
758
762 std::vector<CTxDestination> ListAddrBookAddresses(const std::optional<AddrBookFilter>& filter) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
763
767 std::set<std::string> ListAddrBookLabels(std::optional<AddressPurpose> purpose) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
768
773 using ListAddrBookFunc = std::function<void(const CTxDestination& dest, const std::string& label, bool is_change, const std::optional<AddressPurpose> purpose)>;
775
780 void MarkDestinationsDirty(const std::set<CTxDestination>& destinations) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
781
782 util::Result<CTxDestination> GetNewDestination(OutputType type, const std::string& label);
784
788 CAmount GetDebit(const CTxIn& txin) const;
789 bool IsMine(const CTxOut& txout) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
791 bool IsMine(const COutPoint& outpoint) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
793 bool IsFromMe(const CTransaction& tx) const;
794 CAmount GetDebit(const CTransaction& tx) const;
795
796 DBErrors PopulateWalletFromDB(bilingual_str& error, std::vector<bilingual_str>& warnings);
797
799 util::Result<void> RemoveTxs(std::vector<Txid>& txs_to_remove) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
800 util::Result<void> RemoveTxs(WalletBatch& batch, std::vector<Txid>& txs_to_remove) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
801
802 bool SetAddressBook(const CTxDestination& address, const std::string& strName, const std::optional<AddressPurpose>& purpose);
803
804 bool DelAddressBook(const CTxDestination& address);
805 bool DelAddressBookWithDB(WalletBatch& batch, const CTxDestination& address);
806
809
810 std::vector<std::string> GetAddressReceiveRequests() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
811 bool SetAddressReceiveRequest(WalletBatch& batch, const CTxDestination& dest, const std::string& id, const std::string& value) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
813
815
818
821
823 void Close();
824
826 btcsignals::signal<void ()> NotifyUnload;
827
832 btcsignals::signal<void(const CTxDestination& address,
833 const std::string& label, bool isMine,
834 AddressPurpose purpose, ChangeType status)>
836
841 btcsignals::signal<void(const Txid& hashTx, ChangeType status)> NotifyTransactionChanged;
842
844 btcsignals::signal<void (const std::string &title, int nProgress)> ShowProgress;
845
848
854
858 void SetBroadcastTransactions(bool broadcast) { fBroadcastTransactions = broadcast; }
859
861 bool TransactionCanBeAbandoned(const Txid& hashTx) const;
862
863 /* Mark a transaction (and it in-wallet descendants) as abandoned so its inputs may be respent. */
864 bool AbandonTransaction(const Txid& hashTx);
866
868 bool MarkReplaced(const Txid& originalHash, const Txid& newHash);
869
870 static bool LoadWalletArgs(std::shared_ptr<CWallet> wallet, const WalletContext& context, bilingual_str& error, std::vector<bilingual_str>& warnings);
871
872 /* Initializes, creates and returns a new CWallet; returns a null pointer in case of an error */
873 static std::shared_ptr<CWallet> CreateNew(WalletContext& context, const std::string& name, std::unique_ptr<WalletDatabase> database, uint64_t wallet_creation_flags, bilingual_str& error, std::vector<bilingual_str>& warnings);
874
875 /* Initializes, loads, and returns a CWallet from an existing wallet; returns a null pointer in case of an error */
876 static std::shared_ptr<CWallet> LoadExisting(WalletContext& context, const std::string& name, std::unique_ptr<WalletDatabase> database, bilingual_str& error, std::vector<bilingual_str>& warnings);
877
882 void postInitProcess();
883
884 bool BackupWallet(const std::string& strDest) const;
885
886 /* Returns true if HD is enabled */
887 bool IsHDEnabled() const;
888
889 /* Returns true if the wallet can give out new addresses. This means it has keys in the keypool or can generate new keys */
890 bool CanGetAddresses(bool internal = false) const;
891
892 /* Returns the time of the first created key or, in case of an import, it could be the time of the first received transaction */
893 int64_t GetBirthTime() const { return m_birth_time; }
894
901 void BlockUntilSyncedToCurrentChain() const LOCKS_EXCLUDED(::cs_main) EXCLUSIVE_LOCKS_REQUIRED(!cs_wallet);
902
904 void SetWalletFlag(uint64_t flags);
905
907 void UnsetWalletFlag(uint64_t flag);
908
910 bool IsWalletFlagSet(uint64_t flag) const override;
911
915 void InitWalletFlags(uint64_t flags);
917 bool LoadWalletFlags(uint64_t flags);
919 uint64_t GetWalletFlags() const;
920
922 std::string LogName() const override
923 {
924 std::string name{GetName()};
925 return name.empty() ? "default wallet" : name;
926 };
927
929 std::string DisplayName() const
930 {
931 std::string name{GetName()};
932 return name.empty() ? _("default wallet") : name;
933 };
934
936 template <typename... Params>
937 void WalletLogPrintf(util::ConstevalFormatString<sizeof...(Params)> wallet_fmt, const Params&... params) const
938 {
939 LogInfo("[%s] %s", LogName(), tfm::format(wallet_fmt, params...));
940 };
941
943 {
945 WalletLogPrintf("setKeyPool.size() = %u\n", GetKeyPoolSize());
946 WalletLogPrintf("mapWallet.size() = %u\n", mapWallet.size());
947 WalletLogPrintf("m_address_book.size() = %u\n", m_address_book.size());
948 };
949
951 std::set<ScriptPubKeyMan*> GetActiveScriptPubKeyMans() const;
952 bool IsActiveScriptPubKeyMan(const ScriptPubKeyMan& spkm) const;
953
955 std::set<ScriptPubKeyMan*> GetAllScriptPubKeyMans() const;
956
958 ScriptPubKeyMan* GetScriptPubKeyMan(const OutputType& type, bool internal) const;
959
961 std::set<ScriptPubKeyMan*> GetScriptPubKeyMans(const CScript& script) const;
964
966 std::unique_ptr<SigningProvider> GetSolvingProvider(const CScript& script) const;
967 std::unique_ptr<SigningProvider> GetSolvingProvider(const CScript& script, SignatureData& sigdata) const;
968
970 std::vector<WalletDescriptor> GetWalletDescriptors(const CScript& script) const;
971
975
978
979 bool WithEncryptionKey(std::function<bool (const CKeyingMaterial&)> cb) const override;
980
981 bool HasEncryptionKeys() const override;
982 bool HaveCryptedKeys() const;
983
986 {
988 assert(m_last_block_processed_height >= 0);
989 return m_last_block_processed_height;
990 };
992 {
994 assert(m_last_block_processed_height >= 0);
995 return m_last_block_processed;
996 }
998 void SetLastBlockProcessed(int block_height, uint256 block_hash) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
1001
1004
1007
1012 void AddActiveScriptPubKeyMan(uint256 id, OutputType type, bool internal);
1013
1018 void LoadActiveScriptPubKeyMan(uint256 id, OutputType type, bool internal);
1019
1024 void DeactivateScriptPubKeyMan(uint256 id, OutputType type, bool internal);
1025
1031
1034
1037
1041 std::optional<bool> IsInternalScriptPubKeyMan(ScriptPubKeyMan* spk_man) const;
1042
1044 util::Result<std::reference_wrapper<DescriptorScriptPubKeyMan>> AddWalletDescriptor(WalletDescriptor& desc, const FlatSigningProvider& signing_provider, const std::string& label, bool internal) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet);
1045
1052
1055
1059
1061 bool CanGrindR() const;
1062
1064 void CacheNewScriptPubKeys(const std::set<CScript>& spks, ScriptPubKeyMan* spkm);
1065
1066 void TopUpCallback(const std::set<CScript>& spks, ScriptPubKeyMan* spkm) override;
1067
1070
1073 std::optional<CKey> GetKey(const CKeyID& keyid) const;
1074
1077};
1078
1083void MaybeResendWalletTxs(WalletContext& context);
1084
1087{
1088private:
1089 using Clock = std::chrono::steady_clock;
1090 using NowFn = std::function<Clock::time_point()>;
1092 bool m_could_reserve{false};
1094public:
1096
1097 bool reserve(bool with_passphrase = false)
1098 {
1099 assert(!m_could_reserve);
1100 if (m_wallet.fScanningWallet.exchange(true)) {
1101 return false;
1102 }
1103 m_wallet.m_scanning_with_passphrase.exchange(with_passphrase);
1104 m_wallet.m_scanning_start = SteadyClock::now();
1105 m_wallet.m_scanning_progress = 0;
1106 m_could_reserve = true;
1107 return true;
1108 }
1109
1110 bool isReserved() const
1111 {
1112 return (m_could_reserve && m_wallet.fScanningWallet);
1113 }
1114
1115 Clock::time_point now() const { return m_now ? m_now() : Clock::now(); };
1116
1117 void setNow(NowFn now) { m_now = std::move(now); }
1118
1120 {
1121 if (m_could_reserve) {
1122 m_wallet.fScanningWallet = false;
1123 m_wallet.m_scanning_with_passphrase = false;
1124 }
1125 }
1126};
1127
1129bool AddWalletSetting(interfaces::Chain& chain, const std::string& wallet_name);
1130
1132bool RemoveWalletSetting(interfaces::Chain& chain, const std::string& wallet_name);
1133
1135 std::string wallet_name;
1136 std::shared_ptr<CWallet> wallet;
1137 std::shared_ptr<CWallet> watchonly_wallet;
1138 std::shared_ptr<CWallet> solvables_wallet;
1139 fs::path backup_path;
1140};
1141
1143[[nodiscard]] util::Result<MigrationResult> MigrateLegacyToDescriptor(const std::string& wallet_name, const SecureString& passphrase, WalletContext& context);
1145[[nodiscard]] util::Result<MigrationResult> MigrateLegacyToDescriptor(std::shared_ptr<CWallet> local_wallet, const SecureString& passphrase, WalletContext& context);
1146} // namespace wallet
1147
1148#endif // BITCOIN_WALLET_WALLET_H
std::variant< CNoDestination, PubKeyDestination, PKHash, ScriptHash, WitnessV0ScriptHash, WitnessV0KeyHash, WitnessV1Taproot, PayToAnchor, WitnessUnknown > CTxDestination
A txout script categorized into standard templates.
Definition: addresstype.h:143
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
Definition: bitcoin-tx.cpp:530
const CChainParams & Params()
Return the currently selected parameters.
Fee rate in satoshis per virtualbyte: CAmount / vB the feerate is represented internally as FeeFrac.
Definition: feerate.h:32
An encapsulated private key.
Definition: key.h:36
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:405
The basic transaction that is broadcasted on the network and contained in blocks.
Definition: transaction.h:281
An input of a transaction.
Definition: transaction.h:62
An output of a transaction.
Definition: transaction.h:140
A UTXO entry.
Definition: coins.h:35
An interface to be implemented by keystores that support signing.
bool empty() const EXCLUSIVE_LOCKS_REQUIRED(!m_mutex)
Definition: btcsignals.h:246
Chain notifications.
Definition: chain.h:306
Interface giving clients (wallet processes, maybe other analysis tools in the future) ability to acce...
Definition: chain.h:118
256-bit opaque blob.
Definition: uint256.h:196
Coin Control Features.
Definition: coincontrol.h:84
A CWallet maintains a set of transactions and balances, and provides the ability to create new transa...
Definition: wallet.h:309
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:2630
bool SetAddressBook(const CTxDestination &address, const std::string &strName, const std::optional< AddressPurpose > &purpose)
Definition: wallet.cpp:2518
std::atomic< bool > fAbortRescan
Definition: wallet.h:315
bool TopUpKeyPool(unsigned int kpSize=0)
Definition: wallet.cpp:2593
bool HaveChain() const
Interface to assert chain access.
Definition: wallet.h:493
bool GetBroadcastTransactions() const
Inquire whether this wallet broadcasts transactions.
Definition: wallet.h:856
bool m_signal_rbf
Definition: wallet.h:709
int64_t GetBirthTime() const
Definition: wallet.h:893
std::atomic< SteadyClock::time_point > m_scanning_start
Definition: wallet.h:318
DBErrors PopulateWalletFromDB(bilingual_str &error, std::vector< bilingual_str > &warnings)
Definition: wallet.cpp:2367
unsigned int GetKeyPoolSize() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2582
std::function< bool(CWalletTx &wtx, bool new_tx)> UpdateWalletTxFn
Callback for updating transaction metadata in mapWallet.
Definition: wallet.h:619
CAmount m_default_max_tx_fee
Absolute maximum transaction fee (in satoshis) used by default for the wallet.
Definition: wallet.h:740
btcsignals::signal< void()> NotifyUnload
Wallet is about to be unloaded.
Definition: wallet.h:826
std::optional< WalletTXO > GetTXO(const COutPoint &outpoint) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:4577
bool IsActiveScriptPubKeyMan(const ScriptPubKeyMan &spkm) const
Definition: wallet.cpp:3408
static bool AttachChain(const std::shared_ptr< CWallet > &wallet, interfaces::Chain &chain, 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:3173
OutputType m_default_address_type
Definition: wallet.h:731
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...
static std::shared_ptr< CWallet > LoadExisting(WalletContext &context, const std::string &name, std::unique_ptr< WalletDatabase > database, bilingual_str &error, std::vector< bilingual_str > &warnings)
Definition: wallet.cpp:3129
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:721
void AddActiveScriptPubKeyMan(uint256 id, OutputType type, bool internal)
Adds the active ScriptPubKeyMan for the specified type and internal.
Definition: wallet.cpp:3675
void LogStats() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.h:942
btcsignals::signal< void(const CTxDestination &address, const std::string &label, bool isMine, AddressPurpose purpose, ChangeType status)> NotifyAddressBookChanged
Address book entry changed.
Definition: wallet.h:835
void LoadActiveScriptPubKeyMan(uint256 id, OutputType type, bool internal)
Loads an active ScriptPubKeyMan for the specified type and internal.
Definition: wallet.cpp:3689
std::unique_ptr< WalletDatabase > m_database
Internal database handle.
Definition: wallet.h:398
bool IsLockedCoin(const COutPoint &output) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2777
bool SignTransaction(CMutableTransaction &tx) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Fetch the inputs and sign with SIGHASH_ALL.
Definition: wallet.cpp:2166
CWallet(interfaces::Chain *chain, const std::string &name, std::unique_ptr< WalletDatabase > database)
Construct wallet with specified name and database implementation.
Definition: wallet.h:476
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:773
std::unique_ptr< SigningProvider > GetSolvingProvider(const CScript &script) const
Get the SigningProvider for a script.
Definition: wallet.cpp:3461
bool IsTxImmatureCoinBase(const CWalletTx &wtx) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:3345
void RefreshAllTXOs() EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Cache outputs that belong to the wallet for all transactions in the wallet.
Definition: wallet.cpp:4569
void AddActiveScriptPubKeyManWithDb(WalletBatch &batch, uint256 id, OutputType type, bool internal)
Definition: wallet.cpp:3681
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:4498
std::set< ScriptPubKeyMan * > GetActiveScriptPubKeyMans() const
Returns all unique ScriptPubKeyMans in m_internal_spk_managers and m_external_spk_managers.
Definition: wallet.cpp:3394
const CAddressBookData * FindAddressBookEntry(const CTxDestination &, bool allow_change=false) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:3293
void postInitProcess()
Wallet post-init setup Gives the wallet a chance to register repetitive tasks and complete post-init ...
Definition: wallet.cpp:3303
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:3319
std::optional< common::PSBTError > FillPSBT(PartiallySignedTransaction &psbtx, bool &complete, std::optional< int > sighash_type=std::nullopt, 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:2200
unsigned int nMasterKeyMaxID
Definition: wallet.h:473
bool IsScanning() const
Definition: wallet.h:577
bool SetAddressReceiveRequest(WalletBatch &batch, const CTxDestination &dest, const std::string &id, const std::string &value) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2906
int GetLastBlockHeight() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Get last block processed height.
Definition: wallet.h:985
std::atomic< double > m_scanning_progress
Definition: wallet.h:319
LegacyDataSPKM * GetLegacyDataSPKM() const
Get the LegacyScriptPubKeyMan which is used for all types, internal, and external.
Definition: wallet.cpp:3492
void DisconnectChainNotifications()
Disconnect chain notifications and wait for all notifications to be processed.
Definition: wallet.cpp:4587
CAmount m_max_aps_fee
The maximum fee amount we're willing to pay to prioritize partial spend avoidance.
Definition: wallet.h:730
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:2653
DescriptorScriptPubKeyMan * GetDescriptorScriptPubKeyMan(const WalletDescriptor &desc) const
Return the DescriptorScriptPubKeyMan for a WalletDescriptor if it is already in the wallet.
Definition: wallet.cpp:3726
btcsignals::signal< void(CWallet *wallet)> NotifyStatusChanged
Wallet status (encrypted, locked) changed.
Definition: wallet.h:853
btcsignals::signal< void()> NotifyCanGetAddressesChanged
Keypool has new keys.
Definition: wallet.h:847
std::map< OutputType, ScriptPubKeyMan * > m_external_spk_managers
Definition: wallet.h:416
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:3566
CKeyingMaterial vMasterKey GUARDED_BY(cs_wallet)
const std::unordered_map< COutPoint, WalletTXO, SaltedOutpointHasher > & GetTXOs() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.h:525
void SetBroadcastTransactions(bool broadcast)
Set whether this wallet broadcasts transactions.
Definition: wallet.h:858
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:3893
std::optional< OutputType > m_default_change_type
Default output type for change outputs.
Definition: wallet.h:738
bool HaveCryptedKeys() const
Definition: wallet.cpp:3546
int64_t nOrderPosNext GUARDED_BY(cs_wallet)=0
LegacyDataSPKM * GetOrCreateLegacyDataSPKM()
Definition: wallet.cpp:3512
interfaces::Chain & chain() const
Interface for accessing chain state.
Definition: wallet.h:519
const std::string & GetName() const
Get a name for this wallet for logging/debugging purposes.
Definition: wallet.h:469
bool Unlock(const CKeyingMaterial &vMasterKeyIn)
Definition: wallet.cpp:3379
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:3819
bool BackupWallet(const std::string &strDest) const
Definition: wallet.cpp:3313
std::unique_ptr< interfaces::Handler > m_chain_notifications_handler
Registered interfaces::Chain::Notifications handler.
Definition: wallet.h:516
std::map< OutputType, ScriptPubKeyMan * > m_internal_spk_managers
Definition: wallet.h:417
std::string m_name
Wallet name: relative directory name or "" for default wallet.
Definition: wallet.h:395
bool SetAddressPreviouslySpent(WalletBatch &batch, const CTxDestination &dest, bool used) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2865
util::Result< void > RemoveTxs(std::vector< Txid > &txs_to_remove) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Erases the provided transactions from the wallet.
Definition: wallet.cpp:2421
double ScanningProgress() const
Definition: wallet.h:580
SteadyClock::duration ScanningDuration() const
Definition: wallet.h:579
RecursiveMutex m_relock_mutex
Definition: wallet.h:596
btcsignals::signal< void(const Txid &hashTx, ChangeType status)> NotifyTransactionChanged
Wallet transaction added, removed or updated.
Definition: wallet.h:841
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:746
std::vector< std::string > GetAddressReceiveRequests() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2895
std::vector< WalletDescriptor > GetWalletDescriptors(const CScript &script) const
Get the wallet descriptors for a script.
Definition: wallet.cpp:3480
bool fBroadcastTransactions
Whether this wallet will submit newly created transactions to the node's mempool and prompt rebroadca...
Definition: wallet.h:326
size_t KeypoolCountExternalKeys() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2570
void CacheNewScriptPubKeys(const std::set< CScript > &spks, ScriptPubKeyMan *spkm)
Add scriptPubKeys for this ScriptPubKeyMan into the scriptPubKey cache.
Definition: wallet.cpp:4491
int GetTxBlocksToMaturity(const CWalletTx &wtx) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:3333
void WalletLogPrintf(util::ConstevalFormatString< sizeof...(Params)> wallet_fmt, const Params &... params) const
Prepends the wallet name in logging output to ease debugging in multi-wallet use cases.
Definition: wallet.h:937
bool HasEncryptionKeys() const override
Definition: wallet.cpp:3541
bool CanGrindR() const
Whether the (external) signer performs R-value signature grinding.
Definition: wallet.cpp:4125
std::map< CTxDestination, CAddressBookData > m_address_book GUARDED_BY(cs_wallet)
std::string LogName() const override
Return wallet name for use in logs, will return "default wallet" if the wallet has no name.
Definition: wallet.h:922
util::Result< CTxDestination > GetNewChangeDestination(OutputType type)
Definition: wallet.cpp:2619
std::optional< bool > IsInternalScriptPubKeyMan(ScriptPubKeyMan *spk_man) const
Returns whether the provided ScriptPubKeyMan is internal.
Definition: wallet.cpp:3741
void SetNextResend()
Set the next time this wallet should resend transactions to 12-36 hours from now, ~1 day on average.
Definition: wallet.h:651
void LoadLockedCoin(const COutPoint &coin, bool persistent) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2733
TxItems wtxOrdered
Definition: wallet.h:500
std::atomic< bool > m_scanning_with_passphrase
Definition: wallet.h:317
SigningResult SignMessage(const std::string &message, const PKHash &pkhash, std::string &str_sig) const
Definition: wallet.cpp:2254
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:708
MasterKeyMap mapMasterKeys
Definition: wallet.h:472
unsigned int m_confirm_target
Definition: wallet.h:705
CFeeRate m_consolidate_feerate
When the actual feerate is less than the consolidate feerate, we will tend to make transactions which...
Definition: wallet.h:727
btcsignals::signal< void(const std::string &title, int nProgress)> ShowProgress
Show progress e.g.
Definition: wallet.h:844
util::Result< void > ApplyMigrationData(WalletBatch &local_wallet_batch, MigrationData &data) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Adds the ScriptPubKeyMans given in MigrationData to this wallet, removes LegacyScriptPubKeyMan,...
Definition: wallet.cpp:3912
NodeClock::time_point m_next_resend
The next scheduled rebroadcast of wallet transactions.
Definition: wallet.h:323
WalletDatabase & GetDatabase() const override
Definition: wallet.h:461
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:4525
bool EraseAddressReceiveRequest(WalletBatch &batch, const CTxDestination &dest, const std::string &id) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2913
bool SetAddressBookWithDB(WalletBatch &batch, const CTxDestination &address, const std::string &strName, const std::optional< AddressPurpose > &strPurpose)
Definition: wallet.cpp:2482
void WriteBestBlock() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Write the current best block to database.
Definition: wallet.cpp:4540
void AbortRescan()
Definition: wallet.h:575
bool DelAddressBookWithDB(WalletBatch &batch, const CTxDestination &address)
Definition: wallet.cpp:2531
std::string DisplayName() const
Return wallet name for display, like LogName() but translates "default wallet" string.
Definition: wallet.h:929
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:2884
Mutex m_unlock_mutex
Definition: wallet.h:594
void AddScriptPubKeyMan(const uint256 &id, std::unique_ptr< ScriptPubKeyMan > spkm_man)
Definition: wallet.cpp:3502
void DeactivateScriptPubKeyMan(uint256 id, OutputType type, bool internal)
Remove specified ScriptPubKeyMan from set of active SPK managers.
Definition: wallet.cpp:3709
std::atomic< uint64_t > m_wallet_flags
WalletFlags set on this wallet.
Definition: wallet.h:381
interfaces::Chain * m_chain
Interface for accessing chain state.
Definition: wallet.h:392
bool LockCoin(const COutPoint &output, bool persist) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2739
CFeeRate m_fallback_fee
If fee estimation does not have enough data to provide estimates, use this fee instead.
Definition: wallet.h:717
std::set< CExtPubKey > GetActiveHDPubKeys() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Retrieve the xpubs in use by the active descriptors.
Definition: wallet.cpp:4504
bool IsLocked() const override
Definition: wallet.cpp:3353
std::map< unsigned int, CMasterKey > MasterKeyMap
Definition: wallet.h:471
OutputType TransactionChangeType(const std::optional< OutputType > &change_type, const std::vector< CRecipient > &vecSend) const
Definition: wallet.cpp:2267
std::set< ScriptPubKeyMan * > GetAllScriptPubKeyMans() const
Returns all unique ScriptPubKeyMans.
Definition: wallet.cpp:3419
void RefreshTXOsFromTx(const CWalletTx &wtx) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Cache outputs that belong to the wallet from a single transaction.
Definition: wallet.cpp:4555
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:2814
TxSpends mapTxSpends GUARDED_BY(cs_wallet)
std::set< std::string > ListAddrBookLabels(std::optional< AddressPurpose > purpose) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Retrieve all the known labels in the address book.
Definition: wallet.cpp:2669
std::unordered_map< COutPoint, WalletTXO, SaltedOutpointHasher > m_txos GUARDED_BY(cs_wallet)
Set of both spent and unspent transaction outputs owned by this wallet.
void ListLockedCoins(std::vector< COutPoint > &vOutpts) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2783
bool IsAbortingRescan() const
Definition: wallet.h:576
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:2328
bool UnlockAllCoins() EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2765
util::Result< CTxDestination > GetNewDestination(OutputType type, const std::string &label)
Definition: wallet.cpp:2603
ScriptPubKeyMan * GetScriptPubKeyMan(const OutputType &type, bool internal) const
Get the ScriptPubKeyMan for the given OutputType and internal/external chain.
Definition: wallet.cpp:3428
bool IsAddressPreviouslySpent(const CTxDestination &dest) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2889
bool WithEncryptionKey(std::function< bool(const CKeyingMaterial &)> cb) const override
Pass the encryption key to cb().
Definition: wallet.cpp:3535
uint256 GetLastBlockHash() const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.h:991
bool m_allow_fallback_fee
will be false if -fallbackfee=0
Definition: wallet.h:710
int64_t m_keypool_size
Number of pre-generated keys/scripts by each spkm (part of the look-ahead process,...
Definition: wallet.h:743
RecursiveMutex cs_wallet
Main wallet lock.
Definition: wallet.h:459
void ForEachAddrBookEntry(const ListAddrBookFunc &func) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2644
void ConnectScriptPubKeyManNotifiers()
Connect the signals from ScriptPubKeyMans to the signals in CWallet.
Definition: wallet.cpp:3554
static std::shared_ptr< CWallet > CreateNew(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:3075
bool DelAddressBook(const CTxDestination &address)
Definition: wallet.cpp:2524
CFeeRate m_min_fee
Definition: wallet.h:711
std::atomic< int64_t > m_best_block_time
Definition: wallet.h:328
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:434
void SetupLegacyScriptPubKeyMan()
Make a Legacy(Data)SPKM and set it for all types, internal, and external.
Definition: wallet.cpp:3518
std::multimap< int64_t, CWalletTx * > TxItems
Definition: wallet.h:499
std::unordered_map< Txid, CWalletTx, SaltedTxidHasher > mapWallet GUARDED_BY(cs_wallet)
Map from txid to CWalletTx for all transactions this wallet is interested in, including received and ...
void SetupOwnDescriptorScriptPubKeyMans(WalletBatch &batch) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Create new seed and default DescriptorScriptPubKeyMans for this wallet.
Definition: wallet.cpp:3608
void SetupDescriptorScriptPubKeyMans() EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:3624
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:3578
std::map< uint256, std::unique_ptr< ScriptPubKeyMan > > m_spk_managers
Definition: wallet.h:421
std::function< TxUpdate(CWalletTx &wtx)> TryUpdatingStateFn
Definition: wallet.h:367
bool UnlockCoin(const COutPoint &output) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2750
std::atomic< int64_t > m_birth_time
Definition: wallet.h:332
void LoadAddressPreviouslySpent(const CTxDestination &dest) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Marks destination as previously spent.
Definition: wallet.cpp:2879
util::Result< std::reference_wrapper< DescriptorScriptPubKeyMan > > 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:3760
static bool LoadWalletArgs(std::shared_ptr< CWallet > wallet, const WalletContext &context, bilingual_str &error, std::vector< bilingual_str > &warnings)
Definition: wallet.cpp:2953
std::atomic< bool > fScanningWallet
Definition: wallet.h:316
std::set< ScriptPubKeyMan * > GetScriptPubKeyMans(const CScript &script) const
Get all the ScriptPubKeyMans for a script.
Definition: wallet.cpp:3438
util::Result< void > DisplayAddress(const CTxDestination &dest) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Display address on an external signer.
Definition: wallet.cpp:2718
bool IsScanningWithPassphrase() const
Definition: wallet.h:578
std::unordered_multimap< COutPoint, Txid, SaltedOutpointHasher > TxSpends
Used to keep track of spent outpoints, and detect and report conflicts (double-spends or mutated tran...
Definition: wallet.h:339
A transaction with a bunch of additional info that only the owner cares about.
Definition: transaction.h:195
A wrapper to reserve an address from a wallet.
Definition: wallet.h:197
const CWallet *const pwallet
The wallet to reserve from.
Definition: wallet.h:200
void KeepDestination()
Keep the address. Do not return its key to the keypool when this object goes out of scope.
Definition: wallet.cpp:2700
CTxDestination address
The destination.
Definition: wallet.h:207
bool fInternal
Whether this is from the internal (change output) keypool.
Definition: wallet.h:209
~ReserveDestination()
Destructor. If a key has been reserved and not KeepKey'ed, it will be returned to the keypool.
Definition: wallet.h:221
ReserveDestination(CWallet *pwallet, OutputType type)
Construct a ReserveDestination object. This does NOT reserve an address yet.
Definition: wallet.h:213
void ReturnDestination()
Return reserved address.
Definition: wallet.cpp:2709
ScriptPubKeyMan * m_spk_man
The ScriptPubKeyMan to reserve from. Based on type when GetReservedDestination is called.
Definition: wallet.h:202
ReserveDestination & operator=(const ReserveDestination &)=delete
int64_t nIndex
The index of the address's key in the keypool.
Definition: wallet.h:205
OutputType const type
Definition: wallet.h:203
util::Result< CTxDestination > GetReservedDestination(bool internal)
Reserve an address.
Definition: wallet.cpp:2683
ReserveDestination(const ReserveDestination &)=delete
Access to the wallet database.
Definition: walletdb.h:192
An instance of this class represents one database.
Definition: db.h:130
Descriptor with some wallet metadata.
Definition: walletutil.h:64
RAII object to check and reserve a wallet rescan.
Definition: wallet.h:1087
std::function< Clock::time_point()> NowFn
Definition: wallet.h:1090
std::chrono::steady_clock Clock
Definition: wallet.h:1089
WalletRescanReserver(CWallet &w)
Definition: wallet.h:1095
Clock::time_point now() const
Definition: wallet.h:1115
void setNow(NowFn now)
Definition: wallet.h:1117
bool reserve(bool with_passphrase=false)
Definition: wallet.h:1097
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate.
Definition: cs_main.cpp:8
bool IsSpentKey(const CScript &scriptPubKey) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:1022
int64_t IncOrderPosNext(WalletBatch *batch=nullptr) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Increment the next transaction order id.
Definition: wallet.cpp:950
void RecursiveUpdateTxState(const Txid &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:1372
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:1294
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:722
bool ChangeWalletPassphrase(const SecureString &strOldWalletPassphrase, const SecureString &strNewWalletPassphrase)
Definition: wallet.cpp:651
bool AbandonTransaction(const Txid &hashTx)
Definition: wallet.cpp:1304
void SyncMetaData(std::pair< TxSpends::iterator, TxSpends::iterator >) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:739
void SetWalletFlagWithDB(WalletBatch &batch, uint64_t flags)
Store wallet flags.
Definition: wallet.cpp:1746
uint64_t GetWalletFlags() const
Retrieve all of the wallet's flags.
Definition: wallet.cpp:1806
void updatedBlockTip() override
Definition: wallet.cpp:1616
bool TransactionCanBeAbandoned(const Txid &hashTx) const
Return whether transaction can be abandoned.
Definition: wallet.cpp:1270
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:1740
void MaybeUpdateBirthTime(int64_t time)
Updates wallet birth time if 'time' is below it.
Definition: wallet.cpp:1811
void blockDisconnected(const interfaces::BlockInfo &block) override
Definition: wallet.cpp:1569
ScanResult ScanForWalletTransactions(const uint256 &start_block, int start_height, std::optional< int > max_height, const WalletRescanReserver &reserver, bool fUpdate, bool save_progress)
Scan the block chain (starting in start_block) for transactions from or to us.
Definition: wallet.cpp:1871
std::set< Txid > GetConflicts(const Txid &txid) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Get wallet transactions that conflict with given transaction (spend same outputs)
Definition: wallet.cpp:699
bool IsWalletFlagSet(uint64_t flag) const override
check if a certain wallet flag is set
Definition: wallet.cpp:1773
void AddToSpends(const COutPoint &outpoint, const Txid &txid) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:797
void SetLastBlockProcessedInMem(int block_height, uint256 block_hash) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:683
void UnsetWalletFlagWithDB(WalletBatch &batch, uint64_t flag)
Unsets a wallet flag and saves it to disk.
Definition: wallet.cpp:1760
bool IsSpent(const COutPoint &outpoint) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Outpoint is spent if any non-conflicted transaction spends it:
Definition: wallet.cpp:780
void ResubmitWalletTransactions(node::TxBroadcast broadcast_method, bool force)
Definition: wallet.cpp:2119
std::set< Txid > GetTxConflicts(const CWalletTx &wtx) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:2065
void UnsetBlankWalletFlag(WalletBatch &batch) override
Unset the blank wallet flag and saves it to disk.
Definition: wallet.cpp:1768
CWalletTx * AddToWallet(CTransactionRef tx, const TxState &state, const UpdateWalletTxFn &update_wtx=nullptr, bool rescanning_old_block=false)
Add the transaction to the wallet, wrapping it up inside a CWalletTx.
Definition: wallet.cpp:1035
bool MarkReplaced(const Txid &originalHash, const Txid &newHash)
Mark a transaction as replaced by another transaction.
Definition: wallet.cpp:971
bool CanGetAddresses(bool internal=false) const
Definition: wallet.cpp:1727
void MarkDirty()
Definition: wallet.cpp:962
void UpdateTrucSiblingConflicts(const CWalletTx &parent_wtx, const Txid &child_txid, bool add_conflict) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Update mempool conflicts for TRUC sibling transactions.
Definition: wallet.cpp:1277
bool LoadWalletFlags(uint64_t flags)
Loads the flags into the wallet.
Definition: wallet.cpp:1778
bool IsHDEnabled() const
Definition: wallet.cpp:1716
bool SubmitTxMemoryPoolAndRelay(CWalletTx &wtx, std::string &err_string, node::TxBroadcast broadcast_method) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Pass this transaction to node for optional mempool insertion and relay to peers.
Definition: wallet.cpp:2022
void blockConnected(const kernel::ChainstateRole &role, const interfaces::BlockInfo &block) override
Definition: wallet.cpp:1540
void transactionRemovedFromMempool(const CTransactionRef &tx, MemPoolRemovalReason reason) override
Definition: wallet.cpp:1471
static NodeClock::time_point GetDefaultNextResend()
Definition: wallet.cpp:2092
bool ShouldResend() const
Return true if all conditions for periodically resending transactions are met.
Definition: wallet.cpp:2075
const CWalletTx * GetWalletTx(const Txid &hash) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:556
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:1790
bool SyncTransaction(const CTransactionRef &tx, const SyncTxState &state, bool update_tx=true, bool rescanning_old_block=false) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:1416
void UnsetWalletFlag(uint64_t flag)
Unsets a single wallet flag.
Definition: wallet.cpp:1754
bool EncryptWallet(const SecureString &strWalletPassphrase)
Definition: wallet.cpp:818
void SetLastBlockProcessed(int block_height, uint256 block_hash) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Set last block processed height, and write to database.
Definition: wallet.cpp:691
bool LoadToWallet(const Txid &hash, const UpdateWalletTxFn &fill_wtx) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:1170
int64_t RescanFromTime(int64_t startTime, const WalletRescanReserver &reserver, bool update)
Scan active chain for relevant transactions after importing keys.
Definition: wallet.cpp:1827
bool IsFromMe(const CTransaction &tx) const
should probably be renamed to IsRelevantToMe
Definition: wallet.cpp:1695
DBErrors ReorderTransactions()
Definition: wallet.cpp:893
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:1204
bool IsMine(const CTxDestination &dest) const EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:1649
void UpgradeDescriptorCache() EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Upgrade DescriptorCaches.
Definition: wallet.cpp:565
void SetSpentKeyState(WalletBatch &batch, const Txid &hash, unsigned int n, bool used, std::set< CTxDestination > &tx_destinations) EXCLUSIVE_LOCKS_REQUIRED(cs_wallet)
Definition: wallet.cpp:1003
CAmount GetDebit(const CTxIn &txin) const
Returns amount of debit, i.e.
Definition: wallet.cpp:1633
void MarkConflicted(const uint256 &hashBlock, int conflicting_height, const Txid &hashTx)
Mark a transaction (and its in-wallet descendants) as conflicting with a particular block.
Definition: wallet.cpp:1342
void transactionAddedToMempool(const CTransactionRef &tx) override
Definition: wallet.cpp:1428
void Close()
Close wallet database.
Definition: wallet.cpp:734
#define LogInfo(...)
Definition: log.h:97
MemPoolRemovalReason
Reason why a transaction was removed from the mempool, this is passed to the notification signal.
static int sign(const secp256k1_context *ctx, struct signer_secrets *signer_secrets, struct signer *signer, const secp256k1_musig_keyagg_cache *cache, const unsigned char *msg32, unsigned char *sig64)
Definition: musig.c:106
btcsignals is a simple mechanism for signaling events to multiple subscribers.
Definition: btcsignals.h:31
Definition: init.cpp:17
PSBTError
Definition: types.h:17
TxBroadcast
How to broadcast a local transaction.
Definition: types.h:165
Definition: common.h:30
void format(std::ostream &out, FormatStringCheck< sizeof...(Args)> fmt, const Args &... args)
Format list of arguments to the stream according to given format string.
Definition: tinyformat.h:1079
static constexpr size_t DUMMY_NESTED_P2WPKH_INPUT_SIZE
Pre-calculated constants for input size estimation in virtual size
Definition: wallet.h:142
constexpr CAmount HIGH_APS_FEE
discourage APS fee higher than this amount
Definition: wallet.h:121
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:364
static const CAmount DEFAULT_FALLBACK_FEE
-fallbackfee default
Definition: wallet.h:105
void MaybeResendWalletTxs(WalletContext &context)
Called periodically by the schedule thread.
Definition: wallet.cpp:2156
std::variant< TxStateConfirmed, TxStateInMempool, TxStateInactive > SyncTxState
Subset of states transaction sync logic is implemented to handle.
Definition: transaction.h:82
std::vector< std::shared_ptr< CWallet > > GetWallets(WalletContext &context)
Definition: wallet.cpp:194
constexpr CAmount DEFAULT_TRANSACTION_MAXFEE
-maxtxfee default
Definition: wallet.h:136
std::variant< TxStateConfirmed, TxStateInMempool, TxStateBlockConflicted, TxStateInactive, TxStateUnrecognized > TxState
All possible CWalletTx states.
Definition: transaction.h:79
std::map< std::string, std::string > mapValue_t
Definition: transaction.h:167
std::vector< unsigned char, secure_allocator< unsigned char > > CKeyingMaterial
Definition: crypter.h:63
static const CAmount DEFAULT_DISCARD_FEE
-discardfee default
Definition: wallet.h:107
DBErrors
Overview of wallet database classes:
Definition: walletdb.h:44
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:96
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:109
static const bool DEFAULT_WALLETCROSSCHAIN
Definition: wallet.h:134
std::unique_ptr< interfaces::Handler > HandleLoadWallet(WalletContext &context, LoadWalletFn load_wallet)
Definition: wallet.cpp:216
static const CAmount DEFAULT_TRANSACTION_MINFEE
-mintxfee default
Definition: wallet.h:109
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:4256
static const bool DEFAULT_WALLET_RBF
-walletrbf default
Definition: wallet.h:131
constexpr CAmount HIGH_TX_FEE_PER_KB
Discourage users to set fees higher than this amount (in satoshis) per kB.
Definition: wallet.h:138
constexpr OutputType DEFAULT_ADDRESS_TYPE
Default for -addresstype.
Definition: wallet.h:147
std::unique_ptr< WalletDatabase > MakeWalletDatabase(const std::string &name, const DatabaseOptions &options, DatabaseStatus &status, bilingual_str &error_string)
Definition: wallet.cpp:2942
void NotifyWalletLoaded(WalletContext &context, const std::shared_ptr< CWallet > &wallet)
Definition: wallet.cpp:223
constexpr CAmount HIGH_MAX_TX_FEE
-maxtxfee will warn if called with a higher fee than this amount (in satoshis)
Definition: wallet.h:140
static const bool DEFAULT_DISABLE_WALLET
Definition: wallet.h:133
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:119
static const unsigned int DEFAULT_TX_CONFIRM_TARGET
-txconfirmtarget default
Definition: wallet.h:129
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, bool load_after_restore, bool allow_unnamed)
Definition: wallet.cpp:472
std::string PurposeToString(AddressPurpose p)
Definition: wallet.h:279
AddressPurpose
Address purpose field that has been been stored with wallet sending and receiving addresses since BIP...
Definition: types.h:28
@ REFUND
Never set in current code may be present in older wallet databases.
static const bool DEFAULT_WALLETBROADCAST
Definition: wallet.h:132
bool AddWallet(WalletContext &context, const std::shared_ptr< CWallet > &wallet)
Definition: wallet.cpp:151
static const CAmount WALLET_INCREMENTAL_RELAY_FEE
minimum recommended increment for replacement txs
Definition: wallet.h:123
static constexpr uint64_t KNOWN_WALLET_FLAGS
Definition: wallet.h:149
static const CAmount DEFAULT_CONSOLIDATE_FEERATE
-consolidatefeerate default
Definition: wallet.h:111
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:377
@ WALLET_FLAG_EXTERNAL_SIGNER
Indicates that the wallet needs an external signer.
Definition: walletutil.h:56
@ WALLET_FLAG_LAST_HARDENED_XPUB_CACHED
Definition: walletutil.h:27
@ WALLET_FLAG_KEY_ORIGIN_METADATA
Definition: walletutil.h:24
@ WALLET_FLAG_AVOID_REUSE
Definition: walletutil.h:21
@ WALLET_FLAG_DESCRIPTORS
Indicate that this wallet supports DescriptorScriptPubKeyMan.
Definition: walletutil.h:53
@ WALLET_FLAG_DISABLE_PRIVATE_KEYS
Definition: walletutil.h:30
@ WALLET_FLAG_BLANK_WALLET
Flag set when a wallet contains no HD seed and no private keys, scripts, addresses,...
Definition: walletutil.h:50
std::optional< AddressPurpose > PurposeFromString(std::string_view s)
Definition: wallet.h:289
void WaitForDeleteWallet(std::shared_ptr< CWallet > &&wallet)
Explicitly delete the wallet.
Definition: wallet.cpp:254
static const std::map< std::string, WalletFlags > STRING_TO_WALLET_FLAG
Definition: wallet.h:171
static constexpr uint64_t MUTABLE_WALLET_FLAGS
Definition: wallet.h:158
std::shared_ptr< CWallet > GetWallet(WalletContext &context, const std::string &name)
Definition: wallet.cpp:207
static const bool DEFAULT_SPEND_ZEROCONF_CHANGE
Default for -spendzeroconfchange.
Definition: wallet.h:125
static const std::map< WalletFlags, std::string > WALLET_FLAG_TO_STRING
Definition: wallet.h:161
static const bool DEFAULT_WALLET_REJECT_LONG_CHAINS
Default for -walletrejectlongchains.
Definition: wallet.h:127
DatabaseStatus
Definition: db.h:186
bool RemoveWallet(WalletContext &context, const std::shared_ptr< CWallet > &wallet, std::optional< bool > load_on_start, std::vector< bilingual_str > &warnings)
Definition: wallet.cpp:163
std::shared_ptr< CWallet > GetDefaultWallet(WalletContext &context, size_t &count)
Definition: wallet.cpp:200
is a home for public enum and struct type definitions that are used internally by node code,...
OutputType
Definition: outputtype.h:18
std::shared_ptr< const CTransaction > CTransactionRef
Definition: transaction.h:403
const char * name
Definition: rest.cpp:49
std::basic_string< char, std::char_traits< char >, secure_allocator< char > > SecureString
Definition: secure.h:53
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:117
Definition: key.h:231
A mutable version of CTransaction.
Definition: transaction.h:358
std::chrono::time_point< NodeClock > time_point
Definition: time.h:28
A version of CTransaction with the PSBT format.
Definition: psbt.h:1139
Bilingual messages:
Definition: translation.h:24
A wrapper for a compile-time partially validated format string.
Definition: string.h:94
Address book data.
Definition: wallet.h:238
std::optional< AddressPurpose > purpose
Address purpose which was originally recorded for payment protocol support but now serves as a cached...
Definition: wallet.h:253
void SetLabel(std::string name)
Definition: wallet.h:276
std::string GetLabel() const
Definition: wallet.h:275
bool previously_spent
Whether coins with this address have previously been spent.
Definition: wallet.h:262
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:271
std::optional< std::string > label
Address label which is always nullopt for change addresses.
Definition: wallet.h:246
bool IsChange() const
Accessor methods.
Definition: wallet.h:274
CAmount nAmount
Definition: wallet.h:300
bool fSubtractFeeFromAmount
Definition: wallet.h:301
CTxDestination dest
Definition: wallet.h:299
std::optional< int > last_scanned_height
Definition: wallet.h:640
uint256 last_scanned_block
Hash and height of most recent block that was successfully scanned.
Definition: wallet.h:639
uint256 last_failed_block
Height of the most recent block that could not be scanned due to read errors or pruning.
Definition: wallet.h:646
struct containing information needed for migrating legacy wallets to descriptor wallets
std::shared_ptr< CWallet > watchonly_wallet
Definition: wallet.h:1137
std::string wallet_name
Definition: wallet.h:1135
std::shared_ptr< CWallet > solvables_wallet
Definition: wallet.h:1138
std::shared_ptr< CWallet > wallet
Definition: wallet.h:1136
WalletContext struct containing references to state shared between CWallet instances,...
Definition: context.h:36
static int count
#define EXCLUSIVE_LOCKS_REQUIRED(...)
Definition: threadsafety.h:49
#define LOCKS_EXCLUDED(...)
Definition: threadsafety.h:48
consteval auto _(util::TranslatedLiteral str)
Definition: translation.h:79
ChangeType
General change type (added, updated, removed).
Definition: ui_change_type.h:9
AssertLockHeld(pool.cs)
assert(!tx.IsCoinBase())
std::shared_ptr< CWallet > m_wallet
Definition: interfaces.cpp:525
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:80