Bitcoin Core  31.0.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 
25 struct AssumeutxoHash : public BaseHash<uint256> {
26  explicit AssumeutxoHash(const uint256& hash) : BaseHash(hash) {}
27 };
28 
35  int height;
36 
39 
44  uint64_t m_chain_tx_count;
45 
49 };
50 
57 struct ChainTxData {
58  int64_t nTime;
59  uint64_t tx_count;
60  double dTxRate;
61 };
62 
66  size_t commitment_period{0};
70 };
71 
77 {
78 public:
79  enum Base58Type {
85 
87  };
88 
89  const Consensus::Params& GetConsensus() const { return consensus; }
90  const MessageStartChars& MessageStart() const { return pchMessageStart; }
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); }
111  ChainType GetChainType() const { return 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 
133  struct SigNetOptions {
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 
150  struct RegTestOptions {
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 
163 protected:
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 
185 std::optional<ChainType> GetNetworkForMagic(const MessageStartChars& pchMessageStart);
186 
187 #endif // BITCOIN_KERNEL_CHAINPARAMS_H
const std::vector< std::string > & DNSSeeds() const
Return the list of hostnames to look up for DNS seeds.
Definition: chainparams.h:113
static std::unique_ptr< const CChainParams > TestNet4()
double dTxRate
estimated number of transactions per second after that timestamp
Definition: chainparams.h:60
bool fPowNoRetargeting
Definition: params.h:119
std::unordered_map< Consensus::DeploymentPos, VersionBitsParameters > version_bits_parameters
Definition: chainparams.h:151
std::string GetChainTypeString() const
Return the chain type string.
Definition: chainparams.h:109
std::vector< uint8_t > vFixedSeeds
Definition: chainparams.h:177
Definition: block.h:73
const std::string & Bech32HRP() const
Definition: chainparams.h:115
uint64_t AssumedChainStateSize() const
Minimum free space (in GB) needed for data directory when pruned; Does not include prune target...
Definition: chainparams.h:105
std::vector< unsigned char > base58Prefixes[MAX_BASE58_TYPES]
Definition: chainparams.h:173
uint64_t m_assumed_chain_state_size
Definition: chainparams.h:171
bool DefaultConsistencyChecks() const
Default value for -checkmempool and -checkblockindex argument.
Definition: chainparams.h:96
uint256 blockhash
The hash of the base block for this snapshot.
Definition: chainparams.h:48
const CBlock & GenesisBlock() const
Definition: chainparams.h:94
CChainParams defines various tweakable parameters of a given instance of the Bitcoin system...
Definition: chainparams.h:76
std::string bech32_hrp
Definition: chainparams.h:174
CBlock genesis
Definition: chainparams.h:176
int64_t nTime
UNIX timestamp of last known number of transactions.
Definition: chainparams.h:58
static std::unique_ptr< const CChainParams > Main()
static std::unique_ptr< const CChainParams > RegTest(const RegTestOptions &options)
uint16_t GetDefaultPort() const
Definition: chainparams.h:91
ChainTxData chainTxData
Definition: chainparams.h:181
uint64_t m_assumed_blockchain_size
Definition: chainparams.h:170
ChainType m_chain_type
Definition: chainparams.h:175
std::array< uint8_t, 4 > MessageStartChars
uint64_t PruneAfterHeight() const
Definition: chainparams.h:101
std::vector< int > GetAvailableSnapshotHeights() const
AssumeutxoHash hash_serialized
The expected hash of the deserialized UTXO set.
Definition: chainparams.h:38
ChainType
Definition: chaintype.h:11
bool MineBlocksOnDemand() const
Whether it is possible to mine blocks on demand (no retargeting)
Definition: chainparams.h:107
VersionBitsParameters holds activation parameters.
Definition: chainparams.h:141
HeadersSyncParams m_headers_sync_params
Definition: chainparams.h:182
std::optional< AssumeutxoData > AssumeutxoForBlockhash(const uint256 &blockhash) const
Definition: chainparams.h:123
Holds various statistics on transactions within a chain.
Definition: chainparams.h:57
std::vector< std::string > vSeeds
Definition: chainparams.h:172
RegTestOptions holds configurations for creating a regtest CChainParams.
Definition: chainparams.h:150
std::optional< std::vector< std::string > > seeds
Definition: chainparams.h:135
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
bool m_is_mockable_chain
Definition: chainparams.h:179
Parameters that influence chain consensus.
Definition: params.h:84
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
SigNetOptions holds configurations for creating a signet CChainParams.
Definition: chainparams.h:133
AssumeutxoHash(const uint256 &hash)
Definition: chainparams.h:26
256-bit opaque blob.
Definition: uint256.h:195
ChainType GetChainType() const
Return the chain type.
Definition: chainparams.h:111
const ChainTxData & TxData() const
Definition: chainparams.h:128
bool IsTestChain() const
If this chain is exclusively used for testing.
Definition: chainparams.h:98
std::unordered_map< Consensus::BuriedDeployment, int > activation_heights
Definition: chainparams.h:152
uint64_t AssumedBlockchainSize() const
Minimum free space (in GB) needed for data directory.
Definition: chainparams.h:103
static std::unique_ptr< const CChainParams > SigNet(const SigNetOptions &options)
static std::unique_ptr< const CChainParams > TestNet()
Configuration for headers sync memory usage.
Definition: chainparams.h:64
Consensus::Params consensus
Definition: chainparams.h:166
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
const MessageStartChars & MessageStart() const
Definition: chainparams.h:90
CChainParams()=default
Holds configuration for use during UTXO snapshot load and validation.
Definition: chainparams.h:34
std::string ChainTypeToString(ChainType chain)
Definition: chaintype.cpp:11
std::optional< ChainType > GetNetworkForMagic(const MessageStartChars &pchMessageStart)
uint64_t nPruneAfterHeight
Definition: chainparams.h:169
const std::vector< uint8_t > & FixedSeeds() const
Definition: chainparams.h:116
uint16_t nDefaultPort
Definition: chainparams.h:168
MessageStartChars pchMessageStart
Definition: chainparams.h:167
const Consensus::Params & GetConsensus() const
Definition: chainparams.h:89
std::optional< std::vector< uint8_t > > challenge
Definition: chainparams.h:134
uint64_t tx_count
total number of transactions between genesis and that timestamp
Definition: chainparams.h:59
std::optional< AssumeutxoData > AssumeutxoForHeight(int height) const
Definition: chainparams.h:119
bool IsMockableChain() const
If this chain allows time to be mocked.
Definition: chainparams.h:100
const HeadersSyncParams & HeadersSync() const
Definition: chainparams.h:117
bool fDefaultConsistencyChecks
Definition: chainparams.h:178
std::vector< AssumeutxoData > m_assumeutxo_data
Definition: chainparams.h:180
const std::vector< unsigned char > & Base58Prefix(Base58Type type) const
Definition: chainparams.h:114