github.com/0xsequence/ethkit@v1.25.0/go-ethereum/params/config.go (about) 1 // Copyright 2016 The go-ethereum Authors 2 // This file is part of the go-ethereum library. 3 // 4 // The go-ethereum library is free software: you can redistribute it and/or modify 5 // it under the terms of the GNU Lesser General Public License as published by 6 // the Free Software Foundation, either version 3 of the License, or 7 // (at your option) any later version. 8 // 9 // The go-ethereum library is distributed in the hope that it will be useful, 10 // but WITHOUT ANY WARRANTY; without even the implied warranty of 11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 // GNU Lesser General Public License for more details. 13 // 14 // You should have received a copy of the GNU Lesser General Public License 15 // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>. 16 17 package params 18 19 import ( 20 "encoding/binary" 21 "fmt" 22 "math/big" 23 24 "github.com/0xsequence/ethkit/go-ethereum/common" 25 "golang.org/x/crypto/sha3" 26 ) 27 28 // Genesis hashes to enforce below configs on. 29 var ( 30 MainnetGenesisHash = common.HexToHash("0xd4e56740f876aef8c010b86a40d5f56745a118d0906a34e69aec8c0db1cb8fa3") 31 RopstenGenesisHash = common.HexToHash("0x41941023680923e0fe4d74a34bdac8141f2540e3ae90623718e47d66d1ca4a2d") 32 SepoliaGenesisHash = common.HexToHash("0x25a5cc106eea7138acab33231d7160d69cb777ee0c2c553fcddf5138993e6dd9") 33 RinkebyGenesisHash = common.HexToHash("0x6341fd3daf94b748c72ced5a5b26028f2474f5f00d824504e4fa37a75767e177") 34 GoerliGenesisHash = common.HexToHash("0xbf7e331f7f7c1dd2e05159666b3bf8bc7a8a3a9eb1d518969eab529dd9b88c1a") 35 KilnGenesisHash = common.HexToHash("0x51c7fe41be669f69c45c33a56982cbde405313342d9e2b00d7c91a7b284dd4f8") 36 ) 37 38 // TrustedCheckpoints associates each known checkpoint with the genesis hash of 39 // the chain it belongs to. 40 var TrustedCheckpoints = map[common.Hash]*TrustedCheckpoint{ 41 MainnetGenesisHash: MainnetTrustedCheckpoint, 42 RopstenGenesisHash: RopstenTrustedCheckpoint, 43 SepoliaGenesisHash: SepoliaTrustedCheckpoint, 44 RinkebyGenesisHash: RinkebyTrustedCheckpoint, 45 GoerliGenesisHash: GoerliTrustedCheckpoint, 46 } 47 48 // CheckpointOracles associates each known checkpoint oracles with the genesis hash of 49 // the chain it belongs to. 50 var CheckpointOracles = map[common.Hash]*CheckpointOracleConfig{ 51 MainnetGenesisHash: MainnetCheckpointOracle, 52 RopstenGenesisHash: RopstenCheckpointOracle, 53 RinkebyGenesisHash: RinkebyCheckpointOracle, 54 GoerliGenesisHash: GoerliCheckpointOracle, 55 } 56 57 var ( 58 MainnetTerminalTotalDifficulty, _ = new(big.Int).SetString("58_750_000_000_000_000_000_000", 0) 59 60 // MainnetChainConfig is the chain parameters to run a node on the main network. 61 MainnetChainConfig = &ChainConfig{ 62 ChainID: big.NewInt(1), 63 HomesteadBlock: big.NewInt(1_150_000), 64 DAOForkBlock: big.NewInt(1_920_000), 65 DAOForkSupport: true, 66 EIP150Block: big.NewInt(2_463_000), 67 EIP150Hash: common.HexToHash("0x2086799aeebeae135c246c65021c82b4e15a2c451340993aacfd2751886514f0"), 68 EIP155Block: big.NewInt(2_675_000), 69 EIP158Block: big.NewInt(2_675_000), 70 ByzantiumBlock: big.NewInt(4_370_000), 71 ConstantinopleBlock: big.NewInt(7_280_000), 72 PetersburgBlock: big.NewInt(7_280_000), 73 IstanbulBlock: big.NewInt(9_069_000), 74 MuirGlacierBlock: big.NewInt(9_200_000), 75 BerlinBlock: big.NewInt(12_244_000), 76 LondonBlock: big.NewInt(12_965_000), 77 ArrowGlacierBlock: big.NewInt(13_773_000), 78 GrayGlacierBlock: big.NewInt(15_050_000), 79 TerminalTotalDifficulty: MainnetTerminalTotalDifficulty, // 58_750_000_000_000_000_000_000 80 TerminalTotalDifficultyPassed: true, 81 Ethash: new(EthashConfig), 82 } 83 84 // MainnetTrustedCheckpoint contains the light client trusted checkpoint for the main network. 85 MainnetTrustedCheckpoint = &TrustedCheckpoint{ 86 SectionIndex: 451, 87 SectionHead: common.HexToHash("0xe47f84b9967eb2ad2afff74d59901b63134660011822fdababaf8fdd18a75aa6"), 88 CHTRoot: common.HexToHash("0xc31e0462ca3d39a46111bb6b63ac4e1cac84089472b7474a319d582f72b3f0c0"), 89 BloomRoot: common.HexToHash("0x7c9f25ce3577a3ab330d52a7343f801899cf9d4980c69f81de31ccc1a055c809"), 90 } 91 92 // MainnetCheckpointOracle contains a set of configs for the main network oracle. 93 MainnetCheckpointOracle = &CheckpointOracleConfig{ 94 Address: common.HexToAddress("0x9a9070028361F7AAbeB3f2F2Dc07F82C4a98A02a"), 95 Signers: []common.Address{ 96 common.HexToAddress("0x1b2C260efc720BE89101890E4Db589b44E950527"), // Peter 97 common.HexToAddress("0x78d1aD571A1A09D60D9BBf25894b44e4C8859595"), // Martin 98 common.HexToAddress("0x286834935f4A8Cfb4FF4C77D5770C2775aE2b0E7"), // Zsolt 99 common.HexToAddress("0xb86e2B0Ab5A4B1373e40c51A7C712c70Ba2f9f8E"), // Gary 100 common.HexToAddress("0x0DF8fa387C602AE62559cC4aFa4972A7045d6707"), // Guillaume 101 }, 102 Threshold: 2, 103 } 104 105 // RopstenChainConfig contains the chain parameters to run a node on the Ropsten test network. 106 RopstenChainConfig = &ChainConfig{ 107 ChainID: big.NewInt(3), 108 HomesteadBlock: big.NewInt(0), 109 DAOForkBlock: nil, 110 DAOForkSupport: true, 111 EIP150Block: big.NewInt(0), 112 EIP150Hash: common.HexToHash("0x41941023680923e0fe4d74a34bdac8141f2540e3ae90623718e47d66d1ca4a2d"), 113 EIP155Block: big.NewInt(10), 114 EIP158Block: big.NewInt(10), 115 ByzantiumBlock: big.NewInt(1_700_000), 116 ConstantinopleBlock: big.NewInt(4_230_000), 117 PetersburgBlock: big.NewInt(4_939_394), 118 IstanbulBlock: big.NewInt(6_485_846), 119 MuirGlacierBlock: big.NewInt(7_117_117), 120 BerlinBlock: big.NewInt(9_812_189), 121 LondonBlock: big.NewInt(10_499_401), 122 TerminalTotalDifficulty: new(big.Int).SetUint64(50_000_000_000_000_000), 123 TerminalTotalDifficultyPassed: true, 124 Ethash: new(EthashConfig), 125 } 126 127 // RopstenTrustedCheckpoint contains the light client trusted checkpoint for the Ropsten test network. 128 RopstenTrustedCheckpoint = &TrustedCheckpoint{ 129 SectionIndex: 346, 130 SectionHead: common.HexToHash("0xafa0384ebd13a751fb7475aaa7fc08ac308925c8b2e2195bca2d4ab1878a7a84"), 131 CHTRoot: common.HexToHash("0x522ae1f334bfa36033b2315d0b9954052780700b69448ecea8d5877e0f7ee477"), 132 BloomRoot: common.HexToHash("0x4093fd53b0d2cc50181dca353fe66f03ae113e7cb65f869a4dfb5905de6a0493"), 133 } 134 135 // RopstenCheckpointOracle contains a set of configs for the Ropsten test network oracle. 136 RopstenCheckpointOracle = &CheckpointOracleConfig{ 137 Address: common.HexToAddress("0xEF79475013f154E6A65b54cB2742867791bf0B84"), 138 Signers: []common.Address{ 139 common.HexToAddress("0x32162F3581E88a5f62e8A61892B42C46E2c18f7b"), // Peter 140 common.HexToAddress("0x78d1aD571A1A09D60D9BBf25894b44e4C8859595"), // Martin 141 common.HexToAddress("0x286834935f4A8Cfb4FF4C77D5770C2775aE2b0E7"), // Zsolt 142 common.HexToAddress("0xb86e2B0Ab5A4B1373e40c51A7C712c70Ba2f9f8E"), // Gary 143 common.HexToAddress("0x0DF8fa387C602AE62559cC4aFa4972A7045d6707"), // Guillaume 144 }, 145 Threshold: 2, 146 } 147 148 // SepoliaChainConfig contains the chain parameters to run a node on the Sepolia test network. 149 SepoliaChainConfig = &ChainConfig{ 150 ChainID: big.NewInt(11155111), 151 HomesteadBlock: big.NewInt(0), 152 DAOForkBlock: nil, 153 DAOForkSupport: true, 154 EIP150Block: big.NewInt(0), 155 EIP155Block: big.NewInt(0), 156 EIP158Block: big.NewInt(0), 157 ByzantiumBlock: big.NewInt(0), 158 ConstantinopleBlock: big.NewInt(0), 159 PetersburgBlock: big.NewInt(0), 160 IstanbulBlock: big.NewInt(0), 161 MuirGlacierBlock: big.NewInt(0), 162 BerlinBlock: big.NewInt(0), 163 LondonBlock: big.NewInt(0), 164 TerminalTotalDifficulty: big.NewInt(17_000_000_000_000_000), 165 TerminalTotalDifficultyPassed: true, 166 MergeNetsplitBlock: big.NewInt(1735371), 167 Ethash: new(EthashConfig), 168 } 169 170 // SepoliaTrustedCheckpoint contains the light client trusted checkpoint for the Sepolia test network. 171 SepoliaTrustedCheckpoint = &TrustedCheckpoint{ 172 SectionIndex: 34, 173 SectionHead: common.HexToHash("0xe361400fcbc468d641e7bdd0b0946a3548e97c5d2703b124f04a3f1deccec244"), 174 CHTRoot: common.HexToHash("0xea6768fd288dce7d84f590884908ec39e4de78e6e1a38de5c5419b0f49a42f91"), 175 BloomRoot: common.HexToHash("0x06d32f35d5a611bfd0333ad44e39c619449824167d8ef2913edc48a8112be2cd"), 176 } 177 178 // RinkebyChainConfig contains the chain parameters to run a node on the Rinkeby test network. 179 RinkebyChainConfig = &ChainConfig{ 180 ChainID: big.NewInt(4), 181 HomesteadBlock: big.NewInt(1), 182 DAOForkBlock: nil, 183 DAOForkSupport: true, 184 EIP150Block: big.NewInt(2), 185 EIP150Hash: common.HexToHash("0x9b095b36c15eaf13044373aef8ee0bd3a382a5abb92e402afa44b8249c3a90e9"), 186 EIP155Block: big.NewInt(3), 187 EIP158Block: big.NewInt(3), 188 ByzantiumBlock: big.NewInt(1_035_301), 189 ConstantinopleBlock: big.NewInt(3_660_663), 190 PetersburgBlock: big.NewInt(4_321_234), 191 IstanbulBlock: big.NewInt(5_435_345), 192 MuirGlacierBlock: nil, 193 BerlinBlock: big.NewInt(8_290_928), 194 LondonBlock: big.NewInt(8_897_988), 195 ArrowGlacierBlock: nil, 196 Clique: &CliqueConfig{ 197 Period: 15, 198 Epoch: 30000, 199 }, 200 } 201 202 // RinkebyTrustedCheckpoint contains the light client trusted checkpoint for the Rinkeby test network. 203 RinkebyTrustedCheckpoint = &TrustedCheckpoint{ 204 SectionIndex: 326, 205 SectionHead: common.HexToHash("0x941a41a153b0e36cb15d9d193d1d0f9715bdb2435efd1c95119b64168667ce00"), 206 CHTRoot: common.HexToHash("0xe2331e00d579cf4093091dee35bef772e63c2341380c276041dc22563c8aba2e"), 207 BloomRoot: common.HexToHash("0x595206febcf118958c2bc1218ea71d01fd04b8f97ad71813df4be0af5b36b0e5"), 208 } 209 210 // RinkebyCheckpointOracle contains a set of configs for the Rinkeby test network oracle. 211 RinkebyCheckpointOracle = &CheckpointOracleConfig{ 212 Address: common.HexToAddress("0xebe8eFA441B9302A0d7eaECc277c09d20D684540"), 213 Signers: []common.Address{ 214 common.HexToAddress("0xd9c9cd5f6779558b6e0ed4e6acf6b1947e7fa1f3"), // Peter 215 common.HexToAddress("0x78d1aD571A1A09D60D9BBf25894b44e4C8859595"), // Martin 216 common.HexToAddress("0x286834935f4A8Cfb4FF4C77D5770C2775aE2b0E7"), // Zsolt 217 common.HexToAddress("0xb86e2B0Ab5A4B1373e40c51A7C712c70Ba2f9f8E"), // Gary 218 }, 219 Threshold: 2, 220 } 221 222 // GoerliChainConfig contains the chain parameters to run a node on the Görli test network. 223 GoerliChainConfig = &ChainConfig{ 224 ChainID: big.NewInt(5), 225 HomesteadBlock: big.NewInt(0), 226 DAOForkBlock: nil, 227 DAOForkSupport: true, 228 EIP150Block: big.NewInt(0), 229 EIP155Block: big.NewInt(0), 230 EIP158Block: big.NewInt(0), 231 ByzantiumBlock: big.NewInt(0), 232 ConstantinopleBlock: big.NewInt(0), 233 PetersburgBlock: big.NewInt(0), 234 IstanbulBlock: big.NewInt(1_561_651), 235 MuirGlacierBlock: nil, 236 BerlinBlock: big.NewInt(4_460_644), 237 LondonBlock: big.NewInt(5_062_605), 238 ArrowGlacierBlock: nil, 239 TerminalTotalDifficulty: big.NewInt(10_790_000), 240 TerminalTotalDifficultyPassed: true, 241 Clique: &CliqueConfig{ 242 Period: 15, 243 Epoch: 30000, 244 }, 245 } 246 247 // GoerliTrustedCheckpoint contains the light client trusted checkpoint for the Görli test network. 248 GoerliTrustedCheckpoint = &TrustedCheckpoint{ 249 SectionIndex: 210, 250 SectionHead: common.HexToHash("0xbb11eaf551a6c06f74a6c7bbfe1699cbf64b8f248b64691da916dd443176db2f"), 251 CHTRoot: common.HexToHash("0x9934ae326d00d9c7de2e074c0e51689efb7fa7fcba18929ff4279c27259c45e6"), 252 BloomRoot: common.HexToHash("0x7fe3bd4fd45194aa8a5cfe5ac590edff1f870d3d98d3c310494e7f67613a87ff"), 253 } 254 255 // GoerliCheckpointOracle contains a set of configs for the Goerli test network oracle. 256 GoerliCheckpointOracle = &CheckpointOracleConfig{ 257 Address: common.HexToAddress("0x18CA0E045F0D772a851BC7e48357Bcaab0a0795D"), 258 Signers: []common.Address{ 259 common.HexToAddress("0x4769bcaD07e3b938B7f43EB7D278Bc7Cb9efFb38"), // Peter 260 common.HexToAddress("0x78d1aD571A1A09D60D9BBf25894b44e4C8859595"), // Martin 261 common.HexToAddress("0x286834935f4A8Cfb4FF4C77D5770C2775aE2b0E7"), // Zsolt 262 common.HexToAddress("0xb86e2B0Ab5A4B1373e40c51A7C712c70Ba2f9f8E"), // Gary 263 common.HexToAddress("0x0DF8fa387C602AE62559cC4aFa4972A7045d6707"), // Guillaume 264 }, 265 Threshold: 2, 266 } 267 268 // AllEthashProtocolChanges contains every protocol change (EIPs) introduced 269 // and accepted by the Ethereum core developers into the Ethash consensus. 270 // 271 // This configuration is intentionally not using keyed fields to force anyone 272 // adding flags to the config to also have to set these fields. 273 AllEthashProtocolChanges = &ChainConfig{big.NewInt(1337), big.NewInt(0), nil, false, big.NewInt(0), common.Hash{}, big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), nil, nil, nil, nil, false, new(EthashConfig), nil} 274 275 // AllCliqueProtocolChanges contains every protocol change (EIPs) introduced 276 // and accepted by the Ethereum core developers into the Clique consensus. 277 // 278 // This configuration is intentionally not using keyed fields to force anyone 279 // adding flags to the config to also have to set these fields. 280 AllCliqueProtocolChanges = &ChainConfig{big.NewInt(1337), big.NewInt(0), nil, false, big.NewInt(0), common.Hash{}, big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), nil, nil, nil, nil, nil, nil, false, nil, &CliqueConfig{Period: 0, Epoch: 30000}} 281 282 TestChainConfig = &ChainConfig{big.NewInt(1), big.NewInt(0), nil, false, big.NewInt(0), common.Hash{}, big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), big.NewInt(0), nil, nil, nil, nil, false, new(EthashConfig), nil} 283 TestRules = TestChainConfig.Rules(new(big.Int), false) 284 ) 285 286 // NetworkNames are user friendly names to use in the chain spec banner. 287 var NetworkNames = map[string]string{ 288 MainnetChainConfig.ChainID.String(): "mainnet", 289 RopstenChainConfig.ChainID.String(): "ropsten", 290 RinkebyChainConfig.ChainID.String(): "rinkeby", 291 GoerliChainConfig.ChainID.String(): "goerli", 292 SepoliaChainConfig.ChainID.String(): "sepolia", 293 } 294 295 // TrustedCheckpoint represents a set of post-processed trie roots (CHT and 296 // BloomTrie) associated with the appropriate section index and head hash. It is 297 // used to start light syncing from this checkpoint and avoid downloading the 298 // entire header chain while still being able to securely access old headers/logs. 299 type TrustedCheckpoint struct { 300 SectionIndex uint64 `json:"sectionIndex"` 301 SectionHead common.Hash `json:"sectionHead"` 302 CHTRoot common.Hash `json:"chtRoot"` 303 BloomRoot common.Hash `json:"bloomRoot"` 304 } 305 306 // HashEqual returns an indicator comparing the itself hash with given one. 307 func (c *TrustedCheckpoint) HashEqual(hash common.Hash) bool { 308 if c.Empty() { 309 return hash == common.Hash{} 310 } 311 return c.Hash() == hash 312 } 313 314 // Hash returns the hash of checkpoint's four key fields(index, sectionHead, chtRoot and bloomTrieRoot). 315 func (c *TrustedCheckpoint) Hash() common.Hash { 316 var sectionIndex [8]byte 317 binary.BigEndian.PutUint64(sectionIndex[:], c.SectionIndex) 318 319 w := sha3.NewLegacyKeccak256() 320 w.Write(sectionIndex[:]) 321 w.Write(c.SectionHead[:]) 322 w.Write(c.CHTRoot[:]) 323 w.Write(c.BloomRoot[:]) 324 325 var h common.Hash 326 w.Sum(h[:0]) 327 return h 328 } 329 330 // Empty returns an indicator whether the checkpoint is regarded as empty. 331 func (c *TrustedCheckpoint) Empty() bool { 332 return c.SectionHead == (common.Hash{}) || c.CHTRoot == (common.Hash{}) || c.BloomRoot == (common.Hash{}) 333 } 334 335 // CheckpointOracleConfig represents a set of checkpoint contract(which acts as an oracle) 336 // config which used for light client checkpoint syncing. 337 type CheckpointOracleConfig struct { 338 Address common.Address `json:"address"` 339 Signers []common.Address `json:"signers"` 340 Threshold uint64 `json:"threshold"` 341 } 342 343 // ChainConfig is the core config which determines the blockchain settings. 344 // 345 // ChainConfig is stored in the database on a per block basis. This means 346 // that any network, identified by its genesis block, can have its own 347 // set of configuration options. 348 type ChainConfig struct { 349 ChainID *big.Int `json:"chainId"` // chainId identifies the current chain and is used for replay protection 350 351 HomesteadBlock *big.Int `json:"homesteadBlock,omitempty"` // Homestead switch block (nil = no fork, 0 = already homestead) 352 353 DAOForkBlock *big.Int `json:"daoForkBlock,omitempty"` // TheDAO hard-fork switch block (nil = no fork) 354 DAOForkSupport bool `json:"daoForkSupport,omitempty"` // Whether the nodes supports or opposes the DAO hard-fork 355 356 // EIP150 implements the Gas price changes (https://github.com/ethereum/EIPs/issues/150) 357 EIP150Block *big.Int `json:"eip150Block,omitempty"` // EIP150 HF block (nil = no fork) 358 EIP150Hash common.Hash `json:"eip150Hash,omitempty"` // EIP150 HF hash (needed for header only clients as only gas pricing changed) 359 360 EIP155Block *big.Int `json:"eip155Block,omitempty"` // EIP155 HF block 361 EIP158Block *big.Int `json:"eip158Block,omitempty"` // EIP158 HF block 362 363 ByzantiumBlock *big.Int `json:"byzantiumBlock,omitempty"` // Byzantium switch block (nil = no fork, 0 = already on byzantium) 364 ConstantinopleBlock *big.Int `json:"constantinopleBlock,omitempty"` // Constantinople switch block (nil = no fork, 0 = already activated) 365 PetersburgBlock *big.Int `json:"petersburgBlock,omitempty"` // Petersburg switch block (nil = same as Constantinople) 366 IstanbulBlock *big.Int `json:"istanbulBlock,omitempty"` // Istanbul switch block (nil = no fork, 0 = already on istanbul) 367 MuirGlacierBlock *big.Int `json:"muirGlacierBlock,omitempty"` // Eip-2384 (bomb delay) switch block (nil = no fork, 0 = already activated) 368 BerlinBlock *big.Int `json:"berlinBlock,omitempty"` // Berlin switch block (nil = no fork, 0 = already on berlin) 369 LondonBlock *big.Int `json:"londonBlock,omitempty"` // London switch block (nil = no fork, 0 = already on london) 370 ArrowGlacierBlock *big.Int `json:"arrowGlacierBlock,omitempty"` // Eip-4345 (bomb delay) switch block (nil = no fork, 0 = already activated) 371 GrayGlacierBlock *big.Int `json:"grayGlacierBlock,omitempty"` // Eip-5133 (bomb delay) switch block (nil = no fork, 0 = already activated) 372 MergeNetsplitBlock *big.Int `json:"mergeNetsplitBlock,omitempty"` // Virtual fork after The Merge to use as a network splitter 373 ShanghaiBlock *big.Int `json:"shanghaiBlock,omitempty"` // Shanghai switch block (nil = no fork, 0 = already on shanghai) 374 CancunBlock *big.Int `json:"cancunBlock,omitempty"` // Cancun switch block (nil = no fork, 0 = already on cancun) 375 376 // TerminalTotalDifficulty is the amount of total difficulty reached by 377 // the network that triggers the consensus upgrade. 378 TerminalTotalDifficulty *big.Int `json:"terminalTotalDifficulty,omitempty"` 379 380 // TerminalTotalDifficultyPassed is a flag specifying that the network already 381 // passed the terminal total difficulty. Its purpose is to disable legacy sync 382 // even without having seen the TTD locally (safer long term). 383 TerminalTotalDifficultyPassed bool `json:"terminalTotalDifficultyPassed,omitempty"` 384 385 // Various consensus engines 386 Ethash *EthashConfig `json:"ethash,omitempty"` 387 Clique *CliqueConfig `json:"clique,omitempty"` 388 } 389 390 // EthashConfig is the consensus engine configs for proof-of-work based sealing. 391 type EthashConfig struct{} 392 393 // String implements the stringer interface, returning the consensus engine details. 394 func (c *EthashConfig) String() string { 395 return "ethash" 396 } 397 398 // CliqueConfig is the consensus engine configs for proof-of-authority based sealing. 399 type CliqueConfig struct { 400 Period uint64 `json:"period"` // Number of seconds between blocks to enforce 401 Epoch uint64 `json:"epoch"` // Epoch length to reset votes and checkpoint 402 } 403 404 // String implements the stringer interface, returning the consensus engine details. 405 func (c *CliqueConfig) String() string { 406 return "clique" 407 } 408 409 // String implements the fmt.Stringer interface. 410 func (c *ChainConfig) String() string { 411 var banner string 412 413 // Create some basinc network config output 414 network := NetworkNames[c.ChainID.String()] 415 if network == "" { 416 network = "unknown" 417 } 418 banner += fmt.Sprintf("Chain ID: %v (%s)\n", c.ChainID, network) 419 switch { 420 case c.Ethash != nil: 421 if c.TerminalTotalDifficulty == nil { 422 banner += "Consensus: Ethash (proof-of-work)\n" 423 } else if !c.TerminalTotalDifficultyPassed { 424 banner += "Consensus: Beacon (proof-of-stake), merging from Ethash (proof-of-work)\n" 425 } else { 426 banner += "Consensus: Beacon (proof-of-stake), merged from Ethash (proof-of-work)\n" 427 } 428 case c.Clique != nil: 429 if c.TerminalTotalDifficulty == nil { 430 banner += "Consensus: Clique (proof-of-authority)\n" 431 } else if !c.TerminalTotalDifficultyPassed { 432 banner += "Consensus: Beacon (proof-of-stake), merging from Clique (proof-of-authority)\n" 433 } else { 434 banner += "Consensus: Beacon (proof-of-stake), merged from Clique (proof-of-authority)\n" 435 } 436 default: 437 banner += "Consensus: unknown\n" 438 } 439 banner += "\n" 440 441 // Create a list of forks with a short description of them. Forks that only 442 // makes sense for mainnet should be optional at printing to avoid bloating 443 // the output for testnets and private networks. 444 banner += "Pre-Merge hard forks:\n" 445 banner += fmt.Sprintf(" - Homestead: %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/homestead.md)\n", c.HomesteadBlock) 446 if c.DAOForkBlock != nil { 447 banner += fmt.Sprintf(" - DAO Fork: %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/dao-fork.md)\n", c.DAOForkBlock) 448 } 449 banner += fmt.Sprintf(" - Tangerine Whistle (EIP 150): %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/tangerine-whistle.md)\n", c.EIP150Block) 450 banner += fmt.Sprintf(" - Spurious Dragon/1 (EIP 155): %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/spurious-dragon.md)\n", c.EIP155Block) 451 banner += fmt.Sprintf(" - Spurious Dragon/2 (EIP 158): %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/spurious-dragon.md)\n", c.EIP155Block) 452 banner += fmt.Sprintf(" - Byzantium: %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/byzantium.md)\n", c.ByzantiumBlock) 453 banner += fmt.Sprintf(" - Constantinople: %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/constantinople.md)\n", c.ConstantinopleBlock) 454 banner += fmt.Sprintf(" - Petersburg: %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/petersburg.md)\n", c.PetersburgBlock) 455 banner += fmt.Sprintf(" - Istanbul: %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/istanbul.md)\n", c.IstanbulBlock) 456 if c.MuirGlacierBlock != nil { 457 banner += fmt.Sprintf(" - Muir Glacier: %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/muir-glacier.md)\n", c.MuirGlacierBlock) 458 } 459 banner += fmt.Sprintf(" - Berlin: %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/berlin.md)\n", c.BerlinBlock) 460 banner += fmt.Sprintf(" - London: %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/london.md)\n", c.LondonBlock) 461 if c.ArrowGlacierBlock != nil { 462 banner += fmt.Sprintf(" - Arrow Glacier: %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/arrow-glacier.md)\n", c.ArrowGlacierBlock) 463 } 464 if c.GrayGlacierBlock != nil { 465 banner += fmt.Sprintf(" - Gray Glacier: %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/gray-glacier.md)\n", c.GrayGlacierBlock) 466 } 467 if c.ShanghaiBlock != nil { 468 banner += fmt.Sprintf(" - Shanghai: %-8v (https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/shanghai.md)\n", c.ShanghaiBlock) 469 } 470 if c.CancunBlock != nil { 471 banner += fmt.Sprintf(" - Cancun: %-8v\n", c.CancunBlock) 472 } 473 banner += "\n" 474 475 // Add a special section for the merge as it's non-obvious 476 if c.TerminalTotalDifficulty == nil { 477 banner += "The Merge is not yet available for this network!\n" 478 banner += " - Hard-fork specification: https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/paris.md" 479 } else { 480 banner += "Merge configured:\n" 481 banner += " - Hard-fork specification: https://github.com/ethereum/execution-specs/blob/master/network-upgrades/mainnet-upgrades/paris.md\n" 482 banner += fmt.Sprintf(" - Network known to be merged: %v\n", c.TerminalTotalDifficultyPassed) 483 banner += fmt.Sprintf(" - Total terminal difficulty: %v\n", c.TerminalTotalDifficulty) 484 banner += fmt.Sprintf(" - Merge netsplit block: %-8v", c.MergeNetsplitBlock) 485 } 486 return banner 487 } 488 489 // IsHomestead returns whether num is either equal to the homestead block or greater. 490 func (c *ChainConfig) IsHomestead(num *big.Int) bool { 491 return isForked(c.HomesteadBlock, num) 492 } 493 494 // IsDAOFork returns whether num is either equal to the DAO fork block or greater. 495 func (c *ChainConfig) IsDAOFork(num *big.Int) bool { 496 return isForked(c.DAOForkBlock, num) 497 } 498 499 // IsEIP150 returns whether num is either equal to the EIP150 fork block or greater. 500 func (c *ChainConfig) IsEIP150(num *big.Int) bool { 501 return isForked(c.EIP150Block, num) 502 } 503 504 // IsEIP155 returns whether num is either equal to the EIP155 fork block or greater. 505 func (c *ChainConfig) IsEIP155(num *big.Int) bool { 506 return isForked(c.EIP155Block, num) 507 } 508 509 // IsEIP158 returns whether num is either equal to the EIP158 fork block or greater. 510 func (c *ChainConfig) IsEIP158(num *big.Int) bool { 511 return isForked(c.EIP158Block, num) 512 } 513 514 // IsByzantium returns whether num is either equal to the Byzantium fork block or greater. 515 func (c *ChainConfig) IsByzantium(num *big.Int) bool { 516 return isForked(c.ByzantiumBlock, num) 517 } 518 519 // IsConstantinople returns whether num is either equal to the Constantinople fork block or greater. 520 func (c *ChainConfig) IsConstantinople(num *big.Int) bool { 521 return isForked(c.ConstantinopleBlock, num) 522 } 523 524 // IsMuirGlacier returns whether num is either equal to the Muir Glacier (EIP-2384) fork block or greater. 525 func (c *ChainConfig) IsMuirGlacier(num *big.Int) bool { 526 return isForked(c.MuirGlacierBlock, num) 527 } 528 529 // IsPetersburg returns whether num is either 530 // - equal to or greater than the PetersburgBlock fork block, 531 // - OR is nil, and Constantinople is active 532 func (c *ChainConfig) IsPetersburg(num *big.Int) bool { 533 return isForked(c.PetersburgBlock, num) || c.PetersburgBlock == nil && isForked(c.ConstantinopleBlock, num) 534 } 535 536 // IsIstanbul returns whether num is either equal to the Istanbul fork block or greater. 537 func (c *ChainConfig) IsIstanbul(num *big.Int) bool { 538 return isForked(c.IstanbulBlock, num) 539 } 540 541 // IsBerlin returns whether num is either equal to the Berlin fork block or greater. 542 func (c *ChainConfig) IsBerlin(num *big.Int) bool { 543 return isForked(c.BerlinBlock, num) 544 } 545 546 // IsLondon returns whether num is either equal to the London fork block or greater. 547 func (c *ChainConfig) IsLondon(num *big.Int) bool { 548 return isForked(c.LondonBlock, num) 549 } 550 551 // IsArrowGlacier returns whether num is either equal to the Arrow Glacier (EIP-4345) fork block or greater. 552 func (c *ChainConfig) IsArrowGlacier(num *big.Int) bool { 553 return isForked(c.ArrowGlacierBlock, num) 554 } 555 556 // IsGrayGlacier returns whether num is either equal to the Gray Glacier (EIP-5133) fork block or greater. 557 func (c *ChainConfig) IsGrayGlacier(num *big.Int) bool { 558 return isForked(c.GrayGlacierBlock, num) 559 } 560 561 // IsTerminalPoWBlock returns whether the given block is the last block of PoW stage. 562 func (c *ChainConfig) IsTerminalPoWBlock(parentTotalDiff *big.Int, totalDiff *big.Int) bool { 563 if c.TerminalTotalDifficulty == nil { 564 return false 565 } 566 return parentTotalDiff.Cmp(c.TerminalTotalDifficulty) < 0 && totalDiff.Cmp(c.TerminalTotalDifficulty) >= 0 567 } 568 569 // IsShanghai returns whether num is either equal to the Shanghai fork block or greater. 570 func (c *ChainConfig) IsShanghai(num *big.Int) bool { 571 return isForked(c.ShanghaiBlock, num) 572 } 573 574 // IsCancun returns whether num is either equal to the Cancun fork block or greater. 575 func (c *ChainConfig) IsCancun(num *big.Int) bool { 576 return isForked(c.CancunBlock, num) 577 } 578 579 // CheckCompatible checks whether scheduled fork transitions have been imported 580 // with a mismatching chain configuration. 581 func (c *ChainConfig) CheckCompatible(newcfg *ChainConfig, height uint64) *ConfigCompatError { 582 bhead := new(big.Int).SetUint64(height) 583 584 // Iterate checkCompatible to find the lowest conflict. 585 var lasterr *ConfigCompatError 586 for { 587 err := c.checkCompatible(newcfg, bhead) 588 if err == nil || (lasterr != nil && err.RewindTo == lasterr.RewindTo) { 589 break 590 } 591 lasterr = err 592 bhead.SetUint64(err.RewindTo) 593 } 594 return lasterr 595 } 596 597 // CheckConfigForkOrder checks that we don't "skip" any forks, geth isn't pluggable enough 598 // to guarantee that forks can be implemented in a different order than on official networks 599 func (c *ChainConfig) CheckConfigForkOrder() error { 600 type fork struct { 601 name string 602 block *big.Int 603 optional bool // if true, the fork may be nil and next fork is still allowed 604 } 605 var lastFork fork 606 for _, cur := range []fork{ 607 {name: "homesteadBlock", block: c.HomesteadBlock}, 608 {name: "daoForkBlock", block: c.DAOForkBlock, optional: true}, 609 {name: "eip150Block", block: c.EIP150Block}, 610 {name: "eip155Block", block: c.EIP155Block}, 611 {name: "eip158Block", block: c.EIP158Block}, 612 {name: "byzantiumBlock", block: c.ByzantiumBlock}, 613 {name: "constantinopleBlock", block: c.ConstantinopleBlock}, 614 {name: "petersburgBlock", block: c.PetersburgBlock}, 615 {name: "istanbulBlock", block: c.IstanbulBlock}, 616 {name: "muirGlacierBlock", block: c.MuirGlacierBlock, optional: true}, 617 {name: "berlinBlock", block: c.BerlinBlock}, 618 {name: "londonBlock", block: c.LondonBlock}, 619 {name: "arrowGlacierBlock", block: c.ArrowGlacierBlock, optional: true}, 620 {name: "grayGlacierBlock", block: c.GrayGlacierBlock, optional: true}, 621 {name: "mergeNetsplitBlock", block: c.MergeNetsplitBlock, optional: true}, 622 {name: "shanghaiBlock", block: c.ShanghaiBlock, optional: true}, 623 {name: "cancunBlock", block: c.CancunBlock, optional: true}, 624 } { 625 if lastFork.name != "" { 626 // Next one must be higher number 627 if lastFork.block == nil && cur.block != nil { 628 return fmt.Errorf("unsupported fork ordering: %v not enabled, but %v enabled at %v", 629 lastFork.name, cur.name, cur.block) 630 } 631 if lastFork.block != nil && cur.block != nil { 632 if lastFork.block.Cmp(cur.block) > 0 { 633 return fmt.Errorf("unsupported fork ordering: %v enabled at %v, but %v enabled at %v", 634 lastFork.name, lastFork.block, cur.name, cur.block) 635 } 636 } 637 } 638 // If it was optional and not set, then ignore it 639 if !cur.optional || cur.block != nil { 640 lastFork = cur 641 } 642 } 643 return nil 644 } 645 646 func (c *ChainConfig) checkCompatible(newcfg *ChainConfig, head *big.Int) *ConfigCompatError { 647 if isForkIncompatible(c.HomesteadBlock, newcfg.HomesteadBlock, head) { 648 return newCompatError("Homestead fork block", c.HomesteadBlock, newcfg.HomesteadBlock) 649 } 650 if isForkIncompatible(c.DAOForkBlock, newcfg.DAOForkBlock, head) { 651 return newCompatError("DAO fork block", c.DAOForkBlock, newcfg.DAOForkBlock) 652 } 653 if c.IsDAOFork(head) && c.DAOForkSupport != newcfg.DAOForkSupport { 654 return newCompatError("DAO fork support flag", c.DAOForkBlock, newcfg.DAOForkBlock) 655 } 656 if isForkIncompatible(c.EIP150Block, newcfg.EIP150Block, head) { 657 return newCompatError("EIP150 fork block", c.EIP150Block, newcfg.EIP150Block) 658 } 659 if isForkIncompatible(c.EIP155Block, newcfg.EIP155Block, head) { 660 return newCompatError("EIP155 fork block", c.EIP155Block, newcfg.EIP155Block) 661 } 662 if isForkIncompatible(c.EIP158Block, newcfg.EIP158Block, head) { 663 return newCompatError("EIP158 fork block", c.EIP158Block, newcfg.EIP158Block) 664 } 665 if c.IsEIP158(head) && !configNumEqual(c.ChainID, newcfg.ChainID) { 666 return newCompatError("EIP158 chain ID", c.EIP158Block, newcfg.EIP158Block) 667 } 668 if isForkIncompatible(c.ByzantiumBlock, newcfg.ByzantiumBlock, head) { 669 return newCompatError("Byzantium fork block", c.ByzantiumBlock, newcfg.ByzantiumBlock) 670 } 671 if isForkIncompatible(c.ConstantinopleBlock, newcfg.ConstantinopleBlock, head) { 672 return newCompatError("Constantinople fork block", c.ConstantinopleBlock, newcfg.ConstantinopleBlock) 673 } 674 if isForkIncompatible(c.PetersburgBlock, newcfg.PetersburgBlock, head) { 675 // the only case where we allow Petersburg to be set in the past is if it is equal to Constantinople 676 // mainly to satisfy fork ordering requirements which state that Petersburg fork be set if Constantinople fork is set 677 if isForkIncompatible(c.ConstantinopleBlock, newcfg.PetersburgBlock, head) { 678 return newCompatError("Petersburg fork block", c.PetersburgBlock, newcfg.PetersburgBlock) 679 } 680 } 681 if isForkIncompatible(c.IstanbulBlock, newcfg.IstanbulBlock, head) { 682 return newCompatError("Istanbul fork block", c.IstanbulBlock, newcfg.IstanbulBlock) 683 } 684 if isForkIncompatible(c.MuirGlacierBlock, newcfg.MuirGlacierBlock, head) { 685 return newCompatError("Muir Glacier fork block", c.MuirGlacierBlock, newcfg.MuirGlacierBlock) 686 } 687 if isForkIncompatible(c.BerlinBlock, newcfg.BerlinBlock, head) { 688 return newCompatError("Berlin fork block", c.BerlinBlock, newcfg.BerlinBlock) 689 } 690 if isForkIncompatible(c.LondonBlock, newcfg.LondonBlock, head) { 691 return newCompatError("London fork block", c.LondonBlock, newcfg.LondonBlock) 692 } 693 if isForkIncompatible(c.ArrowGlacierBlock, newcfg.ArrowGlacierBlock, head) { 694 return newCompatError("Arrow Glacier fork block", c.ArrowGlacierBlock, newcfg.ArrowGlacierBlock) 695 } 696 if isForkIncompatible(c.GrayGlacierBlock, newcfg.GrayGlacierBlock, head) { 697 return newCompatError("Gray Glacier fork block", c.GrayGlacierBlock, newcfg.GrayGlacierBlock) 698 } 699 if isForkIncompatible(c.MergeNetsplitBlock, newcfg.MergeNetsplitBlock, head) { 700 return newCompatError("Merge netsplit fork block", c.MergeNetsplitBlock, newcfg.MergeNetsplitBlock) 701 } 702 if isForkIncompatible(c.ShanghaiBlock, newcfg.ShanghaiBlock, head) { 703 return newCompatError("Shanghai fork block", c.ShanghaiBlock, newcfg.ShanghaiBlock) 704 } 705 if isForkIncompatible(c.CancunBlock, newcfg.CancunBlock, head) { 706 return newCompatError("Cancun fork block", c.CancunBlock, newcfg.CancunBlock) 707 } 708 return nil 709 } 710 711 // isForkIncompatible returns true if a fork scheduled at s1 cannot be rescheduled to 712 // block s2 because head is already past the fork. 713 func isForkIncompatible(s1, s2, head *big.Int) bool { 714 return (isForked(s1, head) || isForked(s2, head)) && !configNumEqual(s1, s2) 715 } 716 717 // isForked returns whether a fork scheduled at block s is active at the given head block. 718 func isForked(s, head *big.Int) bool { 719 if s == nil || head == nil { 720 return false 721 } 722 return s.Cmp(head) <= 0 723 } 724 725 func configNumEqual(x, y *big.Int) bool { 726 if x == nil { 727 return y == nil 728 } 729 if y == nil { 730 return x == nil 731 } 732 return x.Cmp(y) == 0 733 } 734 735 // ConfigCompatError is raised if the locally-stored blockchain is initialised with a 736 // ChainConfig that would alter the past. 737 type ConfigCompatError struct { 738 What string 739 // block numbers of the stored and new configurations 740 StoredConfig, NewConfig *big.Int 741 // the block number to which the local chain must be rewound to correct the error 742 RewindTo uint64 743 } 744 745 func newCompatError(what string, storedblock, newblock *big.Int) *ConfigCompatError { 746 var rew *big.Int 747 switch { 748 case storedblock == nil: 749 rew = newblock 750 case newblock == nil || storedblock.Cmp(newblock) < 0: 751 rew = storedblock 752 default: 753 rew = newblock 754 } 755 err := &ConfigCompatError{what, storedblock, newblock, 0} 756 if rew != nil && rew.Sign() > 0 { 757 err.RewindTo = rew.Uint64() - 1 758 } 759 return err 760 } 761 762 func (err *ConfigCompatError) Error() string { 763 return fmt.Sprintf("mismatching %s in database (have %d, want %d, rewindto %d)", err.What, err.StoredConfig, err.NewConfig, err.RewindTo) 764 } 765 766 // Rules wraps ChainConfig and is merely syntactic sugar or can be used for functions 767 // that do not have or require information about the block. 768 // 769 // Rules is a one time interface meaning that it shouldn't be used in between transition 770 // phases. 771 type Rules struct { 772 ChainID *big.Int 773 IsHomestead, IsEIP150, IsEIP155, IsEIP158 bool 774 IsByzantium, IsConstantinople, IsPetersburg, IsIstanbul bool 775 IsBerlin, IsLondon bool 776 IsMerge, IsShanghai, isCancun bool 777 } 778 779 // Rules ensures c's ChainID is not nil. 780 func (c *ChainConfig) Rules(num *big.Int, isMerge bool) Rules { 781 chainID := c.ChainID 782 if chainID == nil { 783 chainID = new(big.Int) 784 } 785 return Rules{ 786 ChainID: new(big.Int).Set(chainID), 787 IsHomestead: c.IsHomestead(num), 788 IsEIP150: c.IsEIP150(num), 789 IsEIP155: c.IsEIP155(num), 790 IsEIP158: c.IsEIP158(num), 791 IsByzantium: c.IsByzantium(num), 792 IsConstantinople: c.IsConstantinople(num), 793 IsPetersburg: c.IsPetersburg(num), 794 IsIstanbul: c.IsIstanbul(num), 795 IsBerlin: c.IsBerlin(num), 796 IsLondon: c.IsLondon(num), 797 IsMerge: isMerge, 798 IsShanghai: c.IsShanghai(num), 799 isCancun: c.IsCancun(num), 800 } 801 }