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-2021 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 <cstdint>
18#include <iterator>
19#include <memory>
20#include <optional>
21#include <string>
22#include <unordered_map>
23#include <utility>
24#include <vector>
25
26struct AssumeutxoHash : public BaseHash<uint256> {
27 explicit AssumeutxoHash(const uint256& hash) : BaseHash(hash) {}
28};
29
36 int height;
37
40
46
50};
51
59 int64_t nTime;
60 uint64_t tx_count;
61 double dTxRate;
62};
63
71};
72
78{
79public:
86
88 };
89
90 const Consensus::Params& GetConsensus() const { return consensus; }
92 uint16_t GetDefaultPort() const { return nDefaultPort; }
93 std::vector<int> GetAvailableSnapshotHeights() const;
94
95 const CBlock& GenesisBlock() const { return genesis; }
99 bool IsTestChain() const { return m_chain_type != ChainType::MAIN; }
101 bool IsMockableChain() const { return m_is_mockable_chain; }
102 uint64_t PruneAfterHeight() const { return nPruneAfterHeight; }
110 std::string GetChainTypeString() const { return ChainTypeToString(m_chain_type); }
114 const std::vector<std::string>& DNSSeeds() const { return vSeeds; }
115 const std::vector<unsigned char>& Base58Prefix(Base58Type type) const { return base58Prefixes[type]; }
116 const std::string& Bech32HRP() const { return bech32_hrp; }
117 const std::vector<uint8_t>& FixedSeeds() const { return vFixedSeeds; }
119
120 std::optional<AssumeutxoData> AssumeutxoForHeight(int height) const
121 {
122 return FindFirst(m_assumeutxo_data, [&](const auto& d) { return d.height == height; });
123 }
124 std::optional<AssumeutxoData> AssumeutxoForBlockhash(const uint256& blockhash) const
125 {
126 return FindFirst(m_assumeutxo_data, [&](const auto& d) { return d.blockhash == blockhash; });
127 }
128
129 const ChainTxData& TxData() const { return chainTxData; }
130
135 std::optional<std::vector<uint8_t>> challenge{};
136 std::optional<std::vector<std::string>> seeds{};
137 };
138
143 int64_t start_time;
144 int64_t timeout;
146 };
147
152 std::unordered_map<Consensus::DeploymentPos, VersionBitsParameters> version_bits_parameters{};
153 std::unordered_map<Consensus::BuriedDeployment, int> activation_heights{};
154 bool fastprune{false};
155 bool enforce_bip94{false};
156 };
157
158 static std::unique_ptr<const CChainParams> RegTest(const RegTestOptions& options);
159 static std::unique_ptr<const CChainParams> SigNet(const SigNetOptions& options);
160 static std::unique_ptr<const CChainParams> Main();
161 static std::unique_ptr<const CChainParams> TestNet();
162 static std::unique_ptr<const CChainParams> TestNet4();
163
164protected:
165 CChainParams() = default;
166
169 uint16_t nDefaultPort;
173 std::vector<std::string> vSeeds;
174 std::vector<unsigned char> base58Prefixes[MAX_BASE58_TYPES];
175 std::string bech32_hrp;
178 std::vector<uint8_t> vFixedSeeds;
181 std::vector<AssumeutxoData> m_assumeutxo_data;
184};
185
186std::optional<ChainType> GetNetworkForMagic(const MessageStartChars& pchMessageStart);
187
188#endif // BITCOIN_KERNEL_CHAINPARAMS_H
std::string ChainTypeToString(ChainType chain)
Definition: chaintype.cpp:11
ChainType
Definition: chaintype.h:11
Definition: block.h:69
CChainParams defines various tweakable parameters of a given instance of the Bitcoin system.
Definition: chainparams.h:78
std::string GetChainTypeString() const
Return the chain type string.
Definition: chainparams.h:110
const MessageStartChars & MessageStart() const
Definition: chainparams.h:91
uint64_t m_assumed_chain_state_size
Definition: chainparams.h:172
MessageStartChars pchMessageStart
Definition: chainparams.h:168
CChainParams()=default
static std::unique_ptr< const CChainParams > Main()
const CBlock & GenesisBlock() const
Definition: chainparams.h:95
std::string bech32_hrp
Definition: chainparams.h:175
bool DefaultConsistencyChecks() const
Default value for -checkmempool and -checkblockindex argument.
Definition: chainparams.h:97
std::vector< int > GetAvailableSnapshotHeights() const
static std::unique_ptr< const CChainParams > RegTest(const RegTestOptions &options)
CBlock genesis
Definition: chainparams.h:177
const std::vector< unsigned char > & Base58Prefix(Base58Type type) const
Definition: chainparams.h:115
uint64_t m_assumed_blockchain_size
Definition: chainparams.h:171
std::vector< uint8_t > vFixedSeeds
Definition: chainparams.h:178
bool IsMockableChain() const
If this chain allows time to be mocked.
Definition: chainparams.h:101
bool fDefaultConsistencyChecks
Definition: chainparams.h:179
HeadersSyncParams m_headers_sync_params
Definition: chainparams.h:183
const HeadersSyncParams & HeadersSync() const
Definition: chainparams.h:118
const ChainTxData & TxData() const
Definition: chainparams.h:129
static std::unique_ptr< const CChainParams > TestNet()
const Consensus::Params & GetConsensus() const
Definition: chainparams.h:90
std::vector< unsigned char > base58Prefixes[MAX_BASE58_TYPES]
Definition: chainparams.h:174
bool IsTestChain() const
If this chain is exclusively used for testing.
Definition: chainparams.h:99
bool MineBlocksOnDemand() const
Whether it is possible to mine blocks on demand (no retargeting)
Definition: chainparams.h:108
Consensus::Params consensus
Definition: chainparams.h:167
uint16_t GetDefaultPort() const
Definition: chainparams.h:92
std::vector< AssumeutxoData > m_assumeutxo_data
Definition: chainparams.h:181
uint64_t AssumedBlockchainSize() const
Minimum free space (in GB) needed for data directory.
Definition: chainparams.h:104
const std::string & Bech32HRP() const
Definition: chainparams.h:116
std::vector< std::string > vSeeds
Definition: chainparams.h:173
bool m_is_mockable_chain
Definition: chainparams.h:180
static std::unique_ptr< const CChainParams > TestNet4()
std::optional< AssumeutxoData > AssumeutxoForBlockhash(const uint256 &blockhash) const
Definition: chainparams.h:124
ChainType m_chain_type
Definition: chainparams.h:176
uint64_t AssumedChainStateSize() const
Minimum free space (in GB) needed for data directory when pruned; Does not include prune target.
Definition: chainparams.h:106
uint64_t PruneAfterHeight() const
Definition: chainparams.h:102
uint16_t nDefaultPort
Definition: chainparams.h:169
std::optional< AssumeutxoData > AssumeutxoForHeight(int height) const
Definition: chainparams.h:120
ChainType GetChainType() const
Return the chain type.
Definition: chainparams.h:112
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:114
uint64_t nPruneAfterHeight
Definition: chainparams.h:170
ChainTxData chainTxData
Definition: chainparams.h:182
const std::vector< uint8_t > & FixedSeeds() const
Definition: chainparams.h:117
256-bit opaque blob.
Definition: uint256.h:196
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:35
AssumeutxoHash hash_serialized
The expected hash of the deserialized UTXO set.
Definition: chainparams.h:39
uint64_t m_chain_tx_count
Used to populate the m_chain_tx_count value, which is used during BlockManager::LoadBlockIndex().
Definition: chainparams.h:45
uint256 blockhash
The hash of the base block for this snapshot.
Definition: chainparams.h:49
AssumeutxoHash(const uint256 &hash)
Definition: chainparams.h:27
RegTestOptions holds configurations for creating a regtest CChainParams.
Definition: chainparams.h:151
std::unordered_map< Consensus::DeploymentPos, VersionBitsParameters > version_bits_parameters
Definition: chainparams.h:152
std::unordered_map< Consensus::BuriedDeployment, int > activation_heights
Definition: chainparams.h:153
SigNetOptions holds configurations for creating a signet CChainParams.
Definition: chainparams.h:134
std::optional< std::vector< uint8_t > > challenge
Definition: chainparams.h:135
std::optional< std::vector< std::string > > seeds
Definition: chainparams.h:136
VersionBitsParameters holds activation parameters.
Definition: chainparams.h:142
Holds various statistics on transactions within a chain.
Definition: chainparams.h:58
uint64_t tx_count
total number of transactions between genesis and that timestamp
Definition: chainparams.h:60
double dTxRate
estimated number of transactions per second after that timestamp
Definition: chainparams.h:61
int64_t nTime
UNIX timestamp of last known number of transactions.
Definition: chainparams.h:59
Parameters that influence chain consensus.
Definition: params.h:84
bool fPowNoRetargeting
Definition: params.h:119
Configuration for headers sync memory usage.
Definition: chainparams.h:65
size_t redownload_buffer_size
Minimum number of validated headers to accumulate in the redownload buffer before feeding them into t...
Definition: chainparams.h:70
size_t commitment_period
Distance in blocks between header commitments.
Definition: chainparams.h:67
std::optional< V > FindFirst(const std::vector< V > &vec, const L fnc)
Definition: vector.h:73