Bitcoin ABC  0.26.3
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 <chainparamsbase.h>
9 #include <chainparamsconstants.h>
10 #include <chainparamsseeds.h>
11 #include <consensus/amount.h>
12 #include <consensus/merkle.h>
13 #include <primitives/block.h>
14 #include <primitives/transaction.h>
15 #include <script/script.h>
16 #include <uint256.h>
17 #include <util/strencodings.h>
18 
19 #include <algorithm>
20 #include <cassert>
21 #include <cstdint>
22 #include <cstring>
23 
24 static CBlock CreateGenesisBlock(const char *pszTimestamp,
25  const CScript &genesisOutputScript,
26  uint32_t nTime, uint32_t nNonce,
27  uint32_t nBits, int32_t nVersion,
28  const Amount genesisReward) {
29  CMutableTransaction txNew;
30  txNew.nVersion = 1;
31  txNew.vin.resize(1);
32  txNew.vout.resize(1);
33  txNew.vin[0].scriptSig =
34  CScript() << 486604799 << CScriptNum(4)
35  << std::vector<uint8_t>((const uint8_t *)pszTimestamp,
36  (const uint8_t *)pszTimestamp +
37  strlen(pszTimestamp));
38  txNew.vout[0].nValue = genesisReward;
39  txNew.vout[0].scriptPubKey = genesisOutputScript;
40 
41  CBlock genesis;
42  genesis.nTime = nTime;
43  genesis.nBits = nBits;
44  genesis.nNonce = nNonce;
45  genesis.nVersion = nVersion;
46  genesis.vtx.push_back(MakeTransactionRef(std::move(txNew)));
47  genesis.hashPrevBlock.SetNull();
48  genesis.hashMerkleRoot = BlockMerkleRoot(genesis);
49  return genesis;
50 }
51 
65 static CBlock CreateGenesisBlock(uint32_t nTime, uint32_t nNonce,
66  uint32_t nBits, int32_t nVersion,
67  const Amount genesisReward) {
68  const char *pszTimestamp =
69  "The Times 03/Jan/2009 Chancellor on brink of second bailout for banks";
70  const CScript genesisOutputScript =
71  CScript() << ParseHex("04678afdb0fe5548271967f1a67130b7105cd6a828e03909"
72  "a67962e0ea1f61deb649f6bc3f4cef38c4f35504e51ec112"
73  "de5c384df7ba0b8d578a4c702b6bf11d5f")
74  << OP_CHECKSIG;
75  return CreateGenesisBlock(pszTimestamp, genesisOutputScript, nTime, nNonce,
76  nBits, nVersion, genesisReward);
77 }
78 
82 class CMainParams : public CChainParams {
83 public:
84  explicit CMainParams(const ChainOptions &opts) {
87  // 00000000000000ce80a7e057163a4db1d5ad7b20fb6f598c9597b9665c8fb0d4 -
88  // April 1, 2012
89  consensus.BIP16Height = 173805;
90  consensus.BIP34Height = 227931;
92  "000000000000024b89b42a942fe0d9fea3bb44ab7bd1b19115dd6a759c0808b8");
93  // 000000000000000004c2b624ed5d7756c508d90fd0da2c7c679febfa6c4735f0
94  consensus.BIP65Height = 388381;
95  // 00000000000000000379eaa19dce8c9b722d46ae6a57c2f1a988119488b50931
96  consensus.BIP66Height = 363725;
97  // 000000000000000004a1b34462cb8aeebd5799177f7a29cf28f2d1961716b5b5
98  consensus.CSVHeight = 419328;
100  "00000000ffffffffffffffffffffffffffffffffffffffffffffffffffffffff");
101  // two weeks
102  consensus.nPowTargetTimespan = 14 * 24 * 60 * 60;
103  consensus.nPowTargetSpacing = 10 * 60;
106 
107  // two days
108  consensus.nDAAHalfLife = 2 * 24 * 60 * 60;
109 
110  // The miner fund is enabled by default on mainnet.
111  consensus.enableMinerFund = true;
112 
113  // The staking rewards are enabled by default on mainnet.
115 
116  // The best chain should have at least this much work.
119 
120  // By default assume that the signatures in ancestors of this block are
121  // valid.
124 
125  // August 1, 2017 hard fork
126  consensus.uahfHeight = 478558;
127 
128  // November 13, 2017 hard fork
129  consensus.daaHeight = 504031;
130 
131  // November 15, 2018 hard fork
133 
134  // November 15, 2019 protocol upgrade
135  consensus.gravitonHeight = 609135;
136 
137  // May 15, 2020 12:00:00 UTC protocol upgrade
138  consensus.phononHeight = 635258;
139 
140  // Nov 15, 2020 12:00:00 UTC protocol upgrade
141  consensus.axionHeight = 661647;
142 
143  // May 15, 2023 12:00:00 UTC protocol upgrade
144  consensus.wellingtonHeight = 792116;
145 
146  // Nov 15, 2023 12:00:00 UTC protocol upgrade
148 
149  // Nov 15, 2024 12:00:00 UTC protocol upgrade
150  consensus.augustoActivationTime = 1731672000;
151 
157  diskMagic[0] = 0xf9;
158  diskMagic[1] = 0xbe;
159  diskMagic[2] = 0xb4;
160  diskMagic[3] = 0xd9;
161  netMagic[0] = 0xe3;
162  netMagic[1] = 0xe1;
163  netMagic[2] = 0xf3;
164  netMagic[3] = 0xe8;
165  nDefaultPort = 8333;
166  nPruneAfterHeight = 100000;
171 
172  genesis = CreateGenesisBlock(1231006505, 2083236893, 0x1d00ffff, 1,
173  50 * COIN);
176  uint256S("000000000019d6689c085ae165831e934ff763ae46a2a6c172b3f1"
177  "b60a8ce26f"));
179  uint256S("4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b"
180  "7afdeda33b"));
181 
182  // Note that of those which support the service bits prefix, most only
183  // support a subset of possible options. This is fine at runtime as
184  // we'll fall back to using them as an addrfetch if they don't support
185  // the service bits we want, but we should get them updated to support
186  // all service bits wanted by any release ASAP to avoid it where
187  // possible.
188  // Bitcoin ABC seeder
189  vSeeds.emplace_back("seed.bitcoinabc.org");
190  // Fabien
191  vSeeds.emplace_back("seeder.fabien.cash");
192  // status.cash
193  vSeeds.emplace_back("seeder.status.cash");
194 
195  base58Prefixes[PUBKEY_ADDRESS] = std::vector<uint8_t>(1, 0);
196  base58Prefixes[SCRIPT_ADDRESS] = std::vector<uint8_t>(1, 5);
197  base58Prefixes[SECRET_KEY] = std::vector<uint8_t>(1, 128);
198  base58Prefixes[EXT_PUBLIC_KEY] = {0x04, 0x88, 0xB2, 0x1E};
199  base58Prefixes[EXT_SECRET_KEY] = {0x04, 0x88, 0xAD, 0xE4};
200  cashaddrPrefix = opts.ecash ? "ecash" : "bitcoincash";
201 
202  vFixedSeeds = std::vector<SeedSpec6>(std::begin(pnSeed6_main),
203  std::end(pnSeed6_main));
204 
206  fRequireStandard = true;
207  m_is_test_chain = false;
208  m_is_mockable_chain = false;
209 
211 
213  // TODO to be specified in a future patch.
214  };
215 
216  // Data as of block
217  // 000000000000000001d2ce557406b017a928be25ee98906397d339c3f68eec5d
218  // (height 523992).
220  // UNIX timestamp of last known number of transactions.
221  1522608016,
222  // Total number of transactions between genesis and that timestamp
223  // (the tx=... number in the ChainStateFlushed debug.log lines)
224  248589038,
225  // Estimated number of transactions per second after that timestamp.
226  3.2,
227  };
228  }
229 };
230 
234 class CTestNetParams : public CChainParams {
235 public:
236  explicit CTestNetParams(const ChainOptions &opts) {
239  // 00000000040b4e986385315e14bee30ad876d8b47f748025b26683116d21aa65
240  consensus.BIP16Height = 514;
241  consensus.BIP34Height = 21111;
243  "0000000023b3a96d3484e5abb3755c413e7d41500f8e2a5c3f0dd01299cd8ef8");
244  // 00000000007f6655f22f98e72ed80d8b06dc761d5da09df0fa1dc4be4f861eb6
245  consensus.BIP65Height = 581885;
246  // 000000002104c8c45e99a8853285a3b592602a3ccde2b832481da85e9e4ba182
247  consensus.BIP66Height = 330776;
248  // 00000000025e930139bac5c6c31a403776da130831ab85be56578f3fa75369bb
249  consensus.CSVHeight = 770112;
251  "00000000ffffffffffffffffffffffffffffffffffffffffffffffffffffffff");
252  // two weeks
253  consensus.nPowTargetTimespan = 14 * 24 * 60 * 60;
254  consensus.nPowTargetSpacing = 10 * 60;
257 
258  // two days
259  consensus.nDAAHalfLife = 2 * 24 * 60 * 60;
260 
261  // The miner fund is disabled by default on testnet.
262  consensus.enableMinerFund = false;
263 
264  // The staking rewards are disabled by default on testnet.
266 
267  // The best chain should have at least this much work.
270 
271  // By default assume that the signatures in ancestors of this block are
272  // valid.
275 
276  // August 1, 2017 hard fork
277  consensus.uahfHeight = 1155875;
278 
279  // November 13, 2017 hard fork
280  consensus.daaHeight = 1188697;
281 
282  // November 15, 2018 hard fork
284 
285  // November 15, 2019 protocol upgrade
286  consensus.gravitonHeight = 1341711;
287 
288  // May 15, 2020 12:00:00 UTC protocol upgrade
289  consensus.phononHeight = 1378460;
290 
291  // Nov 15, 2020 12:00:00 UTC protocol upgrade
292  consensus.axionHeight = 1421481;
293 
294  // May 15, 2023 12:00:00 UTC protocol upgrade
295  consensus.wellingtonHeight = 1556117;
296 
297  // Nov 15, 2023 12:00:00 UTC protocol upgrade
298  consensus.cowperthwaiteHeight = 1584485;
299 
300  // Nov 15, 2024 12:00:00 UTC protocol upgrade
301  consensus.augustoActivationTime = 1731672000;
302 
303  diskMagic[0] = 0x0b;
304  diskMagic[1] = 0x11;
305  diskMagic[2] = 0x09;
306  diskMagic[3] = 0x07;
307  netMagic[0] = 0xf4;
308  netMagic[1] = 0xe5;
309  netMagic[2] = 0xf3;
310  netMagic[3] = 0xf4;
311  nDefaultPort = 18333;
312  nPruneAfterHeight = 1000;
317 
318  genesis =
319  CreateGenesisBlock(1296688602, 414098458, 0x1d00ffff, 1, 50 * COIN);
322  uint256S("000000000933ea01ad0ee984209779baaec3ced90fa3f408719526"
323  "f8d77f4943"));
325  uint256S("4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab2127b"
326  "7afdeda33b"));
327 
328  vFixedSeeds.clear();
329  vSeeds.clear();
330  // nodes with support for servicebits filtering should be at the top
331  // Bitcoin ABC seeder
332  vSeeds.emplace_back("testnet-seed.bitcoinabc.org");
333  // Fabien
334  vSeeds.emplace_back("testnet-seeder.fabien.cash");
335  // status.cash
336  vSeeds.emplace_back("testnet-seeder.status.cash");
337 
338  base58Prefixes[PUBKEY_ADDRESS] = std::vector<uint8_t>(1, 111);
339  base58Prefixes[SCRIPT_ADDRESS] = std::vector<uint8_t>(1, 196);
340  base58Prefixes[SECRET_KEY] = std::vector<uint8_t>(1, 239);
341  base58Prefixes[EXT_PUBLIC_KEY] = {0x04, 0x35, 0x87, 0xCF};
342  base58Prefixes[EXT_SECRET_KEY] = {0x04, 0x35, 0x83, 0x94};
343  cashaddrPrefix = opts.ecash ? "ectest" : "bchtest";
344 
345  vFixedSeeds = std::vector<SeedSpec6>(std::begin(pnSeed6_test),
346  std::end(pnSeed6_test));
347 
349  fRequireStandard = false;
350  m_is_test_chain = true;
351  m_is_mockable_chain = false;
352 
354 
356  // TODO to be specified in a future patch.
357  };
358 
359  // Data as of block
360  // 000000000005b07ecf85563034d13efd81c1a29e47e22b20f4fc6919d5b09cd6
361  // (height 1223263)
362  chainTxData = ChainTxData{1522608381, 15052068, 0.15};
363  }
364 };
365 
369 class CRegTestParams : public CChainParams {
370 public:
371  explicit CRegTestParams(const ChainOptions &opts) {
374  // always enforce P2SH BIP16 on regtest
376  // BIP34 activated on regtest (Used in functional tests)
377  consensus.BIP34Height = 500;
379  // BIP65 activated on regtest (Used in functional tests)
380  consensus.BIP65Height = 1351;
381  // BIP66 activated on regtest (Used in functional tests)
382  consensus.BIP66Height = 1251;
383  // CSV activated on regtest (Used in functional tests)
384  consensus.CSVHeight = 576;
386  "7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");
387  // two weeks
388  consensus.nPowTargetTimespan = 14 * 24 * 60 * 60;
389  consensus.nPowTargetSpacing = 10 * 60;
392 
393  // two days
394  consensus.nDAAHalfLife = 2 * 24 * 60 * 60;
395 
396  // The miner fund is disabled by default on regtest.
397  consensus.enableMinerFund = false;
398 
399  // The staking rewards are disabled by default on regtest.
401 
402  // The best chain should have at least this much work.
404 
405  // By default assume that the signatures in ancestors of this block are
406  // valid.
408 
409  // UAHF is always enabled on regtest.
410  consensus.uahfHeight = 0;
411 
412  // November 13, 2017 hard fork is always on on regtest.
413  consensus.daaHeight = 0;
414 
415  // November 15, 2018 hard fork is always on on regtest.
417 
418  // November 15, 2019 protocol upgrade
420 
421  // May 15, 2020 12:00:00 UTC protocol upgrade
423 
424  // Nov 15, 2020 12:00:00 UTC protocol upgrade
426 
427  // May 15, 2023 12:00:00 UTC protocol upgrade
429 
430  // Nov 15, 2023 12:00:00 UTC protocol upgrade
432 
433  // Nov 15, 2024 12:00:00 UTC protocol upgrade
434  consensus.augustoActivationTime = 1731672000;
435 
436  diskMagic[0] = 0xfa;
437  diskMagic[1] = 0xbf;
438  diskMagic[2] = 0xb5;
439  diskMagic[3] = 0xda;
440  netMagic[0] = 0xda;
441  netMagic[1] = 0xb5;
442  netMagic[2] = 0xbf;
443  netMagic[3] = 0xfa;
444  nDefaultPort = 18444;
445  nPruneAfterHeight = opts.fastprune ? 100 : 1000;
448 
449  genesis = CreateGenesisBlock(1296688602, 2, 0x207fffff, 1, 50 * COIN);
452  uint256S("0x0f9188f13cb7b2c71f2a335e3a4fc328bf5beb436012afca590b"
453  "1a11466e2206"));
455  uint256S("0x4a5e1e4baab89f3a32518a88c31bc87f618f76673e2cc77ab212"
456  "7b7afdeda33b"));
457 
459  vFixedSeeds.clear();
461  vSeeds.clear();
462 
464  fRequireStandard = true;
465  m_is_test_chain = true;
466  m_is_mockable_chain = true;
467 
469 
471  {
472  110,
473  {AssumeutxoHash{uint256S("0xd754ca97ef24c5132f8d2147c19310b7a6b"
474  "d136766430304735a73372fe36213")},
475  110},
476  },
477  {
478  210,
479  {AssumeutxoHash{uint256S("0x73b4bc8dd69649c6e9ede39b156713109bf"
480  "044d2466661a3fe8a8b91ba601849")},
481  210},
482  },
483  };
484 
485  chainTxData = ChainTxData{0, 0, 0};
486 
487  base58Prefixes[PUBKEY_ADDRESS] = std::vector<uint8_t>(1, 111);
488  base58Prefixes[SCRIPT_ADDRESS] = std::vector<uint8_t>(1, 196);
489  base58Prefixes[SECRET_KEY] = std::vector<uint8_t>(1, 239);
490  base58Prefixes[EXT_PUBLIC_KEY] = {0x04, 0x35, 0x87, 0xCF};
491  base58Prefixes[EXT_SECRET_KEY] = {0x04, 0x35, 0x83, 0x94};
492  cashaddrPrefix = opts.ecash ? "ecregtest" : "bchreg";
493  }
494 };
495 
496 std::unique_ptr<const CChainParams>
498  return std::make_unique<const CRegTestParams>(options);
499 }
500 
501 std::unique_ptr<const CChainParams>
503  return std::make_unique<const CMainParams>(options);
504 }
505 
506 std::unique_ptr<const CChainParams>
508  return std::make_unique<const CTestNetParams>(options);
509 }
static constexpr Amount COIN
Definition: amount.h:144
static SeedSpec6 pnSeed6_main[]
List of fixed seed nodes for the bitcoin network @generated by contrib/seeds/generate-seeds....
static SeedSpec6 pnSeed6_test[]
static const std::string REGTEST
static const std::string TESTNET
static const std::string MAIN
BIP70 chain name strings (main, test or regtest)
BlockHash GetHash() const
Definition: block.cpp:11
uint32_t nNonce
Definition: block.h:31
uint32_t nBits
Definition: block.h:30
uint32_t nTime
Definition: block.h:29
BlockHash hashPrevBlock
Definition: block.h:27
int32_t nVersion
Definition: block.h:26
uint256 hashMerkleRoot
Definition: block.h:28
Definition: block.h:60
std::vector< CTransactionRef > vtx
Definition: block.h:63
CChainParams defines various tweakable parameters of a given instance of the Bitcoin system.
Definition: chainparams.h:80
uint64_t m_assumed_chain_state_size
Definition: chainparams.h:163
bool m_is_test_chain
Definition: chainparams.h:172
CBlock genesis
Definition: chainparams.h:168
MapAssumeutxo m_assumeutxo_data
Definition: chainparams.h:175
uint64_t m_assumed_blockchain_size
Definition: chainparams.h:162
CMessageHeader::MessageMagic netMagic
Definition: chainparams.h:159
std::vector< uint8_t > base58Prefixes[MAX_BASE58_TYPES]
Definition: chainparams.h:165
bool fDefaultConsistencyChecks
Definition: chainparams.h:170
std::vector< SeedSpec6 > vFixedSeeds
Definition: chainparams.h:169
std::string strNetworkID
Definition: chainparams.h:167
Consensus::Params consensus
Definition: chainparams.h:157
static std::unique_ptr< const CChainParams > TestNet(const ChainOptions &options)
static std::unique_ptr< const CChainParams > RegTest(const ChainOptions &options)
bool fRequireStandard
Definition: chainparams.h:171
std::string cashaddrPrefix
Definition: chainparams.h:166
std::vector< std::string > vSeeds
Definition: chainparams.h:164
bool m_is_mockable_chain
Definition: chainparams.h:173
CMessageHeader::MessageMagic diskMagic
Definition: chainparams.h:158
static std::unique_ptr< const CChainParams > Main(const ChainOptions &options)
CCheckpointData checkpointData
Definition: chainparams.h:174
uint16_t nDefaultPort
Definition: chainparams.h:160
uint64_t nPruneAfterHeight
Definition: chainparams.h:161
ChainTxData chainTxData
Definition: chainparams.h:176
Main network.
Definition: chainparams.cpp:82
CMainParams(const ChainOptions &opts)
Definition: chainparams.cpp:84
A mutable version of CTransaction.
Definition: transaction.h:274
std::vector< CTxOut > vout
Definition: transaction.h:277
std::vector< CTxIn > vin
Definition: transaction.h:276
Regression test.
CRegTestParams(const ChainOptions &opts)
Serialized script, used inside transaction inputs and outputs.
Definition: script.h:431
Testnet (v3)
CTestNetParams(const ChainOptions &opts)
void SetNull()
Definition: uint256.h:41
static CBlock CreateGenesisBlock(const char *pszTimestamp, const CScript &genesisOutputScript, uint32_t nTime, uint32_t nNonce, uint32_t nBits, int32_t nVersion, const Amount genesisReward)
Definition: chainparams.cpp:24
std::map< int, const AssumeutxoData > MapAssumeutxo
Definition: chainparams.h:59
const CCheckpointData & CheckpointData(const std::string &chain)
uint256 BlockMerkleRoot(const CBlock &block, bool *mutated)
Compute the Merkle root of the transactions in a block.
Definition: merkle.cpp:69
const uint64_t MAINNET_ASSUMED_CHAINSTATE_SIZE
const uint64_t TESTNET_ASSUMED_CHAINSTATE_SIZE
const uint64_t MAINNET_ASSUMED_BLOCKCHAIN_SIZE
const uint64_t TESTNET_ASSUMED_BLOCKCHAIN_SIZE
const BlockHash MAINNET_DEFAULT_ASSUME_VALID
const uint256 TESTNET_MINIMUM_CHAIN_WORK
const uint256 MAINNET_MINIMUM_CHAIN_WORK
const BlockHash TESTNET_DEFAULT_ASSUME_VALID
static CTransactionRef MakeTransactionRef()
Definition: transaction.h:316
@ OP_CHECKSIG
Definition: script.h:163
std::vector< uint8_t > ParseHex(const char *psz)
Definition: amount.h:19
A BlockHash is a unqiue identifier for a block.
Definition: blockhash.h:13
static BlockHash fromHex(const std::string &str)
Definition: blockhash.h:17
Holds various statistics on transactions within a chain.
Definition: chainparams.h:67
BlockHash defaultAssumeValid
Definition: params.h:87
int magneticAnomalyHeight
Block height at which the magnetic anomaly activation becomes active.
Definition: params.h:53
int BIP65Height
Block height at which BIP65 becomes active.
Definition: params.h:43
bool enableStakingRewards
Enable or disable the staking rewards by default.
Definition: params.h:71
int CSVHeight
Block height at which CSV (BIP68, BIP112 and BIP113) becomes active.
Definition: params.h:47
int gravitonHeight
Block height at which the graviton activation becomes active.
Definition: params.h:55
int axionHeight
Block height at which the axion activation becomes active.
Definition: params.h:59
BlockHash BIP34Hash
Definition: params.h:41
int BIP16Height
Block height at which BIP16 becomes active.
Definition: params.h:38
int wellingtonHeight
Block height at which the wellington activation becomes active.
Definition: params.h:61
int phononHeight
Block height at which the phonon activation becomes active.
Definition: params.h:57
int64_t nDAAHalfLife
Definition: params.h:77
int BIP34Height
Block height and hash at which BIP34 becomes active.
Definition: params.h:40
int nSubsidyHalvingInterval
Definition: params.h:36
bool fPowNoRetargeting
Definition: params.h:76
uint256 nMinimumChainWork
Definition: params.h:86
int daaHeight
Block height at which the new DAA becomes active.
Definition: params.h:51
int64_t nPowTargetTimespan
Definition: params.h:79
BlockHash hashGenesisBlock
Definition: params.h:35
int BIP66Height
Block height at which BIP66 becomes active.
Definition: params.h:45
uint256 powLimit
Proof of work parameters.
Definition: params.h:74
int uahfHeight
Block height at which UAHF kicks in.
Definition: params.h:49
bool enableMinerFund
Enable or disable the miner fund by default.
Definition: params.h:68
int cowperthwaiteHeight
Block height at which the Cowperthwaite activation becomes active.
Definition: params.h:63
int64_t nPowTargetSpacing
Definition: params.h:78
int augustoActivationTime
Unix time used for MTP activation of 15 Nov 2024 12:00:00 UTC upgrade.
Definition: params.h:65
bool fPowAllowMinDifficultyBlocks
Definition: params.h:75
uint256 uint256S(const char *str)
uint256 from const char *.
Definition: uint256.h:143
assert(!tx.IsCoinBase())