Bitcoin Core  25.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>
10 #include <netaddress.h>
11 #include <primitives/block.h>
12 #include <protocol.h>
13 #include <uint256.h>
14 #include <util/chaintype.h>
15 #include <util/hash_type.h>
16 
17 #include <cstdint>
18 #include <iterator>
19 #include <map>
20 #include <memory>
21 #include <optional>
22 #include <string>
23 #include <unordered_map>
24 #include <utility>
25 #include <vector>
26 
27 typedef std::map<int, uint256> MapCheckpoints;
28 
31 
32  int GetHeight() const {
33  const auto& final_checkpoint = mapCheckpoints.rbegin();
34  return final_checkpoint->first /* height */;
35  }
36 };
37 
38 struct AssumeutxoHash : public BaseHash<uint256> {
39  explicit AssumeutxoHash(const uint256& hash) : BaseHash(hash) {}
40 };
41 
50 
55  const unsigned int nChainTx;
56 };
57 
58 using MapAssumeutxo = std::map<int, const AssumeutxoData>;
59 
66 struct ChainTxData {
67  int64_t nTime;
68  int64_t nTxCount;
69  double dTxRate;
70 };
71 
77 {
78 public:
79  enum Base58Type {
85 
87  };
88 
89  const Consensus::Params& GetConsensus() const { return consensus; }
91  uint16_t GetDefaultPort() const { return nDefaultPort; }
92  uint16_t GetDefaultPort(Network net) const
93  {
94  return net == NET_I2P ? I2P_SAM31_PORT : GetDefaultPort();
95  }
96  uint16_t GetDefaultPort(const std::string& addr) const
97  {
98  CNetAddr a;
99  return a.SetSpecial(addr) ? GetDefaultPort(a.GetNetwork()) : GetDefaultPort();
100  }
101 
102  const CBlock& GenesisBlock() const { return genesis; }
106  bool RequireStandard() const { return fRequireStandard; }
108  bool IsTestChain() const { return m_is_test_chain; }
110  bool IsMockableChain() const { return m_is_mockable_chain; }
111  uint64_t PruneAfterHeight() const { return nPruneAfterHeight; }
119  std::string GetChainTypeString() const { return ChainTypeToString(m_chain_type); }
121  ChainType GetChainType() const { return m_chain_type; }
123  const std::vector<std::string>& DNSSeeds() const { return vSeeds; }
124  const std::vector<unsigned char>& Base58Prefix(Base58Type type) const { return base58Prefixes[type]; }
125  const std::string& Bech32HRP() const { return bech32_hrp; }
126  const std::vector<uint8_t>& FixedSeeds() const { return vFixedSeeds; }
127  const CCheckpointData& Checkpoints() const { return checkpointData; }
128 
131  const MapAssumeutxo& Assumeutxo() const { return m_assumeutxo_data; }
132 
133  const ChainTxData& TxData() const { return chainTxData; }
134 
138  struct SigNetOptions {
139  std::optional<std::vector<uint8_t>> challenge{};
140  std::optional<std::vector<std::string>> seeds{};
141  };
142 
147  int64_t start_time;
148  int64_t timeout;
150  };
151 
155  struct RegTestOptions {
156  std::unordered_map<Consensus::DeploymentPos, VersionBitsParameters> version_bits_parameters{};
157  std::unordered_map<Consensus::BuriedDeployment, int> activation_heights{};
158  bool fastprune{false};
159  };
160 
161  static std::unique_ptr<const CChainParams> RegTest(const RegTestOptions& options);
162  static std::unique_ptr<const CChainParams> SigNet(const SigNetOptions& options);
163  static std::unique_ptr<const CChainParams> Main();
164  static std::unique_ptr<const CChainParams> TestNet();
165 
166 protected:
168 
171  uint16_t nDefaultPort;
175  std::vector<std::string> vSeeds;
176  std::vector<unsigned char> base58Prefixes[MAX_BASE58_TYPES];
177  std::string bech32_hrp;
180  std::vector<uint8_t> vFixedSeeds;
188 };
189 
190 #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:77
std::string GetChainTypeString() const
Return the chain type string.
Definition: chainparams.h:119
uint64_t m_assumed_chain_state_size
Definition: chainparams.h:174
const std::vector< unsigned char > & Base58Prefix(Base58Type type) const
Definition: chainparams.h:124
static std::unique_ptr< const CChainParams > Main()
std::string bech32_hrp
Definition: chainparams.h:177
bool DefaultConsistencyChecks() const
Default value for -checkmempool and -checkblockindex argument.
Definition: chainparams.h:104
bool m_is_test_chain
Definition: chainparams.h:183
static std::unique_ptr< const CChainParams > RegTest(const RegTestOptions &options)
CBlock genesis
Definition: chainparams.h:179
uint16_t GetDefaultPort(const std::string &addr) const
Definition: chainparams.h:96
bool RequireStandard() const
Policy: Filter transactions that do not match well-defined patterns.
Definition: chainparams.h:106
MapAssumeutxo m_assumeutxo_data
Definition: chainparams.h:186
const std::vector< std::string > & DNSSeeds() const
Return the list of hostnames to look up for DNS seeds.
Definition: chainparams.h:123
const ChainTxData & TxData() const
Definition: chainparams.h:133
const CMessageHeader::MessageStartChars & MessageStart() const
Definition: chainparams.h:90
const std::string & Bech32HRP() const
Definition: chainparams.h:125
uint64_t m_assumed_blockchain_size
Definition: chainparams.h:173
const CCheckpointData & Checkpoints() const
Definition: chainparams.h:127
std::vector< uint8_t > vFixedSeeds
Definition: chainparams.h:180
bool IsMockableChain() const
If this chain allows time to be mocked.
Definition: chainparams.h:110
bool fDefaultConsistencyChecks
Definition: chainparams.h:181
static std::unique_ptr< const CChainParams > TestNet()
const MapAssumeutxo & Assumeutxo() const
Get allowed assumeutxo configuration.
Definition: chainparams.h:131
std::vector< unsigned char > base58Prefixes[MAX_BASE58_TYPES]
Definition: chainparams.h:176
bool IsTestChain() const
If this chain is exclusively used for testing.
Definition: chainparams.h:108
bool MineBlocksOnDemand() const
Whether it is possible to mine blocks on demand (no retargeting)
Definition: chainparams.h:117
Consensus::Params consensus
Definition: chainparams.h:169
const std::vector< uint8_t > & FixedSeeds() const
Definition: chainparams.h:126
const Consensus::Params & GetConsensus() const
Definition: chainparams.h:89
uint16_t GetDefaultPort() const
Definition: chainparams.h:91
uint64_t AssumedBlockchainSize() const
Minimum free space (in GB) needed for data directory.
Definition: chainparams.h:113
bool fRequireStandard
Definition: chainparams.h:182
std::vector< std::string > vSeeds
Definition: chainparams.h:175
bool m_is_mockable_chain
Definition: chainparams.h:184
ChainType m_chain_type
Definition: chainparams.h:178
uint64_t AssumedChainStateSize() const
Minimum free space (in GB) needed for data directory when pruned; Does not include prune target.
Definition: chainparams.h:115
uint64_t PruneAfterHeight() const
Definition: chainparams.h:111
CCheckpointData checkpointData
Definition: chainparams.h:185
uint16_t nDefaultPort
Definition: chainparams.h:171
ChainType GetChainType() const
Return the chain type.
Definition: chainparams.h:121
CMessageHeader::MessageStartChars pchMessageStart
Definition: chainparams.h:170
const CBlock & GenesisBlock() const
Definition: chainparams.h:102
static std::unique_ptr< const CChainParams > SigNet(const SigNetOptions &options)
uint64_t nPruneAfterHeight
Definition: chainparams.h:172
ChainTxData chainTxData
Definition: chainparams.h:187
uint16_t GetDefaultPort(Network net) const
Definition: chainparams.h:92
unsigned char MessageStartChars[MESSAGE_START_SIZE]
Definition: protocol.h:36
Network address.
Definition: netaddress.h:120
bool SetSpecial(const std::string &addr)
Parse a Tor or I2P address and set this object to it.
Definition: netaddress.cpp:208
enum Network GetNetwork() const
Definition: netaddress.cpp:518
256-bit opaque blob.
Definition: uint256.h:105
std::map< int, const AssumeutxoData > MapAssumeutxo
Definition: chainparams.h:58
std::map< int, uint256 > MapCheckpoints
Definition: chainparams.h:27
static constexpr uint16_t I2P_SAM31_PORT
SAM 3.1 and earlier do not support specifying ports and force the port to 0.
Definition: netaddress.h:112
Network
A network type.
Definition: netaddress.h:44
@ NET_I2P
I2P.
Definition: netaddress.h:58
Holds configuration for use during UTXO snapshot load and validation.
Definition: chainparams.h:47
const AssumeutxoHash hash_serialized
The expected hash of the deserialized UTXO set.
Definition: chainparams.h:49
const unsigned int nChainTx
Used to populate the nChainTx value, which is used during BlockManager::LoadBlockIndex().
Definition: chainparams.h:55
AssumeutxoHash(const uint256 &hash)
Definition: chainparams.h:39
RegTestOptions holds configurations for creating a regtest CChainParams.
Definition: chainparams.h:155
std::unordered_map< Consensus::DeploymentPos, VersionBitsParameters > version_bits_parameters
Definition: chainparams.h:156
std::unordered_map< Consensus::BuriedDeployment, int > activation_heights
Definition: chainparams.h:157
SigNetOptions holds configurations for creating a signet CChainParams.
Definition: chainparams.h:138
std::optional< std::vector< uint8_t > > challenge
Definition: chainparams.h:139
std::optional< std::vector< std::string > > seeds
Definition: chainparams.h:140
VersionBitsParameters holds activation parameters.
Definition: chainparams.h:146
int GetHeight() const
Definition: chainparams.h:32
MapCheckpoints mapCheckpoints
Definition: chainparams.h:30
Holds various statistics on transactions within a chain.
Definition: chainparams.h:66
double dTxRate
estimated number of transactions per second after that timestamp
Definition: chainparams.h:69
int64_t nTime
UNIX timestamp of last known number of transactions.
Definition: chainparams.h:67
int64_t nTxCount
total number of transactions between genesis and that timestamp
Definition: chainparams.h:68
Parameters that influence chain consensus.
Definition: params.h:74
bool fPowNoRetargeting
Definition: params.h:111