Bitcoin Core
27.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) 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::unordered_set< CScript, SaltedSipHasher > | GetNotMineScriptPubKeys () const |
Retrieves scripts that were imported by bugs into the legacy spkm and are simply invalid, such as a sh(sh(pkh())) script, or not watched. 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... | |
Public Member Functions inherited from wallet::ScriptPubKeyMan | |
ScriptPubKeyMan (WalletStorage &storage) | |
virtual | ~ScriptPubKeyMan () |
template<typename... Params> | |
void | WalletLogPrintf (const char *fmt, Params... parameters) const |
Prepends the wallet name in logging output to ease debugging in multi-wallet use cases. More... | |
Public Member Functions inherited from FillableSigningProvider | |
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 |
Public Member Functions inherited from SigningProvider | |
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) |
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) |
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 (WalletBatch &batch, 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 | |
Public Attributes inherited from wallet::ScriptPubKeyMan | |
boost::signals2::signal< void(bool fHaveWatchOnly)> | NotifyWatchonlyChanged |
Watch-only address added. More... | |
boost::signals2::signal< void()> | NotifyCanGetAddressesChanged |
Keypool has new keys. More... | |
boost::signals2::signal< void(const ScriptPubKeyMan *spkm, int64_t new_birth_time)> | NotifyFirstKeyTimeChanged |
Birth time changed. More... | |
Public Attributes inherited from FillableSigningProvider | |
RecursiveMutex | cs_KeyStore |
Protected Types inherited from FillableSigningProvider | |
using | KeyMap = std::map< CKeyID, CKey > |
using | ScriptMap = std::map< CScriptID, CScript > |
Protected Member Functions inherited from FillableSigningProvider | |
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) |
Protected Attributes inherited from wallet::ScriptPubKeyMan | |
WalletStorage & | m_storage |
Definition at line 280 of file scriptpubkeyman.h.
|
private |
Definition at line 291 of file scriptpubkeyman.h.
|
private |
Definition at line 287 of file scriptpubkeyman.h.
|
private |
Definition at line 286 of file scriptpubkeyman.h.
|
inline |
Definition at line 380 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 846 of file scriptpubkeyman.cpp.
|
private |
Definition at line 836 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from FillableSigningProvider.
Definition at line 1548 of file scriptpubkeyman.cpp.
|
private |
Adds a script to the store and saves it to disk.
Definition at line 1554 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::AddHDChain | ( | const CHDChain & | chain | ) |
Definition at line 959 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::AddInactiveHDChain | ( | const CHDChain & | chain | ) |
Definition at line 974 of file scriptpubkeyman.cpp.
|
private |
Add a KeyOriginInfo to the wallet.
Definition at line 1565 of file scriptpubkeyman.cpp.
|
private |
Definition at line 1351 of file scriptpubkeyman.cpp.
|
overridevirtual |
Adds a key to the store, and saves it to disk.
Reimplemented from FillableSigningProvider.
Definition at line 725 of file scriptpubkeyman.cpp.
|
private |
Definition at line 801 of file scriptpubkeyman.cpp.
|
private |
Adds a key to the store, and saves it to disk.
Definition at line 732 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 941 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::AddWatchOnly | ( | const CScript & | dest, |
int64_t | nCreateTime | ||
) |
|
private |
Definition at line 909 of file scriptpubkeyman.cpp.
|
private |
Definition at line 921 of file scriptpubkeyman.cpp.
|
private |
Adds a watch-only address to the store, and saves it to disk.
Definition at line 935 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::CanGenerateKeys | ( | ) | const |
Definition at line 1180 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 453 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 589 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 230 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::DeleteRecords | ( | ) |
Delete all the records ofthis LegacyScriptPubKeyMan from disk.
Definition at line 2000 of file scriptpubkeyman.cpp.
|
private |
Definition at line 1104 of file scriptpubkeyman.cpp.
Definition at line 1194 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 270 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 630 of file scriptpubkeyman.cpp.
CPubKey wallet::LegacyScriptPubKeyMan::GenerateNewKey | ( | WalletBatch & | batch, |
CHDChain & | hd_chain, | ||
bool | internal = false |
||
) |
Generate a new key.
Definition at line 1060 of file scriptpubkeyman.cpp.
CPubKey wallet::LegacyScriptPubKeyMan::GenerateNewSeed | ( | ) |
Definition at line 1187 of file scriptpubkeyman.cpp.
|
inline |
|
inline |
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 697 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from FillableSigningProvider.
Definition at line 990 of file scriptpubkeyman.cpp.
|
private |
Fetches a key from the keypool.
Definition at line 1401 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from SigningProvider.
Definition at line 1009 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 572 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from FillableSigningProvider.
Definition at line 1667 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 676 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 27 of file scriptpubkeyman.cpp.
std::unordered_set< CScript, SaltedSipHasher > wallet::LegacyScriptPubKeyMan::GetNotMineScriptPubKeys | ( | ) | const |
Retrieves scripts that were imported by bugs into the legacy spkm and are simply invalid, such as a sh(sh(pkh())) script, or not watched.
Definition at line 1738 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 548 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from FillableSigningProvider.
Definition at line 1040 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 300 of file scriptpubkeyman.cpp.
|
overridevirtual |
Returns a set of all the scriptPubKeys that this ScriptPubKeyMan watches.
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 1680 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 584 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 578 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 1029 of file scriptpubkeyman.cpp.
|
private |
|
private |
|
private |
|
private |
|
private |
|
inlineprivate |
Number of pre-generated keys/scripts (part of the look-ahead process, used to detect payments)
Definition at line 301 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 |
|
overridevirtual |
Reimplemented from FillableSigningProvider.
Definition at line 981 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 517 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::HaveWatchOnly | ( | ) | const |
Returns whether there are any watch-only things in the wallet.
Definition at line 870 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 864 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 448 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 216 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 1367 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 1483 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 1470 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 826 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::LoadCScript | ( | const CScript & | redeemScript | ) |
Adds a CScript to the store.
Definition at line 772 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::LoadHDChain | ( | const CHDChain & | chain | ) |
Load a HD chain model (used by LoadWallet)
Definition at line 953 of file scriptpubkeyman.cpp.
Adds a key to the store, without saving it to disk (used by LoadWallet)
Definition at line 720 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::LoadKeyMetadata | ( | const CKeyID & | keyID, |
const CKeyMetadata & | metadata | ||
) |
Load metadata (used by LoadWallet)
Definition at line 787 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::LoadKeyPool | ( | int64_t | nIndex, |
const CKeyPool & | keypool | ||
) |
Load a keypool entry.
Definition at line 1159 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::LoadScriptMetadata | ( | const CScriptID & | script_id, |
const CKeyMetadata & | metadata | ||
) |
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 904 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::MarkPreSplitKeys | ( | ) |
Definition at line 1530 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 1489 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 344 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 1748 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::NewKeyPool | ( | ) |
Mark old keypool keys as used, and generate all new keys.
Definition at line 1241 of file scriptpubkeyman.cpp.
bool wallet::LegacyScriptPubKeyMan::RemoveWatchOnly | ( | const CScript & | dest | ) |
Remove a watch only script from the keystore.
Definition at line 883 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 1424 of file scriptpubkeyman.cpp.
|
overridevirtual |
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 1381 of file scriptpubkeyman.cpp.
|
overridevirtual |
The action to do when the DB needs rewrite.
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 523 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::SetHDSeed | ( | const CPubKey & | key | ) |
Definition at line 1222 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 435 of file scriptpubkeyman.cpp.
|
overridevirtual |
Sign a message with the given script.
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 617 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 612 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 1275 of file scriptpubkeyman.cpp.
|
private |
Definition at line 1299 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 321 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 706 of file scriptpubkeyman.cpp.
|
overridevirtual |
Upgrades the wallet to the specified version.
Reimplemented from wallet::ScriptPubKeyMan.
Definition at line 470 of file scriptpubkeyman.cpp.
void wallet::LegacyScriptPubKeyMan::UpgradeKeyMetadata | ( | ) |
Upgrade stored CKeyMetadata objects to store key origin info as KeyOriginInfo.
Definition at line 400 of file scriptpubkeyman.cpp.
|
private |
keeps track of whether Unlock has run a thorough check before
Definition at line 284 of file scriptpubkeyman.h.
|
private |
Definition at line 333 of file scriptpubkeyman.h.
|
private |
Definition at line 334 of file scriptpubkeyman.h.
|
private |
Definition at line 345 of file scriptpubkeyman.h.
|
private |
Definition at line 343 of file scriptpubkeyman.h.