Bitcoin Core  29.1.0
P2P Digital Currency
chainparams.cpp
Go to the documentation of this file.
1 // Copyright (c) 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 #include <kernel/chainparams.h>
7 
8 #include <chainparamsseeds.h>
9 #include <consensus/amount.h>
10 #include <consensus/merkle.h>
11 #include <consensus/params.h>
12 #include <hash.h>
14 #include <logging.h>
15 #include <primitives/block.h>
16 #include <primitives/transaction.h>
17 #include <script/interpreter.h>
18 #include <script/script.h>
19 #include <uint256.h>
20 #include <util/chaintype.h>
21 #include <util/strencodings.h>
22 
23 #include <algorithm>
24 #include <cassert>
25 #include <cstdint>
26 #include <cstring>
27 #include <type_traits>
28 
29 using namespace util::hex_literals;
30 
31 // Workaround MSVC bug triggering C7595 when calling consteval constructors in
32 // initializer lists.
33 // A fix may be on the way:
34 // https://developercommunity.visualstudio.com/t/consteval-conversion-function-fails/1579014
35 #if defined(_MSC_VER)
36 auto consteval_ctor(auto&& input) { return input; }
37 #else
38 #define consteval_ctor(input) (input)
39 #endif
40 
41 static CBlock CreateGenesisBlock(const char* pszTimestamp, const CScript& genesisOutputScript, uint32_t nTime, uint32_t nNonce, uint32_t nBits, int32_t nVersion, const CAmount& genesisReward)
42 {
43  CMutableTransaction txNew;
44  txNew.version = 1;
45  txNew.vin.resize(1);
46  txNew.vout.resize(1);
47  txNew.vin[0].scriptSig = CScript() << 486604799 << CScriptNum(4) << std::vector<unsigned char>((const unsigned char*)pszTimestamp, (const unsigned char*)pszTimestamp + strlen(pszTimestamp));
48  txNew.vout[0].nValue = genesisReward;
49  txNew.vout[0].scriptPubKey = genesisOutputScript;
50 
51  CBlock genesis;
52  genesis.nTime = nTime;
53  genesis.nBits = nBits;
54  genesis.nNonce = nNonce;
55  genesis.nVersion = nVersion;
56  genesis.vtx.push_back(MakeTransactionRef(std::move(txNew)));
57  genesis.hashPrevBlock.SetNull();
58  genesis.hashMerkleRoot = BlockMerkleRoot(genesis);
59  return genesis;
60 }
61 
73 static CBlock CreateGenesisBlock(uint32_t nTime, uint32_t nNonce, uint32_t nBits, int32_t nVersion, const CAmount& genesisReward)
74 {
75  const char* pszTimestamp = "The Times 03/Jan/2009 Chancellor on brink of second bailout for banks";
76  const CScript genesisOutputScript = CScript() << "04678afdb0fe5548271967f1a67130b7105cd6a828e03909a67962e0ea1f61deb649f6bc3f4cef38c4f35504e51ec112de5c384df7ba0b8d578a4c702b6bf11d5f"_hex << OP_CHECKSIG;
77  return CreateGenesisBlock(pszTimestamp, genesisOutputScript, nTime, nNonce, nBits, nVersion, genesisReward);
78 }
79 
83 class CMainParams : public CChainParams {
84 public:
86  m_chain_type = ChainType::MAIN;
87  consensus.signet_blocks = false;
88  consensus.signet_challenge.clear();
89  consensus.nSubsidyHalvingInterval = 210000;
90  consensus.script_flag_exceptions.emplace( // BIP16 exception
91  uint256{"00000000000002dc756eebf4f49723ed8d30cc28a5f108eb94b1ba88ac4f9c22"}, SCRIPT_VERIFY_NONE);
92  consensus.script_flag_exceptions.emplace( // Taproot exception
93  uint256{"0000000000000000000f14c35b2d841e986ab5441de8c585d5ffe55ea1e395ad"}, SCRIPT_VERIFY_P2SH | SCRIPT_VERIFY_WITNESS);
94  consensus.BIP34Height = 227931;
95  consensus.BIP34Hash = uint256{"000000000000024b89b42a942fe0d9fea3bb44ab7bd1b19115dd6a759c0808b8"};
96  consensus.BIP65Height = 388381; // 000000000000000004c2b624ed5d7756c508d90fd0da2c7c679febfa6c4735f0
97  consensus.BIP66Height = 363725; // 00000000000000000379eaa19dce8c9b722d46ae6a57c2f1a988119488b50931
98  consensus.CSVHeight = 419328; // 000000000000000004a1b34462cb8aeebd5799177f7a29cf28f2d1961716b5b5
99  consensus.SegwitHeight = 481824; // 0000000000000000001c8018d9cb3b742ef25114f27563e3fc4a1902167f9893
100  consensus.MinBIP9WarningHeight = 483840; // segwit activation height + miner confirmation window
101  consensus.powLimit = uint256{"00000000ffffffffffffffffffffffffffffffffffffffffffffffffffffffff"};
102  consensus.nPowTargetTimespan = 14 * 24 * 60 * 60; // two weeks
103  consensus.nPowTargetSpacing = 10 * 60;
104  consensus.fPowAllowMinDifficultyBlocks = false;
105  consensus.enforce_BIP94 = false;
106  consensus.fPowNoRetargeting = false;
107  consensus.nRuleChangeActivationThreshold = 1815; // 90% of 2016
108  consensus.nMinerConfirmationWindow = 2016; // nPowTargetTimespan / nPowTargetSpacing
109  consensus.vDeployments[Consensus::DEPLOYMENT_TESTDUMMY].bit = 28;
112  consensus.vDeployments[Consensus::DEPLOYMENT_TESTDUMMY].min_activation_height = 0; // No activation delay
113 
114  // Deployment of Taproot (BIPs 340-342)
115  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].bit = 2;
116  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].nStartTime = 1619222400; // April 24th, 2021
117  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].nTimeout = 1628640000; // August 11th, 2021
118  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].min_activation_height = 709632; // Approximately November 12th, 2021
119 
120  consensus.nMinimumChainWork = uint256{"0000000000000000000000000000000000000000b1f3b93b65b16d035a82be84"};
121  consensus.defaultAssumeValid = uint256{"00000000000000000001b658dd1120e82e66d2790811f89ede9742ada3ed6d77"}; // 886157
122 
128  pchMessageStart[0] = 0xf9;
129  pchMessageStart[1] = 0xbe;
130  pchMessageStart[2] = 0xb4;
131  pchMessageStart[3] = 0xd9;
132  nDefaultPort = 8333;
133  nPruneAfterHeight = 100000;
134  m_assumed_blockchain_size = 720;
135  m_assumed_chain_state_size = 14;
136 
137  genesis = CreateGenesisBlock(1231006505, 2083236893, 0x1d00ffff, 1, 50 * COIN);
138  consensus.hashGenesisBlock = genesis.GetHash();
139  assert(consensus.hashGenesisBlock == uint256{"000000000019d6689c085ae165831e934ff763ae46a2a6c172b3f1b60a8ce26f"});
140  assert(genesis.hashMerkleRoot == uint256{"4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b"});
141 
142  // Note that of those which support the service bits prefix, most only support a subset of
143  // possible options.
144  // This is fine at runtime as we'll fall back to using them as an addrfetch if they don't support the
145  // service bits we want, but we should get them updated to support all service bits wanted by any
146  // release ASAP to avoid it where possible.
147  vSeeds.emplace_back("seed.bitcoin.sipa.be."); // Pieter Wuille, only supports x1, x5, x9, and xd
148  vSeeds.emplace_back("dnsseed.bluematt.me."); // Matt Corallo, only supports x9
149  vSeeds.emplace_back("dnsseed.bitcoin.dashjr-list-of-p2p-nodes.us."); // Luke Dashjr
150  vSeeds.emplace_back("seed.bitcoin.jonasschnelli.ch."); // Jonas Schnelli, only supports x1, x5, x9, and xd
151  vSeeds.emplace_back("seed.btc.petertodd.net."); // Peter Todd, only supports x1, x5, x9, and xd
152  vSeeds.emplace_back("seed.bitcoin.sprovoost.nl."); // Sjors Provoost
153  vSeeds.emplace_back("dnsseed.emzy.de."); // Stephan Oeste
154  vSeeds.emplace_back("seed.bitcoin.wiz.biz."); // Jason Maurice
155  vSeeds.emplace_back("seed.mainnet.achownodes.xyz."); // Ava Chow, only supports x1, x5, x9, x49, x809, x849, xd, x400, x404, x408, x448, xc08, xc48, x40c
156 
157  base58Prefixes[PUBKEY_ADDRESS] = std::vector<unsigned char>(1,0);
158  base58Prefixes[SCRIPT_ADDRESS] = std::vector<unsigned char>(1,5);
159  base58Prefixes[SECRET_KEY] = std::vector<unsigned char>(1,128);
160  base58Prefixes[EXT_PUBLIC_KEY] = {0x04, 0x88, 0xB2, 0x1E};
161  base58Prefixes[EXT_SECRET_KEY] = {0x04, 0x88, 0xAD, 0xE4};
162 
163  bech32_hrp = "bc";
164 
165  vFixedSeeds = std::vector<uint8_t>(std::begin(chainparams_seed_main), std::end(chainparams_seed_main));
166 
167  fDefaultConsistencyChecks = false;
168  m_is_mockable_chain = false;
169 
170  checkpointData = {
171  {
172  { 11111, uint256{"0000000069e244f73d78e8fd29ba2fd2ed618bd6fa2ee92559f542fdb26e7c1d"}},
173  { 33333, uint256{"000000002dd5588a74784eaa7ab0507a18ad16a236e7b1ce69f00d7ddfb5d0a6"}},
174  { 74000, uint256{"0000000000573993a3c9e41ce34471c079dcf5f52a0e824a81e7f953b8661a20"}},
175  {105000, uint256{"00000000000291ce28027faea320c8d2b054b2e0fe44a773f3eefb151d6bdc97"}},
176  {134444, uint256{"00000000000005b12ffd4cd315cd34ffd4a594f430ac814c91184a0d42d2b0fe"}},
177  {168000, uint256{"000000000000099e61ea72015e79632f216fe6cb33d7899acb35b75c8303b763"}},
178  {193000, uint256{"000000000000059f452a5f7340de6682a977387c17010ff6e6c3bd83ca8b1317"}},
179  {210000, uint256{"000000000000048b95347e83192f69cf0366076336c639f9b7228e9ba171342e"}},
180  {216116, uint256{"00000000000001b4f4b433e81ee46494af945cf96014816a4e2370f11b23df4e"}},
181  {225430, uint256{"00000000000001c108384350f74090433e7fcf79a606b8e797f065b130575932"}},
182  {250000, uint256{"000000000000003887df1f29024b06fc2200b55f8af8f35453d7be294df2d214"}},
183  {279000, uint256{"0000000000000001ae8c72a0b0c301f67e3afca10e819efa9041e458e9bd7e40"}},
184  {295000, uint256{"00000000000000004d9b4ef50f0f9d686fd69db2e03af35a100370c64632a983"}},
185  }
186  };
187 
188  m_assumeutxo_data = {
189  {
190  .height = 840'000,
191  .hash_serialized = AssumeutxoHash{uint256{"a2a5521b1b5ab65f67818e5e8eccabb7171a517f9e2382208f77687310768f96"}},
192  .m_chain_tx_count = 991032194,
193  .blockhash = consteval_ctor(uint256{"0000000000000000000320283a032748cef8227873ff4872689bf23f1cda83a5"}),
194  },
195  {
196  .height = 880'000,
197  .hash_serialized = AssumeutxoHash{uint256{"dbd190983eaf433ef7c15f78a278ae42c00ef52e0fd2a54953782175fbadcea9"}},
198  .m_chain_tx_count = 1145604538,
199  .blockhash = consteval_ctor(uint256{"000000000000000000010b17283c3c400507969a9c2afd1dcf2082ec5cca2880"}),
200  }
201  };
202 
203  chainTxData = ChainTxData{
204  // Data from RPC: getchaintxstats 4096 00000000000000000001b658dd1120e82e66d2790811f89ede9742ada3ed6d77
205  .nTime = 1741017141,
206  .tx_count = 1161875261,
207  .dTxRate = 4.620728156243148,
208  };
209  }
210 };
211 
215 class CTestNetParams : public CChainParams {
216 public:
218  m_chain_type = ChainType::TESTNET;
219  consensus.signet_blocks = false;
220  consensus.signet_challenge.clear();
221  consensus.nSubsidyHalvingInterval = 210000;
222  consensus.script_flag_exceptions.emplace( // BIP16 exception
223  uint256{"00000000dd30457c001f4095d208cc1296b0eed002427aa599874af7a432b105"}, SCRIPT_VERIFY_NONE);
224  consensus.BIP34Height = 21111;
225  consensus.BIP34Hash = uint256{"0000000023b3a96d3484e5abb3755c413e7d41500f8e2a5c3f0dd01299cd8ef8"};
226  consensus.BIP65Height = 581885; // 00000000007f6655f22f98e72ed80d8b06dc761d5da09df0fa1dc4be4f861eb6
227  consensus.BIP66Height = 330776; // 000000002104c8c45e99a8853285a3b592602a3ccde2b832481da85e9e4ba182
228  consensus.CSVHeight = 770112; // 00000000025e930139bac5c6c31a403776da130831ab85be56578f3fa75369bb
229  consensus.SegwitHeight = 834624; // 00000000002b980fcd729daaa248fd9316a5200e9b367f4ff2c42453e84201ca
230  consensus.MinBIP9WarningHeight = 836640; // segwit activation height + miner confirmation window
231  consensus.powLimit = uint256{"00000000ffffffffffffffffffffffffffffffffffffffffffffffffffffffff"};
232  consensus.nPowTargetTimespan = 14 * 24 * 60 * 60; // two weeks
233  consensus.nPowTargetSpacing = 10 * 60;
234  consensus.fPowAllowMinDifficultyBlocks = true;
235  consensus.enforce_BIP94 = false;
236  consensus.fPowNoRetargeting = false;
237  consensus.nRuleChangeActivationThreshold = 1512; // 75% for testchains
238  consensus.nMinerConfirmationWindow = 2016; // nPowTargetTimespan / nPowTargetSpacing
239  consensus.vDeployments[Consensus::DEPLOYMENT_TESTDUMMY].bit = 28;
242  consensus.vDeployments[Consensus::DEPLOYMENT_TESTDUMMY].min_activation_height = 0; // No activation delay
243 
244  // Deployment of Taproot (BIPs 340-342)
245  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].bit = 2;
246  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].nStartTime = 1619222400; // April 24th, 2021
247  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].nTimeout = 1628640000; // August 11th, 2021
248  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].min_activation_height = 0; // No activation delay
249 
250  consensus.nMinimumChainWork = uint256{"0000000000000000000000000000000000000000000015f5e0c9f13455b0eb17"};
251  consensus.defaultAssumeValid = uint256{"00000000000003fc7967410ba2d0a8a8d50daedc318d43e8baf1a9782c236a57"}; // 3974606
252 
253  pchMessageStart[0] = 0x0b;
254  pchMessageStart[1] = 0x11;
255  pchMessageStart[2] = 0x09;
256  pchMessageStart[3] = 0x07;
257  nDefaultPort = 18333;
258  nPruneAfterHeight = 1000;
259  m_assumed_blockchain_size = 200;
260  m_assumed_chain_state_size = 19;
261 
262  genesis = CreateGenesisBlock(1296688602, 414098458, 0x1d00ffff, 1, 50 * COIN);
263  consensus.hashGenesisBlock = genesis.GetHash();
264  assert(consensus.hashGenesisBlock == uint256{"000000000933ea01ad0ee984209779baaec3ced90fa3f408719526f8d77f4943"});
265  assert(genesis.hashMerkleRoot == uint256{"4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b"});
266 
267  vFixedSeeds.clear();
268  vSeeds.clear();
269  // nodes with support for servicebits filtering should be at the top
270  vSeeds.emplace_back("testnet-seed.bitcoin.jonasschnelli.ch.");
271  vSeeds.emplace_back("seed.tbtc.petertodd.net.");
272  vSeeds.emplace_back("seed.testnet.bitcoin.sprovoost.nl.");
273  vSeeds.emplace_back("testnet-seed.bluematt.me."); // Just a static list of stable node(s), only supports x9
274  vSeeds.emplace_back("seed.testnet.achownodes.xyz."); // Ava Chow, only supports x1, x5, x9, x49, x809, x849, xd, x400, x404, x408, x448, xc08, xc48, x40c
275 
276  base58Prefixes[PUBKEY_ADDRESS] = std::vector<unsigned char>(1,111);
277  base58Prefixes[SCRIPT_ADDRESS] = std::vector<unsigned char>(1,196);
278  base58Prefixes[SECRET_KEY] = std::vector<unsigned char>(1,239);
279  base58Prefixes[EXT_PUBLIC_KEY] = {0x04, 0x35, 0x87, 0xCF};
280  base58Prefixes[EXT_SECRET_KEY] = {0x04, 0x35, 0x83, 0x94};
281 
282  bech32_hrp = "tb";
283 
284  vFixedSeeds = std::vector<uint8_t>(std::begin(chainparams_seed_test), std::end(chainparams_seed_test));
285 
286  fDefaultConsistencyChecks = false;
287  m_is_mockable_chain = false;
288 
289  checkpointData = {
290  {
291  {546, uint256{"000000002a936ca763904c3c35fce2f3556c559c0214345d31b1bcebf76acb70"}},
292  }
293  };
294 
295  m_assumeutxo_data = {
296  {
297  .height = 2'500'000,
298  .hash_serialized = AssumeutxoHash{uint256{"f841584909f68e47897952345234e37fcd9128cd818f41ee6c3ca68db8071be7"}},
299  .m_chain_tx_count = 66484552,
300  .blockhash = consteval_ctor(uint256{"0000000000000093bcb68c03a9a168ae252572d348a2eaeba2cdf9231d73206f"}),
301  }
302  };
303 
304  chainTxData = ChainTxData{
305  // Data from RPC: getchaintxstats 4096 00000000000003fc7967410ba2d0a8a8d50daedc318d43e8baf1a9782c236a57
306  .nTime = 1741042082,
307  .tx_count = 475477615,
308  .dTxRate = 17.15933950357594,
309  };
310  }
311 };
312 
317 public:
319  m_chain_type = ChainType::TESTNET4;
320  consensus.signet_blocks = false;
321  consensus.signet_challenge.clear();
322  consensus.nSubsidyHalvingInterval = 210000;
323  consensus.BIP34Height = 1;
324  consensus.BIP34Hash = uint256{};
325  consensus.BIP65Height = 1;
326  consensus.BIP66Height = 1;
327  consensus.CSVHeight = 1;
328  consensus.SegwitHeight = 1;
329  consensus.MinBIP9WarningHeight = 0;
330  consensus.powLimit = uint256{"00000000ffffffffffffffffffffffffffffffffffffffffffffffffffffffff"};
331  consensus.nPowTargetTimespan = 14 * 24 * 60 * 60; // two weeks
332  consensus.nPowTargetSpacing = 10 * 60;
333  consensus.fPowAllowMinDifficultyBlocks = true;
334  consensus.enforce_BIP94 = true;
335  consensus.fPowNoRetargeting = false;
336  consensus.nRuleChangeActivationThreshold = 1512; // 75% for testchains
337  consensus.nMinerConfirmationWindow = 2016; // nPowTargetTimespan / nPowTargetSpacing
338  consensus.vDeployments[Consensus::DEPLOYMENT_TESTDUMMY].bit = 28;
341  consensus.vDeployments[Consensus::DEPLOYMENT_TESTDUMMY].min_activation_height = 0; // No activation delay
342 
343  // Deployment of Taproot (BIPs 340-342)
344  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].bit = 2;
345  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].nStartTime = Consensus::BIP9Deployment::ALWAYS_ACTIVE;
346  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].nTimeout = Consensus::BIP9Deployment::NO_TIMEOUT;
347  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].min_activation_height = 0; // No activation delay
348 
349  consensus.nMinimumChainWork = uint256{"0000000000000000000000000000000000000000000001d6dce8651b6094e4c1"};
350  consensus.defaultAssumeValid = uint256{"0000000000003ed4f08dbdf6f7d6b271a6bcffce25675cb40aa9fa43179a89f3"}; // 72600
351 
352  pchMessageStart[0] = 0x1c;
353  pchMessageStart[1] = 0x16;
354  pchMessageStart[2] = 0x3f;
355  pchMessageStart[3] = 0x28;
356  nDefaultPort = 48333;
357  nPruneAfterHeight = 1000;
358  m_assumed_blockchain_size = 11;
359  m_assumed_chain_state_size = 1;
360 
361  const char* testnet4_genesis_msg = "03/May/2024 000000000000000000001ebd58c244970b3aa9d783bb001011fbe8ea8e98e00e";
362  const CScript testnet4_genesis_script = CScript() << "000000000000000000000000000000000000000000000000000000000000000000"_hex << OP_CHECKSIG;
363  genesis = CreateGenesisBlock(testnet4_genesis_msg,
364  testnet4_genesis_script,
365  1714777860,
366  393743547,
367  0x1d00ffff,
368  1,
369  50 * COIN);
370  consensus.hashGenesisBlock = genesis.GetHash();
371  assert(consensus.hashGenesisBlock == uint256{"00000000da84f2bafbbc53dee25a72ae507ff4914b867c565be350b0da8bf043"});
372  assert(genesis.hashMerkleRoot == uint256{"7aa0a7ae1e223414cb807e40cd57e667b718e42aaf9306db9102fe28912b7b4e"});
373 
374  vFixedSeeds.clear();
375  vSeeds.clear();
376  // nodes with support for servicebits filtering should be at the top
377  vSeeds.emplace_back("seed.testnet4.bitcoin.sprovoost.nl."); // Sjors Provoost
378  vSeeds.emplace_back("seed.testnet4.wiz.biz."); // Jason Maurice
379 
380  base58Prefixes[PUBKEY_ADDRESS] = std::vector<unsigned char>(1,111);
381  base58Prefixes[SCRIPT_ADDRESS] = std::vector<unsigned char>(1,196);
382  base58Prefixes[SECRET_KEY] = std::vector<unsigned char>(1,239);
383  base58Prefixes[EXT_PUBLIC_KEY] = {0x04, 0x35, 0x87, 0xCF};
384  base58Prefixes[EXT_SECRET_KEY] = {0x04, 0x35, 0x83, 0x94};
385 
386  bech32_hrp = "tb";
387 
388  vFixedSeeds = std::vector<uint8_t>(std::begin(chainparams_seed_testnet4), std::end(chainparams_seed_testnet4));
389 
390  fDefaultConsistencyChecks = false;
391  m_is_mockable_chain = false;
392 
393  checkpointData = {
394  {
395  {},
396  }
397  };
398 
399  m_assumeutxo_data = {
400  {}
401  };
402 
403  chainTxData = ChainTxData{
404  // Data from RPC: getchaintxstats 4096 0000000000003ed4f08dbdf6f7d6b271a6bcffce25675cb40aa9fa43179a89f3
405  .nTime = 1741070246,
406  .tx_count = 7653966,
407  .dTxRate = 1.239174414591965,
408  };
409  }
410 };
411 
415 class SigNetParams : public CChainParams {
416 public:
417  explicit SigNetParams(const SigNetOptions& options)
418  {
419  std::vector<uint8_t> bin;
420  vFixedSeeds.clear();
421  vSeeds.clear();
422 
423  if (!options.challenge) {
424  bin = "512103ad5e0edad18cb1f0fc0d28a3d4f1f3e445640337489abb10404f2d1e086be430210359ef5021964fe22d6f8e05b2463c9540ce96883fe3b278760f048f5189f2e6c452ae"_hex_v_u8;
425  vFixedSeeds = std::vector<uint8_t>(std::begin(chainparams_seed_signet), std::end(chainparams_seed_signet));
426  vSeeds.emplace_back("seed.signet.bitcoin.sprovoost.nl.");
427  vSeeds.emplace_back("seed.signet.achownodes.xyz."); // Ava Chow, only supports x1, x5, x9, x49, x809, x849, xd, x400, x404, x408, x448, xc08, xc48, x40c
428 
429  consensus.nMinimumChainWork = uint256{"000000000000000000000000000000000000000000000000000002b517f3d1a1"};
430  consensus.defaultAssumeValid = uint256{"000000895a110f46e59eb82bbc5bfb67fa314656009c295509c21b4999f5180a"}; // 237722
431  m_assumed_blockchain_size = 9;
432  m_assumed_chain_state_size = 1;
433  chainTxData = ChainTxData{
434  // Data from RPC: getchaintxstats 4096 000000895a110f46e59eb82bbc5bfb67fa314656009c295509c21b4999f5180a
435  .nTime = 1741019645,
436  .tx_count = 16540736,
437  .dTxRate = 1.064918879911595,
438  };
439  } else {
440  bin = *options.challenge;
441  consensus.nMinimumChainWork = uint256{};
442  consensus.defaultAssumeValid = uint256{};
443  m_assumed_blockchain_size = 0;
444  m_assumed_chain_state_size = 0;
445  chainTxData = ChainTxData{
446  0,
447  0,
448  0,
449  };
450  LogPrintf("Signet with challenge %s\n", HexStr(bin));
451  }
452 
453  if (options.seeds) {
454  vSeeds = *options.seeds;
455  }
456 
457  m_chain_type = ChainType::SIGNET;
458  consensus.signet_blocks = true;
459  consensus.signet_challenge.assign(bin.begin(), bin.end());
460  consensus.nSubsidyHalvingInterval = 210000;
461  consensus.BIP34Height = 1;
462  consensus.BIP34Hash = uint256{};
463  consensus.BIP65Height = 1;
464  consensus.BIP66Height = 1;
465  consensus.CSVHeight = 1;
466  consensus.SegwitHeight = 1;
467  consensus.nPowTargetTimespan = 14 * 24 * 60 * 60; // two weeks
468  consensus.nPowTargetSpacing = 10 * 60;
469  consensus.fPowAllowMinDifficultyBlocks = false;
470  consensus.enforce_BIP94 = false;
471  consensus.fPowNoRetargeting = false;
472  consensus.nRuleChangeActivationThreshold = 1815; // 90% of 2016
473  consensus.nMinerConfirmationWindow = 2016; // nPowTargetTimespan / nPowTargetSpacing
474  consensus.MinBIP9WarningHeight = 0;
475  consensus.powLimit = uint256{"00000377ae000000000000000000000000000000000000000000000000000000"};
476  consensus.vDeployments[Consensus::DEPLOYMENT_TESTDUMMY].bit = 28;
479  consensus.vDeployments[Consensus::DEPLOYMENT_TESTDUMMY].min_activation_height = 0; // No activation delay
480 
481  // Activation of Taproot (BIPs 340-342)
482  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].bit = 2;
483  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].nStartTime = Consensus::BIP9Deployment::ALWAYS_ACTIVE;
484  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].nTimeout = Consensus::BIP9Deployment::NO_TIMEOUT;
485  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].min_activation_height = 0; // No activation delay
486 
487  // message start is defined as the first 4 bytes of the sha256d of the block script
488  HashWriter h{};
489  h << consensus.signet_challenge;
490  uint256 hash = h.GetHash();
491  std::copy_n(hash.begin(), 4, pchMessageStart.begin());
492 
493  nDefaultPort = 38333;
494  nPruneAfterHeight = 1000;
495 
496  genesis = CreateGenesisBlock(1598918400, 52613770, 0x1e0377ae, 1, 50 * COIN);
497  consensus.hashGenesisBlock = genesis.GetHash();
498  assert(consensus.hashGenesisBlock == uint256{"00000008819873e925422c1ff0f99f7cc9bbb232af63a077a480a3633bee1ef6"});
499  assert(genesis.hashMerkleRoot == uint256{"4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b"});
500 
501  m_assumeutxo_data = {
502  {
503  .height = 160'000,
504  .hash_serialized = AssumeutxoHash{uint256{"fe0a44309b74d6b5883d246cb419c6221bcccf0b308c9b59b7d70783dbdf928a"}},
505  .m_chain_tx_count = 2289496,
506  .blockhash = consteval_ctor(uint256{"0000003ca3c99aff040f2563c2ad8f8ec88bd0fd6b8f0895cfaf1ef90353a62c"}),
507  }
508  };
509 
510  base58Prefixes[PUBKEY_ADDRESS] = std::vector<unsigned char>(1,111);
511  base58Prefixes[SCRIPT_ADDRESS] = std::vector<unsigned char>(1,196);
512  base58Prefixes[SECRET_KEY] = std::vector<unsigned char>(1,239);
513  base58Prefixes[EXT_PUBLIC_KEY] = {0x04, 0x35, 0x87, 0xCF};
514  base58Prefixes[EXT_SECRET_KEY] = {0x04, 0x35, 0x83, 0x94};
515 
516  bech32_hrp = "tb";
517 
518  fDefaultConsistencyChecks = false;
519  m_is_mockable_chain = false;
520  }
521 };
522 
527 class CRegTestParams : public CChainParams
528 {
529 public:
530  explicit CRegTestParams(const RegTestOptions& opts)
531  {
532  m_chain_type = ChainType::REGTEST;
533  consensus.signet_blocks = false;
534  consensus.signet_challenge.clear();
535  consensus.nSubsidyHalvingInterval = 150;
536  consensus.BIP34Height = 1; // Always active unless overridden
537  consensus.BIP34Hash = uint256();
538  consensus.BIP65Height = 1; // Always active unless overridden
539  consensus.BIP66Height = 1; // Always active unless overridden
540  consensus.CSVHeight = 1; // Always active unless overridden
541  consensus.SegwitHeight = 0; // Always active unless overridden
542  consensus.MinBIP9WarningHeight = 0;
543  consensus.powLimit = uint256{"7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"};
544  consensus.nPowTargetTimespan = 24 * 60 * 60; // one day
545  consensus.nPowTargetSpacing = 10 * 60;
546  consensus.fPowAllowMinDifficultyBlocks = true;
547  consensus.enforce_BIP94 = opts.enforce_bip94;
548  consensus.fPowNoRetargeting = true;
549  consensus.nRuleChangeActivationThreshold = 108; // 75% for testchains
550  consensus.nMinerConfirmationWindow = 144; // Faster than normal for regtest (144 instead of 2016)
551 
552  consensus.vDeployments[Consensus::DEPLOYMENT_TESTDUMMY].bit = 28;
553  consensus.vDeployments[Consensus::DEPLOYMENT_TESTDUMMY].nStartTime = 0;
554  consensus.vDeployments[Consensus::DEPLOYMENT_TESTDUMMY].nTimeout = Consensus::BIP9Deployment::NO_TIMEOUT;
555  consensus.vDeployments[Consensus::DEPLOYMENT_TESTDUMMY].min_activation_height = 0; // No activation delay
556 
557  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].bit = 2;
558  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].nStartTime = Consensus::BIP9Deployment::ALWAYS_ACTIVE;
559  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].nTimeout = Consensus::BIP9Deployment::NO_TIMEOUT;
560  consensus.vDeployments[Consensus::DEPLOYMENT_TAPROOT].min_activation_height = 0; // No activation delay
561 
562  consensus.nMinimumChainWork = uint256{};
563  consensus.defaultAssumeValid = uint256{};
564 
565  pchMessageStart[0] = 0xfa;
566  pchMessageStart[1] = 0xbf;
567  pchMessageStart[2] = 0xb5;
568  pchMessageStart[3] = 0xda;
569  nDefaultPort = 18444;
570  nPruneAfterHeight = opts.fastprune ? 100 : 1000;
571  m_assumed_blockchain_size = 0;
572  m_assumed_chain_state_size = 0;
573 
574  for (const auto& [dep, height] : opts.activation_heights) {
575  switch (dep) {
576  case Consensus::BuriedDeployment::DEPLOYMENT_SEGWIT:
577  consensus.SegwitHeight = int{height};
578  break;
579  case Consensus::BuriedDeployment::DEPLOYMENT_HEIGHTINCB:
580  consensus.BIP34Height = int{height};
581  break;
582  case Consensus::BuriedDeployment::DEPLOYMENT_DERSIG:
583  consensus.BIP66Height = int{height};
584  break;
585  case Consensus::BuriedDeployment::DEPLOYMENT_CLTV:
586  consensus.BIP65Height = int{height};
587  break;
588  case Consensus::BuriedDeployment::DEPLOYMENT_CSV:
589  consensus.CSVHeight = int{height};
590  break;
591  }
592  }
593 
594  for (const auto& [deployment_pos, version_bits_params] : opts.version_bits_parameters) {
595  consensus.vDeployments[deployment_pos].nStartTime = version_bits_params.start_time;
596  consensus.vDeployments[deployment_pos].nTimeout = version_bits_params.timeout;
597  consensus.vDeployments[deployment_pos].min_activation_height = version_bits_params.min_activation_height;
598  }
599 
600  genesis = CreateGenesisBlock(1296688602, 2, 0x207fffff, 1, 50 * COIN);
601  consensus.hashGenesisBlock = genesis.GetHash();
602  assert(consensus.hashGenesisBlock == uint256{"0f9188f13cb7b2c71f2a335e3a4fc328bf5beb436012afca590b1a11466e2206"});
603  assert(genesis.hashMerkleRoot == uint256{"4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b7afdeda33b"});
604 
605  vFixedSeeds.clear(); //!< Regtest mode doesn't have any fixed seeds.
606  vSeeds.clear();
607  vSeeds.emplace_back("dummySeed.invalid.");
608 
609  fDefaultConsistencyChecks = true;
610  m_is_mockable_chain = true;
611 
612  checkpointData = {
613  {
614  {0, uint256{"0f9188f13cb7b2c71f2a335e3a4fc328bf5beb436012afca590b1a11466e2206"}},
615  }
616  };
617 
618  m_assumeutxo_data = {
619  { // For use by unit tests
620  .height = 110,
621  .hash_serialized = AssumeutxoHash{uint256{"6657b736d4fe4db0cbc796789e812d5dba7f5c143764b1b6905612f1830609d1"}},
622  .m_chain_tx_count = 111,
623  .blockhash = consteval_ctor(uint256{"696e92821f65549c7ee134edceeeeaaa4105647a3c4fd9f298c0aec0ab50425c"}),
624  },
625  {
626  // For use by fuzz target src/test/fuzz/utxo_snapshot.cpp
627  .height = 200,
628  .hash_serialized = AssumeutxoHash{uint256{"4f34d431c3e482f6b0d67b64609ece3964dc8d7976d02ac68dd7c9c1421738f2"}},
629  .m_chain_tx_count = 201,
630  .blockhash = consteval_ctor(uint256{"5e93653318f294fb5aa339d00bbf8cf1c3515488ad99412c37608b139ea63b27"}),
631  },
632  {
633  // For use by test/functional/feature_assumeutxo.py
634  .height = 299,
635  .hash_serialized = AssumeutxoHash{uint256{"a4bf3407ccb2cc0145c49ebba8fa91199f8a3903daf0883875941497d2493c27"}},
636  .m_chain_tx_count = 334,
637  .blockhash = consteval_ctor(uint256{"3bb7ce5eba0be48939b7a521ac1ba9316afee2c7bada3a0cca24188e6d7d96c0"}),
638  },
639  };
640 
641  chainTxData = ChainTxData{
642  0,
643  0,
644  0
645  };
646 
647  base58Prefixes[PUBKEY_ADDRESS] = std::vector<unsigned char>(1,111);
648  base58Prefixes[SCRIPT_ADDRESS] = std::vector<unsigned char>(1,196);
649  base58Prefixes[SECRET_KEY] = std::vector<unsigned char>(1,239);
650  base58Prefixes[EXT_PUBLIC_KEY] = {0x04, 0x35, 0x87, 0xCF};
651  base58Prefixes[EXT_SECRET_KEY] = {0x04, 0x35, 0x83, 0x94};
652 
653  bech32_hrp = "bcrt";
654  }
655 };
656 
657 std::unique_ptr<const CChainParams> CChainParams::SigNet(const SigNetOptions& options)
658 {
659  return std::make_unique<const SigNetParams>(options);
660 }
661 
662 std::unique_ptr<const CChainParams> CChainParams::RegTest(const RegTestOptions& options)
663 {
664  return std::make_unique<const CRegTestParams>(options);
665 }
666 
667 std::unique_ptr<const CChainParams> CChainParams::Main()
668 {
669  return std::make_unique<const CMainParams>();
670 }
671 
672 std::unique_ptr<const CChainParams> CChainParams::TestNet()
673 {
674  return std::make_unique<const CTestNetParams>();
675 }
676 
677 std::unique_ptr<const CChainParams> CChainParams::TestNet4()
678 {
679  return std::make_unique<const CTestNet4Params>();
680 }
681 
683 {
684  std::vector<int> heights;
685  heights.reserve(m_assumeutxo_data.size());
686 
687  for (const auto& data : m_assumeutxo_data) {
688  heights.emplace_back(data.height);
689  }
690  return heights;
691 }
692 
693 std::optional<ChainType> GetNetworkForMagic(const MessageStartChars& message)
694 {
695  const auto mainnet_msg = CChainParams::Main()->MessageStart();
696  const auto testnet_msg = CChainParams::TestNet()->MessageStart();
697  const auto testnet4_msg = CChainParams::TestNet4()->MessageStart();
698  const auto regtest_msg = CChainParams::RegTest({})->MessageStart();
699  const auto signet_msg = CChainParams::SigNet({})->MessageStart();
700 
701  if (std::ranges::equal(message, mainnet_msg)) {
702  return ChainType::MAIN;
703  } else if (std::ranges::equal(message, testnet_msg)) {
704  return ChainType::TESTNET;
705  } else if (std::ranges::equal(message, testnet4_msg)) {
706  return ChainType::TESTNET4;
707  } else if (std::ranges::equal(message, regtest_msg)) {
708  return ChainType::REGTEST;
709  } else if (std::ranges::equal(message, signet_msg)) {
710  return ChainType::SIGNET;
711  }
712  return std::nullopt;
713 }
uint32_t nNonce
Definition: block.h:30
static constexpr int64_t NO_TIMEOUT
Constant for nTimeout very far in the future.
Definition: params.h:57
static std::unique_ptr< const CChainParams > TestNet4()
Main network on which people trade goods and services.
Definition: chainparams.cpp:83
assert(!tx.IsCoinBase())
Definition: block.h:68
static const uint8_t chainparams_seed_testnet4[]
std::vector< CTxIn > vin
Definition: transaction.h:379
static constexpr int64_t ALWAYS_ACTIVE
Special value for nStartTime indicating that the deployment is always active.
Definition: params.h:63
static const uint8_t chainparams_seed_test[]
CChainParams defines various tweakable parameters of a given instance of the Bitcoin system...
Definition: chainparams.h:80
int64_t nTime
UNIX timestamp of last known number of transactions.
Definition: chainparams.h:71
Testnet (v4): public test network which is reset from time to time.
uint32_t nTime
Definition: block.h:28
static std::unique_ptr< const CChainParams > Main()
static std::unique_ptr< const CChainParams > RegTest(const RegTestOptions &options)
constexpr unsigned char * begin()
Definition: uint256.h:115
int64_t CAmount
Amount in satoshis (Can be negative)
Definition: amount.h:12
std::array< uint8_t, 4 > MessageStartChars
Signet: test network with an additional consensus parameter (see BIP325).
std::vector< int > GetAvailableSnapshotHeights() const
static const uint8_t chainparams_seed_main[]
List of fixed seed nodes for the bitcoin network AUTOGENERATED by contrib/seeds/generate-seeds.py.
SigNetParams(const SigNetOptions &options)
uint256 hashMerkleRoot
Definition: block.h:27
static const uint8_t chainparams_seed_signet[]
A writer stream (for serialization) that computes a 256-bit hash.
Definition: hash.h:100
uint256 hashPrevBlock
Definition: block.h:26
Holds various statistics on transactions within a chain.
Definition: chainparams.h:70
RegTestOptions holds configurations for creating a regtest CChainParams.
Definition: chainparams.h:154
std::optional< std::vector< std::string > > seeds
Definition: chainparams.h:139
static constexpr int64_t NEVER_ACTIVE
Special value for nStartTime indicating that the deployment is never active.
Definition: params.h:68
uint256 BlockMerkleRoot(const CBlock &block, bool *mutated)
Definition: merkle.cpp:66
""_hex is a compile-time user-defined literal returning a std::array<std::byte>, equivalent to ParseH...
Definition: strencodings.h:427
std::vector< CTxOut > vout
Definition: transaction.h:380
SigNetOptions holds configurations for creating a signet CChainParams.
Definition: chainparams.h:137
static CTransactionRef MakeTransactionRef(Tx &&txIn)
Definition: transaction.h:424
Testnet (v3): public test network which is reset from time to time.
256-bit opaque blob.
Definition: uint256.h:201
std::vector< CTransactionRef > vtx
Definition: block.h:72
static std::unique_ptr< const CChainParams > SigNet(const SigNetOptions &options)
constexpr void SetNull()
Definition: uint256.h:55
static std::unique_ptr< const CChainParams > TestNet()
Serialized script, used inside transaction inputs and outputs.
Definition: script.h:414
#define consteval_ctor(input)
Definition: chainparams.cpp:38
std::string HexStr(const Span< const uint8_t > s)
Convert a span of bytes to a lower-case hexadecimal string.
Definition: hex_base.cpp:29
std::optional< ChainType > GetNetworkForMagic(const MessageStartChars &message)
static CBlock CreateGenesisBlock(const char *pszTimestamp, const CScript &genesisOutputScript, uint32_t nTime, uint32_t nNonce, uint32_t nBits, int32_t nVersion, const CAmount &genesisReward)
Definition: chainparams.cpp:41
A mutable version of CTransaction.
Definition: transaction.h:377
std::optional< std::vector< uint8_t > > challenge
Definition: chainparams.h:138
#define LogPrintf(...)
Definition: logging.h:361
int32_t nVersion
Definition: block.h:25
uint32_t nBits
Definition: block.h:29
static constexpr CAmount COIN
The amount of satoshis in one BTC.
Definition: amount.h:15