Bitcoin Core 30.99.0
P2P Digital Currency
chainparams.h
Go to the documentation of this file.
1// Copyright (c) 2009-2010 Satoshi Nakamoto
2// Copyright (c) 2009-present The Bitcoin Core developers
3// Distributed under the MIT software license, see the accompanying
4// file COPYING or http://www.opensource.org/licenses/mit-license.php.
5
6#ifndef BITCOIN_KERNEL_CHAINPARAMS_H
7#define BITCOIN_KERNEL_CHAINPARAMS_H
8
9#include <consensus/params.h>
11#include <primitives/block.h>
12#include <uint256.h>
13#include <util/chaintype.h>
14#include <util/hash_type.h>
15#include <util/vector.h>
16
17#include <cstddef>
18#include <cstdint>
19#include <memory>
20#include <optional>
21#include <string>
22#include <unordered_map>
23#include <vector>
24
25struct AssumeutxoHash : public BaseHash<uint256> {
26 explicit AssumeutxoHash(const uint256& hash) : BaseHash(hash) {}
27};
28
35 int height;
36
39
45
49};
50
58 int64_t nTime;
59 uint64_t tx_count;
60 double dTxRate;
61};
62
70};
71
77{
78public:
85
87 };
88
89 const Consensus::Params& GetConsensus() const { return consensus; }
91 uint16_t GetDefaultPort() const { return nDefaultPort; }
92 std::vector<int> GetAvailableSnapshotHeights() const;
93
94 const CBlock& GenesisBlock() const { return genesis; }
98 bool IsTestChain() const { return m_chain_type != ChainType::MAIN; }
100 bool IsMockableChain() const { return m_is_mockable_chain; }
101 uint64_t PruneAfterHeight() const { return nPruneAfterHeight; }
109 std::string GetChainTypeString() const { return ChainTypeToString(m_chain_type); }
113 const std::vector<std::string>& DNSSeeds() const { return vSeeds; }
114 const std::vector<unsigned char>& Base58Prefix(Base58Type type) const { return base58Prefixes[type]; }
115 const std::string& Bech32HRP() const { return bech32_hrp; }
116 const std::vector<uint8_t>& FixedSeeds() const { return vFixedSeeds; }
118
119 std::optional<AssumeutxoData> AssumeutxoForHeight(int height) const
120 {
121 return FindFirst(m_assumeutxo_data, [&](const auto& d) { return d.height == height; });
122 }
123 std::optional<AssumeutxoData> AssumeutxoForBlockhash(const uint256& blockhash) const
124 {
125 return FindFirst(m_assumeutxo_data, [&](const auto& d) { return d.blockhash == blockhash; });
126 }
127
128 const ChainTxData& TxData() const { return chainTxData; }
129
134 std::optional<std::vector<uint8_t>> challenge{};
135 std::optional<std::vector<std::string>> seeds{};
136 };
137
142 int64_t start_time;
143 int64_t timeout;
145 };
146
151 std::unordered_map<Consensus::DeploymentPos, VersionBitsParameters> version_bits_parameters{};
152 std::unordered_map<Consensus::BuriedDeployment, int> activation_heights{};
153 bool fastprune{false};
154 bool enforce_bip94{false};
155 };
156
157 static std::unique_ptr<const CChainParams> RegTest(const RegTestOptions& options);
158 static std::unique_ptr<const CChainParams> SigNet(const SigNetOptions& options);
159 static std::unique_ptr<const CChainParams> Main();
160 static std::unique_ptr<const CChainParams> TestNet();
161 static std::unique_ptr<const CChainParams> TestNet4();
162
163protected:
164 CChainParams() = default;
165
168 uint16_t nDefaultPort;
172 std::vector<std::string> vSeeds;
173 std::vector<unsigned char> base58Prefixes[MAX_BASE58_TYPES];
174 std::string bech32_hrp;
177 std::vector<uint8_t> vFixedSeeds;
180 std::vector<AssumeutxoData> m_assumeutxo_data;
183};
184
185std::optional<ChainType> GetNetworkForMagic(const MessageStartChars& pchMessageStart);
186
187#endif // BITCOIN_KERNEL_CHAINPARAMS_H
std::string ChainTypeToString(ChainType chain)
Definition: chaintype.cpp:11
ChainType
Definition: chaintype.h:11
Definition: block.h:74
CChainParams defines various tweakable parameters of a given instance of the Bitcoin system.
Definition: chainparams.h:77
std::string GetChainTypeString() const
Return the chain type string.
Definition: chainparams.h:109
const MessageStartChars & MessageStart() const
Definition: chainparams.h:90
uint64_t m_assumed_chain_state_size
Definition: chainparams.h:171
MessageStartChars pchMessageStart
Definition: chainparams.h:167
CChainParams()=default
static std::unique_ptr< const CChainParams > Main()
const CBlock & GenesisBlock() const
Definition: chainparams.h:94
std::string bech32_hrp
Definition: chainparams.h:174
bool DefaultConsistencyChecks() const
Default value for -checkmempool and -checkblockindex argument.
Definition: chainparams.h:96
std::vector< int > GetAvailableSnapshotHeights() const
static std::unique_ptr< const CChainParams > RegTest(const RegTestOptions &options)
CBlock genesis
Definition: chainparams.h:176
const std::vector< unsigned char > & Base58Prefix(Base58Type type) const
Definition: chainparams.h:114
uint64_t m_assumed_blockchain_size
Definition: chainparams.h:170
std::vector< uint8_t > vFixedSeeds
Definition: chainparams.h:177
bool IsMockableChain() const
If this chain allows time to be mocked.
Definition: chainparams.h:100
bool fDefaultConsistencyChecks
Definition: chainparams.h:178
HeadersSyncParams m_headers_sync_params
Definition: chainparams.h:182
const HeadersSyncParams & HeadersSync() const
Definition: chainparams.h:117
const ChainTxData & TxData() const
Definition: chainparams.h:128
static std::unique_ptr< const CChainParams > TestNet()
const Consensus::Params & GetConsensus() const
Definition: chainparams.h:89
std::vector< unsigned char > base58Prefixes[MAX_BASE58_TYPES]
Definition: chainparams.h:173
bool IsTestChain() const
If this chain is exclusively used for testing.
Definition: chainparams.h:98
bool MineBlocksOnDemand() const
Whether it is possible to mine blocks on demand (no retargeting)
Definition: chainparams.h:107
Consensus::Params consensus
Definition: chainparams.h:166
uint16_t GetDefaultPort() const
Definition: chainparams.h:91
std::vector< AssumeutxoData > m_assumeutxo_data
Definition: chainparams.h:180
uint64_t AssumedBlockchainSize() const
Minimum free space (in GB) needed for data directory.
Definition: chainparams.h:103
const std::string & Bech32HRP() const
Definition: chainparams.h:115
std::vector< std::string > vSeeds
Definition: chainparams.h:172
bool m_is_mockable_chain
Definition: chainparams.h:179
static std::unique_ptr< const CChainParams > TestNet4()
std::optional< AssumeutxoData > AssumeutxoForBlockhash(const uint256 &blockhash) const
Definition: chainparams.h:123
ChainType m_chain_type
Definition: chainparams.h:175
uint64_t AssumedChainStateSize() const
Minimum free space (in GB) needed for data directory when pruned; Does not include prune target.
Definition: chainparams.h:105
uint64_t PruneAfterHeight() const
Definition: chainparams.h:101
uint16_t nDefaultPort
Definition: chainparams.h:168
std::optional< AssumeutxoData > AssumeutxoForHeight(int height) const
Definition: chainparams.h:119
ChainType GetChainType() const
Return the chain type.
Definition: chainparams.h:111
static std::unique_ptr< const CChainParams > SigNet(const SigNetOptions &options)
const std::vector< std::string > & DNSSeeds() const
Return the list of hostnames to look up for DNS seeds.
Definition: chainparams.h:113
uint64_t nPruneAfterHeight
Definition: chainparams.h:169
ChainTxData chainTxData
Definition: chainparams.h:181
const std::vector< uint8_t > & FixedSeeds() const
Definition: chainparams.h:116
256-bit opaque blob.
Definition: uint256.h:195
std::optional< ChainType > GetNetworkForMagic(const MessageStartChars &pchMessageStart)
std::array< uint8_t, 4 > MessageStartChars
Holds configuration for use during UTXO snapshot load and validation.
Definition: chainparams.h:34
AssumeutxoHash hash_serialized
The expected hash of the deserialized UTXO set.
Definition: chainparams.h:38
uint64_t m_chain_tx_count
Used to populate the m_chain_tx_count value, which is used during BlockManager::LoadBlockIndex().
Definition: chainparams.h:44
uint256 blockhash
The hash of the base block for this snapshot.
Definition: chainparams.h:48
AssumeutxoHash(const uint256 &hash)
Definition: chainparams.h:26
RegTestOptions holds configurations for creating a regtest CChainParams.
Definition: chainparams.h:150
std::unordered_map< Consensus::DeploymentPos, VersionBitsParameters > version_bits_parameters
Definition: chainparams.h:151
std::unordered_map< Consensus::BuriedDeployment, int > activation_heights
Definition: chainparams.h:152
SigNetOptions holds configurations for creating a signet CChainParams.
Definition: chainparams.h:133
std::optional< std::vector< uint8_t > > challenge
Definition: chainparams.h:134
std::optional< std::vector< std::string > > seeds
Definition: chainparams.h:135
VersionBitsParameters holds activation parameters.
Definition: chainparams.h:141
Holds various statistics on transactions within a chain.
Definition: chainparams.h:57
uint64_t tx_count
total number of transactions between genesis and that timestamp
Definition: chainparams.h:59
double dTxRate
estimated number of transactions per second after that timestamp
Definition: chainparams.h:60
int64_t nTime
UNIX timestamp of last known number of transactions.
Definition: chainparams.h:58
Parameters that influence chain consensus.
Definition: params.h:84
bool fPowNoRetargeting
Definition: params.h:119
Configuration for headers sync memory usage.
Definition: chainparams.h:64
size_t redownload_buffer_size
Minimum number of validated headers to accumulate in the redownload buffer before feeding them into t...
Definition: chainparams.h:69
size_t commitment_period
Distance in blocks between header commitments.
Definition: chainparams.h:66
std::optional< V > FindFirst(const std::vector< V > &vec, const L fnc)
Definition: vector.h:73