![]() |
Bitcoin ABC 0.31.0
P2P Digital Currency
|
Base class for indices of blockchain data. More...
#include <base.h>
Classes | |
class | DB |
The database stores a block locator of the chain the database is synced to so that the TxIndex can efficiently determine the point it last stopped at. More... | |
Public Member Functions | |
BaseIndex (std::unique_ptr< interfaces::Chain > chain, std::string name) | |
virtual | ~BaseIndex () |
Destructor interrupts sync thread if running and blocks until it exits. More... | |
const std::string & | GetName () const LIFETIMEBOUND |
Get the name of the index for display in logs. More... | |
bool BlockUntilSyncedToCurrentChain() const LOCKS_EXCLUDED(void | Interrupt () |
Blocks the current thread until the index is caught up to the current state of the block chain. More... | |
bool | Init () |
Initializes the sync state and registers the instance to the validation interface so that it stays in sync with blockchain updates. More... | |
bool | StartBackgroundSync () |
Starts the initial sync process. More... | |
void | Stop () |
Stops the instance from staying in sync with blockchain updates. More... | |
IndexSummary | GetSummary () const |
Get a summary of the index and its state. More... | |
Protected Member Functions | |
void | BlockConnected (ChainstateRole role, const std::shared_ptr< const CBlock > &block, const CBlockIndex *pindex) override |
Notifies listeners of a block being connected. More... | |
void | ChainStateFlushed (ChainstateRole role, const CBlockLocator &locator) override |
Notifies listeners of the new active block chain on-disk. More... | |
virtual bool | CustomInit (const std::optional< interfaces::BlockKey > &block) |
Initialize internal state from the database and block index. More... | |
virtual bool | WriteBlock (const CBlock &block, const CBlockIndex *pindex) |
Write update index entries for a newly connected block. More... | |
virtual bool | CommitInternal (CDBBatch &batch) |
Virtual method called internally by Commit that can be overridden to atomically commit more index state. More... | |
virtual bool | Rewind (const CBlockIndex *current_tip, const CBlockIndex *new_tip) |
Rewind index to an earlier chain tip during a chain reorg. More... | |
virtual DB & | GetDB () const =0 |
void | SetBestBlockIndex (const CBlockIndex *block) |
Update the internal best block index as well as the prune lock. More... | |
![]() | |
~CValidationInterface ()=default | |
Protected destructor so that instances can only be deleted by derived classes. More... | |
virtual void | UpdatedBlockTip (const CBlockIndex *pindexNew, const CBlockIndex *pindexFork, bool fInitialDownload) |
Notifies listeners when the block chain tip advances. More... | |
virtual void | TransactionAddedToMempool (const CTransactionRef &tx, std::shared_ptr< const std::vector< Coin > > spent_coins, uint64_t mempool_sequence) |
Notifies listeners of a transaction having been added to mempool. More... | |
virtual void | TransactionRemovedFromMempool (const CTransactionRef &tx, MemPoolRemovalReason reason, uint64_t mempool_sequence) |
Notifies listeners of a transaction leaving mempool. More... | |
virtual void | BlockConnected (ChainstateRole role, const std::shared_ptr< const CBlock > &block, const CBlockIndex *pindex) |
Notifies listeners of a block being connected. More... | |
virtual void | BlockDisconnected (const std::shared_ptr< const CBlock > &block, const CBlockIndex *pindex) |
Notifies listeners of a block being disconnected. More... | |
virtual void | ChainStateFlushed (ChainstateRole role, const CBlockLocator &locator) |
Notifies listeners of the new active block chain on-disk. More... | |
virtual void | BlockChecked (const CBlock &, const BlockValidationState &) |
Notifies listeners of a block validation result. More... | |
virtual void | NewPoWValidBlock (const CBlockIndex *pindex, const std::shared_ptr< const CBlock > &block) |
Notifies listeners that a block which builds directly on our current tip has been received and connected to the headers tree, though not validated yet. More... | |
virtual void | BlockFinalized (const CBlockIndex *pindex) |
virtual void | BlockInvalidated (const CBlockIndex *pindex, const std::shared_ptr< const CBlock > &block) |
Protected Attributes | |
std::unique_ptr< interfaces::Chain > | m_chain |
Chainstate * | m_chainstate {nullptr} |
const std::string | m_name |
Private Member Functions | |
void | ThreadSync () |
Sync the index with the block index starting from the current best block. More... | |
bool | Commit () |
Write the current index state (eg. More... | |
virtual bool | AllowPrune () const =0 |
Private Attributes | |
std::atomic< bool > | m_init {false} |
Whether the index has been initialized or not. More... | |
std::atomic< bool > | m_synced {false} |
Whether the index is in sync with the main chain. More... | |
std::atomic< const CBlockIndex * > | m_best_block_index {nullptr} |
The last block in the chain that the index is in sync with. More... | |
std::thread | m_thread_sync |
CThreadInterrupt | m_interrupt |
Base class for indices of blockchain data.
This implements CValidationInterface and ensures blocks are indexed sequentially according to their position in the active chain.
In the presence of multiple chainstates (i.e. if a UTXO snapshot is loaded), only the background "IBD" chainstate will be indexed to avoid building the index out of order. When the background chainstate completes validation, the index will be reinitialized and indexing will continue.
BaseIndex::BaseIndex | ( | std::unique_ptr< interfaces::Chain > | chain, |
std::string | name | ||
) |
|
virtual |
|
privatepure virtual |
Implemented in BlockFilterIndex, CoinStatsIndex, and TxIndex.
|
overrideprotectedvirtual |
Notifies listeners of a block being connected.
Provides a vector of transactions evicted from the mempool as a result.
Called on a background thread.
Reimplemented from CValidationInterface.
Definition at line 263 of file base.cpp.
|
overrideprotectedvirtual |
Notifies listeners of the new active block chain on-disk.
Prior to this callback, any updates are not guaranteed to persist on disk (ie clients need to handle shutdown/restart safety by being able to understand when some updates were lost due to unclean shutdown).
When this callback is invoked, the validation changes done by any prior callback are guaranteed to exist on disk and survive a restart, including an unclean shutdown.
Provides a locator describing the best chain, which is likely useful for storing current state on disk in client DBs.
Called on a background thread.
Reimplemented from CValidationInterface.
Definition at line 326 of file base.cpp.
|
private |
Write the current index state (eg.
chain block locator and subclass-specific items) to disk.
Recommendations for error handling: If called on a successor of the previous committed best block in the index, the index can continue processing without risk of corruption, though the index state will need to catch up from further behind on reboot. If the new state is not a successor of the previous state (due to a chain reorganization), the index must halt until Commit succeeds or else it could end up getting corrupted.
Definition at line 223 of file base.cpp.
|
protectedvirtual |
Virtual method called internally by Commit that can be overridden to atomically commit more index state.
Reimplemented in BlockFilterIndex, and CoinStatsIndex.
Definition at line 232 of file base.cpp.
|
inlineprotectedvirtual |
Initialize internal state from the database and block index.
Reimplemented in BlockFilterIndex, and CoinStatsIndex.
Definition at line 111 of file base.h.
|
protectedpure virtual |
Implemented in BlockFilterIndex, CoinStatsIndex, and TxIndex.
|
inline |
IndexSummary BaseIndex::GetSummary | ( | ) | const |
bool BaseIndex::Init | ( | ) |
void BaseIndex::Interrupt | ( | ) |
Blocks the current thread until the index is caught up to the current state of the block chain.
This only blocks if the index has gotten in sync once and only needs to process blocks in the ValidationInterface queue. If the index is catching up from far behind, this method does not block and immediately returns false.
Definition at line 399 of file base.cpp.
|
protectedvirtual |
Rewind index to an earlier chain tip during a chain reorg.
The tip must be an ancestor of the current best block.
Reimplemented in BlockFilterIndex, and CoinStatsIndex.
Definition at line 243 of file base.cpp.
|
protected |
bool BaseIndex::StartBackgroundSync | ( | ) |
void BaseIndex::Stop | ( | ) |
|
private |
Sync the index with the block index starting from the current best block.
Intended to be run in its own thread, m_thread_sync, and can be interrupted with m_interrupt. Once the index gets in sync, the m_synced flag is set and the BlockConnected ValidationInterface callback takes over and the sync thread exits.
Definition at line 147 of file base.cpp.
|
inlineprotectedvirtual |
Write update index entries for a newly connected block.
Reimplemented in BlockFilterIndex, CoinStatsIndex, and TxIndex.
Definition at line 116 of file base.h.
|
private |
|
protected |
|
protected |
|
private |
|
private |
|
private |
Whether the index is in sync with the main chain.
The flag is flipped from false to true once, after which point this starts processing ValidationInterface notifications to stay in sync.
Note that this will latch to true immediately upon startup if m_chainstate->m_chain
is empty, which will be the case upon startup with an empty datadir if, e.g., -txindex=1
is specified.