![]() |
Bitcoin Core
24.99.0
P2P Digital Currency
|
#include <scriptpubkeyman.h>
Public Member Functions | |
LegacyScriptPubKeyMan (WalletStorage &storage, int64_t keypool_size) | |
util::Result< CTxDestination > | GetNewDestination (const OutputType type) override |
isminetype | IsMine (const CScript &script) const override |
bool | CheckDecryptionKey (const CKeyingMaterial &master_key, bool accept_no_keys=false) override |
Check that the given decryption key is valid for this ScriptPubKeyMan, i.e. it decrypts all of the keys handled by it. More... | |
bool | Encrypt (const CKeyingMaterial &master_key, WalletBatch *batch) override |
util::Result< CTxDestination > | GetReservedDestination (const OutputType type, bool internal, int64_t &index, CKeyPool &keypool) override |
void | KeepDestination (int64_t index, const OutputType &type) override |
void | ReturnDestination (int64_t index, bool internal, const CTxDestination &) override |
bool | TopUp (unsigned int size=0) override |
Fills internal address pool. More... | |
std::vector< WalletDestination > | MarkUnusedAddresses (const CScript &script) override |
Mark unused addresses as being used Affects all keys up to and including the one determined by provided script. More... | |
void | UpgradeKeyMetadata () |
Upgrade stored CKeyMetadata objects to store key origin info as KeyOriginInfo. More... | |
bool | IsHDEnabled () const override |
bool | SetupGeneration (bool force=false) override |
Sets up the key generation stuff, i.e. More... | |
bool | Upgrade (int prev_version, int new_version, bilingual_str &error) override |
Upgrades the wallet to the specified version. More... | |
bool | HavePrivateKeys () const override |
void | RewriteDB () override |
The action to do when the DB needs rewrite. More... | |
std::optional< int64_t > | GetOldestKeyPoolTime () const override |
size_t | KeypoolCountExternalKeys () const |
unsigned int | GetKeyPoolSize () const override |
int64_t | GetTimeFirstKey () const override |
std::unique_ptr< CKeyMetadata > | GetMetadata (const CTxDestination &dest) const override |
bool | CanGetAddresses (bool internal=false) const override |
std::unique_ptr< SigningProvider > | GetSolvingProvider (const CScript &script) const override |
bool | CanProvide (const CScript &script, SignatureData &sigdata) override |
Whether this ScriptPubKeyMan can provide a SigningProvider (via GetSolvingProvider) that, combined with sigdata, can produce solving data. More... | |
bool | SignTransaction (CMutableTransaction &tx, const std::map< COutPoint, Coin > &coins, int sighash, std::map< int, bilingual_str > &input_errors) const override |
Creates new signatures and adds them to the transaction. More... | |
SigningResult | SignMessage (const std::string &message, const PKHash &pkhash, std::string &str_sig) const override |
Sign a message with the given script. More... | |
TransactionError | FillPSBT (PartiallySignedTransaction &psbt, const PrecomputedTransactionData &txdata, int sighash_type=SIGHASH_DEFAULT, bool sign=true, bool bip32derivs=false, int *n_signed=nullptr, bool finalize=true) const override |
Adds script and derivation path information to a PSBT, and optionally signs it. More... | |
uint256 | GetID () const override |
std::map< CKeyID, CKeyMetadata > mapKeyMetadata | GUARDED_BY (cs_KeyStore) |
std::map< CScriptID, CKeyMetadata > m_script_metadata | GUARDED_BY (cs_KeyStore) |
bool | AddKeyPubKey (const CKey &key, const CPubKey &pubkey) override |
Adds a key to the store, and saves it to disk. More... | |
bool | LoadKey (const CKey &key, const CPubKey &pubkey) |
Adds a key to the store, without saving it to disk (used by LoadWallet) More... | |
bool | AddCryptedKey (const CPubKey &vchPubKey, const std::vector< unsigned char > &vchCryptedSecret) |
Adds an encrypted key to the store, and saves it to disk. More... | |
bool | LoadCryptedKey (const CPubKey &vchPubKey, const std::vector< unsigned char > &vchCryptedSecret, bool checksum_valid) |
Adds an encrypted key to the store, without saving it to disk (used by LoadWallet) More... | |
void | UpdateTimeFirstKey (int64_t nCreateTime) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
Update wallet first key creation time. More... | |
bool | LoadCScript (const CScript &redeemScript) |
Adds a CScript to the store. More... | |
void | LoadKeyMetadata (const CKeyID &keyID, const CKeyMetadata &metadata) |
Load metadata (used by LoadWallet) More... | |
void | LoadScriptMetadata (const CScriptID &script_id, const CKeyMetadata &metadata) |
CPubKey | GenerateNewKey (WalletBatch &batch, CHDChain &hd_chain, bool internal=false) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
Generate a new key. More... | |
void | AddHDChain (const CHDChain &chain) |
void | LoadHDChain (const CHDChain &chain) |
Load a HD chain model (used by LoadWallet) More... | |
const CHDChain & | GetHDChain () const |
void | AddInactiveHDChain (const CHDChain &chain) |
bool | LoadWatchOnly (const CScript &dest) |
Adds a watch-only address to the store, without saving it to disk (used by LoadWallet) More... | |
bool | HaveWatchOnly (const CScript &dest) const |
Returns whether the watch-only script is in the wallet. More... | |
bool | HaveWatchOnly () const |
Returns whether there are any watch-only things in the wallet. More... | |
bool | RemoveWatchOnly (const CScript &dest) |
Remove a watch only script from the keystore. More... | |
bool | AddWatchOnly (const CScript &dest, int64_t nCreateTime) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
bool | GetWatchPubKey (const CKeyID &address, CPubKey &pubkey_out) const |
Fetches a pubkey from mapWatchKeys if it exists there. More... | |
bool | HaveKey (const CKeyID &address) const override |
bool | GetKey (const CKeyID &address, CKey &keyOut) const override |
bool | GetPubKey (const CKeyID &address, CPubKey &vchPubKeyOut) const override |
bool | AddCScript (const CScript &redeemScript) override |
bool | GetKeyOrigin (const CKeyID &keyid, KeyOriginInfo &info) const override |
void | LoadKeyPool (int64_t nIndex, const CKeyPool &keypool) |
Load a keypool entry. More... | |
bool | NewKeyPool () |
Mark old keypool keys as used, and generate all new keys. More... | |
void | MarkPreSplitKeys () EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
bool | ImportScripts (const std::set< CScript > scripts, int64_t timestamp) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
bool | ImportPrivKeys (const std::map< CKeyID, CKey > &privkey_map, const int64_t timestamp) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
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_KeyStore) |
bool | ImportScriptPubKeys (const std::set< CScript > &script_pub_keys, const bool have_solving_data, const int64_t timestamp) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
bool | CanGenerateKeys () const |
CPubKey | GenerateNewSeed () |
CPubKey | DeriveNewSeed (const CKey &key) |
void | SetHDSeed (const CPubKey &key) |
void | LearnRelatedScripts (const CPubKey &key, OutputType) |
Explicitly make the wallet learn the related scripts for outputs to the given key. More... | |
void | LearnAllRelatedScripts (const CPubKey &key) |
Same as LearnRelatedScripts, but when the OutputType is not known (and could be anything). More... | |
std::vector< CKeyPool > | MarkReserveKeysAsUsed (int64_t keypool_id) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
Marks all keys in the keypool up to and including the provided key as used. More... | |
const std::map< CKeyID, int64_t > & | GetAllReserveKeys () const |
std::set< CKeyID > | GetKeys () const override |
std::unordered_set< CScript, SaltedSipHasher > | GetScriptPubKeys () const override |
Returns a set of all the scriptPubKeys that this ScriptPubKeyMan watches. More... | |
std::optional< MigrationData > | MigrateToDescriptor () |
Get the DescriptorScriptPubKeyMans (with private keys) that have the same scriptPubKeys as this LegacyScriptPubKeyMan. More... | |
bool | DeleteRecords () |
Delete all the records ofthis LegacyScriptPubKeyMan from disk. More... | |
![]() | |
ScriptPubKeyMan (WalletStorage &storage) | |
virtual | ~ScriptPubKeyMan () |
template<typename... Params> | |
void | WalletLogPrintf (std::string fmt, Params... parameters) const |
Prepends the wallet name in logging output to ease debugging in multi-wallet use cases. More... | |
![]() | |
virtual bool | AddKey (const CKey &key) |
virtual bool | HaveCScript (const CScriptID &hash) const override |
virtual std::set< CScriptID > | GetCScripts () const |
virtual bool | GetCScript (const CScriptID &hash, CScript &redeemScriptOut) const override |
![]() | |
virtual | ~SigningProvider () |
virtual bool | GetTaprootSpendData (const XOnlyPubKey &output_key, TaprootSpendData &spenddata) const |
virtual bool | GetTaprootBuilder (const XOnlyPubKey &output_key, TaprootBuilder &builder) const |
bool | GetKeyByXOnly (const XOnlyPubKey &pubkey, CKey &key) const |
bool | GetPubKeyByXOnly (const XOnlyPubKey &pubkey, CPubKey &out) const |
bool | GetKeyOriginByXOnly (const XOnlyPubKey &pubkey, KeyOriginInfo &info) const |
Private Types | |
using | WatchOnlySet = std::set< CScript > |
using | WatchKeyMap = std::map< CKeyID, CPubKey > |
using | CryptedKeyMap = std::map< CKeyID, std::pair< CPubKey, std::vector< unsigned char > >> |
Private Member Functions | |
WalletBatch *encrypted_batch | GUARDED_BY (cs_KeyStore) |
CryptedKeyMap mapCryptedKeys | GUARDED_BY (cs_KeyStore) |
WatchOnlySet setWatchOnly | GUARDED_BY (cs_KeyStore) |
WatchKeyMap mapWatchKeys | GUARDED_BY (cs_KeyStore) |
int64_t nTimeFirstKey | GUARDED_BY (cs_KeyStore)=0 |
int64_t m_keypool_size | GUARDED_BY (cs_KeyStore) |
Number of pre-generated keys/scripts (part of the look-ahead process, used to detect payments) More... | |
bool | AddKeyPubKeyInner (const CKey &key, const CPubKey &pubkey) |
bool | AddCryptedKeyInner (const CPubKey &vchPubKey, const std::vector< unsigned char > &vchCryptedSecret) |
bool | AddWatchOnly (const CScript &dest) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
Private version of AddWatchOnly method which does not accept a timestamp, and which will reset the wallet's nTimeFirstKey value to 1 if the watch key did not previously have a timestamp associated with it. More... | |
bool | AddWatchOnlyWithDB (WalletBatch &batch, const CScript &dest) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
bool | AddWatchOnlyInMem (const CScript &dest) |
bool | AddWatchOnlyWithDB (WalletBatch &batch, const CScript &dest, int64_t create_time) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
Adds a watch-only address to the store, and saves it to disk. More... | |
bool | AddKeyPubKeyWithDB (WalletBatch &batch, const CKey &key, const CPubKey &pubkey) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
Adds a key to the store, and saves it to disk. More... | |
void | AddKeypoolPubkeyWithDB (const CPubKey &pubkey, const bool internal, WalletBatch &batch) |
bool | AddCScriptWithDB (WalletBatch &batch, const CScript &script) |
Adds a script to the store and saves it to disk. More... | |
bool | AddKeyOriginWithDB (WalletBatch &batch, const CPubKey &pubkey, const KeyOriginInfo &info) |
Add a KeyOriginInfo to the wallet. More... | |
void | DeriveNewChildKey (WalletBatch &batch, CKeyMetadata &metadata, CKey &secret, CHDChain &hd_chain, bool internal=false) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
std::set< int64_t > setInternalKeyPool | GUARDED_BY (cs_KeyStore) |
std::set< int64_t > setExternalKeyPool | GUARDED_BY (cs_KeyStore) |
std::set< int64_t > set_pre_split_keypool | GUARDED_BY (cs_KeyStore) |
int64_t m_max_keypool_index | GUARDED_BY (cs_KeyStore)=0 |
bool | GetKeyFromPool (CPubKey &key, const OutputType type, bool internal=false) |
Fetches a key from the keypool. More... | |
bool | ReserveKeyFromKeyPool (int64_t &nIndex, CKeyPool &keypool, bool fRequestedInternal) |
Reserves a key from the keypool and sets nIndex to its index. More... | |
bool | TopUpInactiveHDChain (const CKeyID seed_id, int64_t index, bool internal) |
Like TopUp() but adds keys for inactive HD chains. More... | |
bool | TopUpChain (CHDChain &chain, unsigned int size) |
Private Attributes | |
bool | fDecryptionThoroughlyChecked = true |
keeps track of whether Unlock has run a thorough check before More... | |
CHDChain | m_hd_chain |
std::unordered_map< CKeyID, CHDChain, SaltedSipHasher > | m_inactive_hd_chains |
std::map< CKeyID, int64_t > | m_pool_key_to_index |
std::map< int64_t, CKeyID > | m_index_to_reserved_key |
Additional Inherited Members | |
![]() | |
boost::signals2::signal< void(bool fHaveWatchOnly)> | NotifyWatchonlyChanged |
Watch-only address added. More... | |
boost::signals2::signal< void()> | NotifyCanGetAddressesChanged |
Keypool has new keys. More... | |
![]() | |
RecursiveMutex | cs_KeyStore |
![]() | |
using | KeyMap = std::map< CKeyID, CKey > |
using | ScriptMap = std::map< CScriptID, CScript > |
![]() | |
KeyMap mapKeys | GUARDED_BY (cs_KeyStore) |
Map of key id to unencrypted private keys known by the signing provider. More... | |
ScriptMap mapScripts | GUARDED_BY (cs_KeyStore) |
Map of script id to scripts known by the signing provider. More... | |
void | ImplicitlyLearnRelatedKeyScripts (const CPubKey &pubkey) EXCLUSIVE_LOCKS_REQUIRED(cs_KeyStore) |
![]() | |
WalletStorage & | m_storage |
Definition at line 270 of file scriptpubkeyman.h.
|
private |
Definition at line 281 of file scriptpubkeyman.h.
|
private |
Definition at line 277 of file scriptpubkeyman.h.
|
private |
Definition at line 276 of file scriptpubkeyman.h.
|
inline |
Definition at line 369 of file scriptpubkeyman.h.
bool wallet::LegacyScriptPubKeyMan::AddCryptedKey | ( | const CPubKey & | vchPubKey, |
const std::vector< unsigned char > & | vchCryptedSecret | ||
) |
Adds an encrypted key to the store, and saves it to disk.
Definition at line 839 of file scriptpubkeyman.cpp.
|
private |
Definition at line 829 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from FillableSigningProvider.
Definition at line 1535 of file scriptpubkeyman.cpp.
|
private |
Adds a script to the store and saves it to disk.
Definition at line 1541 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::AddHDChain | ( | const CHDChain & | chain | ) |
Definition at line 952 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::AddInactiveHDChain | ( | const CHDChain & | chain | ) |
Definition at line 967 of file scriptpubkeyman.cpp.
|
private |
Add a KeyOriginInfo to the wallet.
Definition at line 1552 of file scriptpubkeyman.cpp.
|
private |
Definition at line 1338 of file scriptpubkeyman.cpp.
|
overridevirtual |
Adds a key to the store, and saves it to disk.
Reimplemented from FillableSigningProvider.
Definition at line 720 of file scriptpubkeyman.cpp.
|
private |
Definition at line 796 of file scriptpubkeyman.cpp.
|
private |
Adds a key to the store, and saves it to disk.
Definition at line 727 of file scriptpubkeyman.cpp.
|
private |
Private version of AddWatchOnly method which does not accept a timestamp, and which will reset the wallet's nTimeFirstKey value to 1 if the watch key did not previously have a timestamp associated with it.
Because this is an inherited virtual method, it is accessible despite being marked private, but it is marked private anyway to encourage use of the other AddWatchOnly which accepts a timestamp and sets nTimeFirstKey more intelligently for more efficient rescans.
Definition at line 934 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::AddWatchOnly | ( | const CScript & | dest, |
int64_t | nCreateTime | ||
) |
|
private |
Definition at line 902 of file scriptpubkeyman.cpp.
|
private |
Definition at line 914 of file scriptpubkeyman.cpp.
|
private |
Adds a watch-only address to the store, and saves it to disk.
Definition at line 928 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::CanGenerateKeys | ( | ) | const |
Definition at line 1171 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 448 of file scriptpubkeyman.cpp.
|
overridevirtual |
Whether this ScriptPubKeyMan can provide a SigningProvider (via GetSolvingProvider) that, combined with sigdata, can produce solving data.
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 584 of file scriptpubkeyman.cpp.
|
overridevirtual |
Check that the given decryption key is valid for this ScriptPubKeyMan, i.e. it decrypts all of the keys handled by it.
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 226 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::DeleteRecords | ( | ) |
Delete all the records ofthis LegacyScriptPubKeyMan from disk.
Definition at line 1972 of file scriptpubkeyman.cpp.
|
private |
Definition at line 1095 of file scriptpubkeyman.cpp.
Definition at line 1186 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 266 of file scriptpubkeyman.cpp.
|
overridevirtual |
Adds script and derivation path information to a PSBT, and optionally signs it.
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 625 of file scriptpubkeyman.cpp.
CPubKey wallet::LegacyScriptPubKeyMan::GenerateNewKey | ( | WalletBatch & | batch, |
CHDChain & | hd_chain, | ||
bool | internal = false |
||
) |
Generate a new key.
Definition at line 1051 of file scriptpubkeyman.cpp.
CPubKey wallet::LegacyScriptPubKeyMan::GenerateNewSeed | ( | ) |
Definition at line 1178 of file scriptpubkeyman.cpp.
|
inline |
|
inline |
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 694 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from FillableSigningProvider.
Definition at line 983 of file scriptpubkeyman.cpp.
|
private |
Fetches a key from the keypool.
Definition at line 1388 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from SigningProvider.
Definition at line 1000 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 567 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from FillableSigningProvider.
Definition at line 1654 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 673 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 24 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 543 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from FillableSigningProvider.
Definition at line 1031 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 296 of file scriptpubkeyman.cpp.
|
overridevirtual |
Returns a set of all the scriptPubKeys that this ScriptPubKeyMan watches.
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 1667 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 579 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 573 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::GetWatchPubKey | ( | const CKeyID & | address, |
CPubKey & | pubkey_out | ||
) | const |
Fetches a pubkey from mapWatchKeys if it exists there.
Definition at line 1020 of file scriptpubkeyman.cpp.
|
private |
|
private |
|
private |
|
private |
|
inlineprivate |
Number of pre-generated keys/scripts (part of the look-ahead process, used to detect payments)
Definition at line 290 of file scriptpubkeyman.h.
|
private |
|
private |
|
private |
std::map<CKeyID, CKeyMetadata> mapKeyMetadata wallet::LegacyScriptPubKeyMan::GUARDED_BY | ( | cs_KeyStore | ) |
std::map<CScriptID, CKeyMetadata> m_script_metadata wallet::LegacyScriptPubKeyMan::GUARDED_BY | ( | cs_KeyStore | ) |
|
privatepure virtual |
|
privatepure virtual |
|
overridevirtual |
Reimplemented from FillableSigningProvider.
Definition at line 974 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 512 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::HaveWatchOnly | ( | ) | const |
Returns whether there are any watch-only things in the wallet.
Definition at line 863 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::HaveWatchOnly | ( | const CScript & | dest | ) | const |
Returns whether the watch-only script is in the wallet.
Definition at line 857 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::ImportScriptPubKeys | ( | const std::set< CScript > & | script_pub_keys, |
const bool | have_solving_data, | ||
const int64_t | timestamp | ||
) |
bool wallet::LegacyScriptPubKeyMan::ImportScripts | ( | const std::set< CScript > | scripts, |
int64_t | timestamp | ||
) |
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 443 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 212 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 1354 of file scriptpubkeyman.cpp.
size_t wallet::LegacyScriptPubKeyMan::KeypoolCountExternalKeys | ( | ) | const |
void wallet::LegacyScriptPubKeyMan::LearnAllRelatedScripts | ( | const CPubKey & | key | ) |
Same as LearnRelatedScripts, but when the OutputType is not known (and could be anything).
Definition at line 1470 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::LearnRelatedScripts | ( | const CPubKey & | key, |
OutputType | type | ||
) |
Explicitly make the wallet learn the related scripts for outputs to the given key.
This is purely to make the wallet file compatible with older software, as FillableSigningProvider automatically does this implicitly for all keys now.
Definition at line 1457 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::LoadCryptedKey | ( | const CPubKey & | vchPubKey, |
const std::vector< unsigned char > & | vchCryptedSecret, | ||
bool | checksum_valid | ||
) |
Adds an encrypted key to the store, without saving it to disk (used by LoadWallet)
Definition at line 819 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::LoadCScript | ( | const CScript & | redeemScript | ) |
Adds a CScript to the store.
Definition at line 767 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::LoadHDChain | ( | const CHDChain & | chain | ) |
Load a HD chain model (used by LoadWallet)
Definition at line 946 of file scriptpubkeyman.cpp.
Adds a key to the store, without saving it to disk (used by LoadWallet)
Definition at line 715 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::LoadKeyMetadata | ( | const CKeyID & | keyID, |
const CKeyMetadata & | metadata | ||
) |
Load metadata (used by LoadWallet)
Definition at line 782 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::LoadKeyPool | ( | int64_t | nIndex, |
const CKeyPool & | keypool | ||
) |
Load a keypool entry.
Definition at line 1150 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::LoadScriptMetadata | ( | const CScriptID & | script_id, |
const CKeyMetadata & | metadata | ||
) |
Definition at line 789 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::LoadWatchOnly | ( | const CScript & | dest | ) |
Adds a watch-only address to the store, without saving it to disk (used by LoadWallet)
Definition at line 897 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::MarkPreSplitKeys | ( | ) |
Definition at line 1517 of file scriptpubkeyman.cpp.
std::vector< CKeyPool > wallet::LegacyScriptPubKeyMan::MarkReserveKeysAsUsed | ( | int64_t | keypool_id | ) |
Marks all keys in the keypool up to and including the provided key as used.
keypool_id | determines the last key to mark as used |
Definition at line 1476 of file scriptpubkeyman.cpp.
|
overridevirtual |
Mark unused addresses as being used Affects all keys up to and including the one determined by provided script.
script | determines the last key to mark as used |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 339 of file scriptpubkeyman.cpp.
std::optional< MigrationData > wallet::LegacyScriptPubKeyMan::MigrateToDescriptor | ( | ) |
Get the DescriptorScriptPubKeyMans (with private keys) that have the same scriptPubKeys as this LegacyScriptPubKeyMan.
Does not modify this ScriptPubKeyMan.
Definition at line 1720 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::NewKeyPool | ( | ) |
Mark old keypool keys as used, and generate all new keys.
Definition at line 1233 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::RemoveWatchOnly | ( | const CScript & | dest | ) |
Remove a watch only script from the keystore.
Definition at line 876 of file scriptpubkeyman.cpp.
|
private |
Reserves a key from the keypool and sets nIndex to its index.
[out] | nIndex | the index of the key in keypool |
[out] | keypool | the keypool the key was drawn from, which could be the the pre-split pool if present, or the internal or external pool |
fRequestedInternal | true if the caller would like the key drawn from the internal keypool, false if external is preferred |
std::runtime_error | if keypool read failed, key was invalid, was not found in the wallet, or was misclassified in the internal or external keypool |
Definition at line 1411 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 1368 of file scriptpubkeyman.cpp.
|
overridevirtual |
The action to do when the DB needs rewrite.
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 518 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::SetHDSeed | ( | const CPubKey & | key | ) |
Definition at line 1214 of file scriptpubkeyman.cpp.
|
overridevirtual |
Sets up the key generation stuff, i.e.
generates new HD seeds and sets them as active. Returns false if already setup or setup fails, true if setup is successful Set force=true to make it re-setup if already setup, used for upgrades
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 430 of file scriptpubkeyman.cpp.
|
overridevirtual |
Sign a message with the given script.
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 612 of file scriptpubkeyman.cpp.
|
overridevirtual |
Creates new signatures and adds them to the transaction.
Returns whether all inputs were signed
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 607 of file scriptpubkeyman.cpp.
|
overridevirtual |
Fills internal address pool.
Use within ScriptPubKeyMan implementations should be used sparingly and only when something from the address pool is removed, excluding GetNewDestination and GetReservedDestination. External wallet code is primarily responsible for topping up prior to fetching new addresses
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 1267 of file scriptpubkeyman.cpp.
|
private |
Definition at line 1285 of file scriptpubkeyman.cpp.
|
private |
Like TopUp() but adds keys for inactive HD chains.
Ensures that there are at least -keypool number of keys derived after the given index.
seed_id | the CKeyID for the HD seed. |
index | the index to start generating keys from |
internal | whether the internal chain should be used. true for internal chain, false for external chain. |
Definition at line 317 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::UpdateTimeFirstKey | ( | int64_t | nCreateTime | ) |
Update wallet first key creation time.
This should be called whenever keys are added to the wallet, with the oldest key creation time.
Definition at line 703 of file scriptpubkeyman.cpp.
|
overridevirtual |
Upgrades the wallet to the specified version.
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 465 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::UpgradeKeyMetadata | ( | ) |
Upgrade stored CKeyMetadata objects to store key origin info as KeyOriginInfo.
Definition at line 395 of file scriptpubkeyman.cpp.
|
private |
keeps track of whether Unlock has run a thorough check before
Definition at line 274 of file scriptpubkeyman.h.
|
private |
Definition at line 322 of file scriptpubkeyman.h.
|
private |
Definition at line 323 of file scriptpubkeyman.h.
|
private |
Definition at line 334 of file scriptpubkeyman.h.
|
private |
Definition at line 332 of file scriptpubkeyman.h.