Bitcoin ABC 0.32.4
P2P Digital Currency
base.h
Go to the documentation of this file.
1// Copyright (c) 2017-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_BASE_H
6#define BITCOIN_INDEX_BASE_H
7
8#include <dbwrapper.h>
9#include <interfaces/chain.h>
11#include <validationinterface.h>
12
13#include <string>
14
15class CBlock;
16class CBlockIndex;
17class Chainstate;
19
21 std::string name;
22 bool synced{false};
25};
26
38protected:
46 class DB : public CDBWrapper {
47 public:
48 DB(const fs::path &path, size_t n_cache_size, bool f_memory = false,
49 bool f_wipe = false, bool f_obfuscate = false);
50
52 bool ReadBestBlock(CBlockLocator &locator) const;
53
55 void WriteBestBlock(CDBBatch &batch, const CBlockLocator &locator);
56 };
57
58private:
60 std::atomic<bool> m_init{false};
68 std::atomic<bool> m_synced{false};
69
71 std::atomic<const CBlockIndex *> m_best_block_index{nullptr};
72
73 std::thread m_thread_sync;
75
81 void ThreadSync();
82
93 bool Commit();
94
95 virtual bool AllowPrune() const = 0;
96
97 template <typename... Args>
98 void FatalErrorf(const char *fmt, const Args &...args);
99
100protected:
101 std::unique_ptr<interfaces::Chain> m_chain;
103 const std::string m_name;
104
106 const std::shared_ptr<const CBlock> &block,
107 const CBlockIndex *pindex) override;
108
110 const CBlockLocator &locator) override;
111
113 [[nodiscard]] virtual bool
114 CustomInit(const std::optional<interfaces::BlockKey> &block) {
115 return true;
116 }
117
119 virtual bool WriteBlock(const CBlock &block, const CBlockIndex *pindex) {
120 return true;
121 }
122
125 virtual bool CustomCommit(CDBBatch &batch) { return true; }
126
129 virtual bool Rewind(const CBlockIndex *current_tip,
130 const CBlockIndex *new_tip);
131
132 virtual DB &GetDB() const = 0;
133
135 void SetBestBlockIndex(const CBlockIndex *block);
136
137public:
138 BaseIndex(std::unique_ptr<interfaces::Chain> chain, std::string name);
140 virtual ~BaseIndex();
141
143 const std::string &GetName() const LIFETIMEBOUND { return m_name; }
144
150 bool BlockUntilSyncedToCurrentChain() const LOCKS_EXCLUDED(::cs_main);
151
152 void Interrupt();
153
156 [[nodiscard]] bool Init();
157
159 [[nodiscard]] bool StartBackgroundSync();
160
162 void Stop();
163
165 IndexSummary GetSummary() const;
166};
167
168#endif // BITCOIN_INDEX_BASE_H
#define LIFETIMEBOUND
Definition: attributes.h:16
The database stores a block locator of the chain the database is synced to so that the TxIndex can ef...
Definition: base.h:46
void WriteBestBlock(CDBBatch &batch, const CBlockLocator &locator)
Write block locator of the chain that the index is in sync with.
Definition: base.cpp:70
DB(const fs::path &path, size_t n_cache_size, bool f_memory=false, bool f_wipe=false, bool f_obfuscate=false)
Definition: base.cpp:49
bool ReadBestBlock(CBlockLocator &locator) const
Read block locator of the chain that the index is in sync with.
Definition: base.cpp:62
Base class for indices of blockchain data.
Definition: base.h:37
void Stop()
Stops the instance from staying in sync with blockchain updates.
Definition: base.cpp:418
void SetBestBlockIndex(const CBlockIndex *block)
Update the internal best block index as well as the prune lock.
Definition: base.cpp:440
bool Init()
Initializes the sync state and registers the instance to the validation interface so that it stays in...
Definition: base.cpp:83
virtual ~BaseIndex()
Destructor interrupts sync thread if running and blocks until it exits.
Definition: base.cpp:78
std::atomic< const CBlockIndex * > m_best_block_index
The last block in the chain that the index is in sync with.
Definition: base.h:71
virtual bool CustomCommit(CDBBatch &batch)
Virtual method called internally by Commit that can be overridden to atomically commit more index sta...
Definition: base.h:125
const std::string & GetName() const LIFETIMEBOUND
Get the name of the index for display in logs.
Definition: base.h:143
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.
Definition: base.cpp:404
virtual bool AllowPrune() const =0
void BlockConnected(ChainstateRole role, const std::shared_ptr< const CBlock > &block, const CBlockIndex *pindex) override
Notifies listeners of a block being connected.
Definition: base.cpp:268
std::atomic< bool > m_synced
Whether the index is in sync with the main chain.
Definition: base.h:68
CThreadInterrupt m_interrupt
Definition: base.h:74
BaseIndex(std::unique_ptr< interfaces::Chain > chain, std::string name)
Definition: base.cpp:75
IndexSummary GetSummary() const
Get a summary of the index and its state.
Definition: base.cpp:426
const std::string m_name
Definition: base.h:103
virtual DB & GetDB() const =0
std::thread m_thread_sync
Definition: base.h:73
bool Commit()
Write the current index state (eg.
Definition: base.cpp:231
virtual bool WriteBlock(const CBlock &block, const CBlockIndex *pindex)
Write update index entries for a newly connected block.
Definition: base.h:119
virtual bool CustomInit(const std::optional< interfaces::BlockKey > &block)
Initialize internal state from the database and block index.
Definition: base.h:114
void ThreadSync()
Sync the index with the block index starting from the current best block.
Definition: base.cpp:155
void FatalErrorf(const char *fmt, const Args &...args)
Definition: base.cpp:34
Chainstate * m_chainstate
Definition: base.h:102
virtual bool Rewind(const CBlockIndex *current_tip, const CBlockIndex *new_tip)
Rewind index to an earlier chain tip during a chain reorg.
Definition: base.cpp:252
bool StartBackgroundSync()
Starts the initial sync process.
Definition: base.cpp:408
void ChainStateFlushed(ChainstateRole role, const CBlockLocator &locator) override
Notifies listeners of the new active block chain on-disk.
Definition: base.cpp:331
std::unique_ptr< interfaces::Chain > m_chain
Definition: base.h:101
std::atomic< bool > m_init
Whether the index has been initialized or not.
Definition: base.h:60
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
A helper class for interruptible sleeps.
Implement this to subscribe to events generated in validation.
Chainstate stores and provides an API to update our local knowledge of the current best chain.
Definition: validation.h:734
Provides an interface for creating and interacting with one or two chainstates: an IBD chainstate gen...
Definition: validation.h:1186
Path class wrapper to block calls to the fs::path(std::string) implicit constructor and the fs::path:...
Definition: fs.h:30
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate.
Definition: cs_main.cpp:7
ChainstateRole
This enum describes the various roles a specific Chainstate instance can take.
Definition: chain.h:14
const char * name
Definition: rest.cpp:47
A BlockHash is a unqiue identifier for a block.
Definition: blockhash.h:13
Describes a place in the block chain to another node such that if the other node doesn't have the sam...
Definition: block.h:109
std::string name
Definition: base.h:21
bool synced
Definition: base.h:22
BlockHash best_block_hash
Definition: base.h:24
int best_block_height
Definition: base.h:23
#define LOCKS_EXCLUDED(...)
Definition: threadsafety.h:55