Bitcoin ABC 0.30.5
P2P Digital Currency
blockfilterindex.h
Go to the documentation of this file.
1// Copyright (c) 2018 The Bitcoin Core developers
2// Distributed under the MIT software license, see the accompanying
3// file COPYING or http://www.opensource.org/licenses/mit-license.php.
4
5#ifndef BITCOIN_INDEX_BLOCKFILTERINDEX_H
6#define BITCOIN_INDEX_BLOCKFILTERINDEX_H
7
8#include <blockfilter.h>
9#include <chain.h>
10#include <flatfile.h>
11#include <index/base.h>
12#include <util/hasher.h>
13
14static const char *const DEFAULT_BLOCKFILTERINDEX = "0";
15
17static constexpr int CFCHECKPT_INTERVAL = 1000;
18
27class BlockFilterIndex final : public BaseIndex {
28private:
30 std::string m_name;
31 std::unique_ptr<BaseIndex::DB> m_db;
32
34 std::unique_ptr<FlatFileSeq> m_filter_fileseq;
35
36 bool ReadFilterFromDisk(const FlatFilePos &pos, BlockFilter &filter) const;
37 size_t WriteFilterToDisk(FlatFilePos &pos, const BlockFilter &filter);
38
44 std::unordered_map<BlockHash, uint256, FilterHeaderHasher>
46
47 bool AllowPrune() const override { return true; }
48
49protected:
50 bool Init() override;
51
52 bool CommitInternal(CDBBatch &batch) override;
53
54 bool WriteBlock(const CBlock &block, const CBlockIndex *pindex) override;
55
56 bool Rewind(const CBlockIndex *current_tip,
57 const CBlockIndex *new_tip) override;
58
59 BaseIndex::DB &GetDB() const override { return *m_db; }
60
61 const char *GetName() const override { return m_name.c_str(); }
62
63public:
65 explicit BlockFilterIndex(BlockFilterType filter_type, size_t n_cache_size,
66 bool f_memory = false, bool f_wipe = false);
67
69
71 bool LookupFilter(const CBlockIndex *block_index,
72 BlockFilter &filter_out) const;
73
75 bool LookupFilterHeader(const CBlockIndex *block_index, uint256 &header_out)
77
79 bool LookupFilterRange(int start_height, const CBlockIndex *stop_index,
80 std::vector<BlockFilter> &filters_out) const;
81
83 bool LookupFilterHashRange(int start_height, const CBlockIndex *stop_index,
84 std::vector<uint256> &hashes_out) const;
85};
86
92
94void ForEachBlockFilterIndex(std::function<void(BlockFilterIndex &)> fn);
95
101bool InitBlockFilterIndex(BlockFilterType filter_type, size_t n_cache_size,
102 bool f_memory = false, bool f_wipe = false);
103
110
113
114#endif // BITCOIN_INDEX_BLOCKFILTERINDEX_H
BlockFilterType
Definition: blockfilter.h:88
bool DestroyBlockFilterIndex(BlockFilterType filter_type)
Destroy the block filter index with the given type.
void DestroyAllBlockFilterIndexes()
Destroy all open block filter indexes.
bool InitBlockFilterIndex(BlockFilterType filter_type, size_t n_cache_size, bool f_memory=false, bool f_wipe=false)
Initialize a block filter index for the given type if one does not already exist.
static const char *const DEFAULT_BLOCKFILTERINDEX
BlockFilterIndex * GetBlockFilterIndex(BlockFilterType filter_type)
Get a block filter index by type.
static constexpr int CFCHECKPT_INTERVAL
Interval between compact filter checkpoints.
void ForEachBlockFilterIndex(std::function< void(BlockFilterIndex &)> fn)
Iterate over all running block filter indexes, invoking fn on each.
The database stores a block locator of the chain the database is synced to so that the TxIndex can ef...
Definition: base.h:36
Base class for indices of blockchain data.
Definition: base.h:27
Complete block filter struct as defined in BIP 157.
Definition: blockfilter.h:111
BlockFilterIndex is used to store and retrieve block filters, hashes, and headers for a range of bloc...
std::unique_ptr< BaseIndex::DB > m_db
bool CommitInternal(CDBBatch &batch) override
Virtual method called internally by Commit that can be overridden to atomically commit more index sta...
bool Rewind(const CBlockIndex *current_tip, const CBlockIndex *new_tip) override
Rewind index to an earlier chain tip during a chain reorg.
bool ReadFilterFromDisk(const FlatFilePos &pos, BlockFilter &filter) const
bool LookupFilterRange(int start_height, const CBlockIndex *stop_index, std::vector< BlockFilter > &filters_out) const
Get a range of filters between two heights on a chain.
const char * GetName() const override
Get the name of the index for display in logs.
BlockFilterType GetFilterType() const
BlockFilterType m_filter_type
bool Init() override
Initialize internal state from the database and block index.
bool WriteBlock(const CBlock &block, const CBlockIndex *pindex) override
Write update index entries for a newly connected block.
BlockFilterIndex(BlockFilterType filter_type, size_t n_cache_size, bool f_memory=false, bool f_wipe=false)
Constructs the index, which becomes available to be queried.
std::unique_ptr< FlatFileSeq > m_filter_fileseq
bool LookupFilter(const CBlockIndex *block_index, BlockFilter &filter_out) const
Get a single filter by block.
bool LookupFilterHashRange(int start_height, const CBlockIndex *stop_index, std::vector< uint256 > &hashes_out) const
Get a range of filter hashes between two heights on a chain.
bool AllowPrune() const override
size_t WriteFilterToDisk(FlatFilePos &pos, const BlockFilter &filter)
std::unordered_map< BlockHash, uint256, FilterHeaderHasher > m_headers_cache GUARDED_BY(m_cs_headers_cache)
Cache of block hash to filter header, to avoid disk access when responding to getcfcheckpt.
bool LookupFilterHeader(const CBlockIndex *block_index, uint256 &header_out) EXCLUSIVE_LOCKS_REQUIRED(!m_cs_headers_cache)
Get a single filter header by block.
BaseIndex::DB & GetDB() const override
std::string m_name
FlatFilePos m_next_filter_pos
Definition: block.h:60
The block chain is a tree shaped structure starting with the genesis block at the root,...
Definition: blockindex.h:25
Batch of changes queued to be written to a CDBWrapper.
Definition: dbwrapper.h:78
256-bit opaque blob.
Definition: uint256.h:129
#define EXCLUSIVE_LOCKS_REQUIRED(...)
Definition: threadsafety.h:56