Bitcoin Core 28.99.0
P2P Digital Currency
Classes | Public Member Functions | Protected Member Functions | Private Member Functions | Private Attributes | List of all members
TxIndex Class Referencefinal

TxIndex is used to look up transactions included in the blockchain by hash. More...

#include <txindex.h>

Inheritance diagram for TxIndex:
[legend]
Collaboration diagram for TxIndex:
[legend]

Classes

class  DB
 Access to the txindex database (indexes/txindex/) More...
 

Public Member Functions

 TxIndex (std::unique_ptr< interfaces::Chain > chain, size_t n_cache_size, bool f_memory=false, bool f_wipe=false)
 Constructs the index, which becomes available to be queried. More...
 
virtual ~TxIndex () override
 
bool FindTx (const uint256 &tx_hash, uint256 &block_hash, CTransactionRef &tx) const
 Look up a transaction by hash. More...
 
- Public Member Functions inherited from BaseIndex
 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 on a background thread. More...
 
void Sync ()
 Sync the index with the block index starting from the current best block. 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

bool CustomAppend (const interfaces::BlockInfo &block) override
 Write update index entries for a newly connected block. More...
 
BaseIndex::DBGetDB () const override
 
- Protected Member Functions inherited from BaseIndex
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::BlockRef > &block)
 Initialize internal state from the database and block index. More...
 
virtual bool CustomAppend (const interfaces::BlockInfo &block)
 Write update index entries for a newly connected block. More...
 
virtual bool CustomCommit (CDBBatch &batch)
 Virtual method called internally by Commit that can be overridden to atomically commit more index state. More...
 
virtual bool CustomRewind (const interfaces::BlockRef &current_tip, const interfaces::BlockRef &new_tip)
 Rewind index to an earlier chain tip during a chain reorg. More...
 
virtual DBGetDB () const =0
 
void SetBestBlockIndex (const CBlockIndex *block)
 Update the internal best block index as well as the prune lock. More...
 
- Protected Member Functions inherited from CValidationInterface
 ~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 ActiveTipChange (const CBlockIndex &new_tip, bool is_ibd)
 Notifies listeners any time the block chain tip changes, synchronously. More...
 
virtual void TransactionAddedToMempool (const NewMempoolTransactionInfo &tx, 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 MempoolTransactionsRemovedForBlock (const std::vector< RemovedMempoolTransactionInfo > &txs_removed_for_block, unsigned int nBlockHeight)
 
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 Provides the block that was 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...
 

Private Member Functions

bool AllowPrune () const override
 

Private Attributes

const std::unique_ptr< DBm_db
 

Additional Inherited Members

- Protected Attributes inherited from BaseIndex
std::unique_ptr< interfaces::Chainm_chain
 
Chainstatem_chainstate {nullptr}
 
const std::string m_name
 

Detailed Description

TxIndex is used to look up transactions included in the blockchain by hash.

The index is written to a LevelDB database and records the filesystem location of each transaction by transaction hash.

Definition at line 17 of file txindex.h.

Constructor & Destructor Documentation

◆ TxIndex()

TxIndex::TxIndex ( std::unique_ptr< interfaces::Chain chain,
size_t  n_cache_size,
bool  f_memory = false,
bool  f_wipe = false 
)
explicit

Constructs the index, which becomes available to be queried.

Definition at line 51 of file txindex.cpp.

◆ ~TxIndex()

TxIndex::~TxIndex ( )
overridevirtualdefault

Member Function Documentation

◆ AllowPrune()

bool TxIndex::AllowPrune ( ) const
inlineoverrideprivatevirtual

Implements BaseIndex.

Definition at line 25 of file txindex.h.

◆ CustomAppend()

bool TxIndex::CustomAppend ( const interfaces::BlockInfo block)
overrideprotectedvirtual

Write update index entries for a newly connected block.

Reimplemented from BaseIndex.

Definition at line 57 of file txindex.cpp.

Here is the call graph for this function:

◆ FindTx()

bool TxIndex::FindTx ( const uint256 tx_hash,
uint256 block_hash,
CTransactionRef tx 
) const

Look up a transaction by hash.

Parameters
[in]tx_hashThe hash of the transaction to be returned.
[out]block_hashThe hash of the block the transaction is found in.
[out]txThe transaction itself.
Returns
true if transaction is found, false otherwise

Definition at line 75 of file txindex.cpp.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GetDB()

BaseIndex::DB & TxIndex::GetDB ( ) const
overrideprotectedvirtual

Implements BaseIndex.

Definition at line 73 of file txindex.cpp.

Member Data Documentation

◆ m_db

const std::unique_ptr<DB> TxIndex::m_db
private

Definition at line 23 of file txindex.h.


The documentation for this class was generated from the following files: