Bitcoin ABC 0.30.10
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
7
8#include <chainparamsbase.h>
10#include <chainparamsseeds.h>
11#include <consensus/amount.h>
12#include <consensus/merkle.h>
13#include <primitives/block.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
24static 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) {
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
65static 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
82class CMainParams : public CChainParams {
83public:
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;
106
107 // two days
108 consensus.nDAAHalfLife = 2 * 24 * 60 * 60;
109
110 // The miner fund is enabled by default on mainnet.
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
145
146 // Nov 15, 2023 12:00:00 UTC protocol upgrade
148
149 // May 15, 2025 12:00:00 UTC protocol upgrade
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
235public:
236 explicit CTestNetParams(const ChainOptions &opts) {
239 // 00000000040b4e986385315e14bee30ad876d8b47f748025b26683116d21aa65
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;
257
258 // two days
259 consensus.nDAAHalfLife = 2 * 24 * 60 * 60;
260
261 // The miner fund is disabled by default on testnet.
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
299
300 // May 15, 2025 12:00:00 UTC protocol upgrade
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
370public:
371 explicit CRegTestParams(const ChainOptions &opts) {
374 // always enforce P2SH BIP16 on regtest
376 // BIP34 activated on regtest (Used in functional tests)
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;
392
393 // two days
394 consensus.nDAAHalfLife = 2 * 24 * 60 * 60;
395
396 // The miner fund is disabled by default on regtest.
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.
411
412 // November 13, 2017 hard fork is always on on regtest.
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 // May 15, 2025 12:00:00 UTC protocol upgrade
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
496std::unique_ptr<const CChainParams>
498 return std::make_unique<const CRegTestParams>(options);
499}
500
501std::unique_ptr<const CChainParams>
503 return std::make_unique<const CMainParams>(options);
504}
505
506std::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)
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
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 schumpeterActivationTime
Unix time used for MTP activation of 15 May 2025 12:00:00 UTC upgrade.
Definition: params.h:65
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
bool fPowAllowMinDifficultyBlocks
Definition: params.h:75
uint256 uint256S(const char *str)
uint256 from const char *.
Definition: uint256.h:143
template std::vector< std::byte > ParseHex(std::string_view)
assert(!tx.IsCoinBase())