Add support for the Ropsten beacon chain (#3648)

This commit is contained in:
zah 2022-05-20 18:26:07 +03:00 committed by GitHub
parent 68fb3962c8
commit e7ce3cacd0
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
11 changed files with 71 additions and 5 deletions

4
.gitmodules vendored
View File

@ -223,3 +223,7 @@
url = https://github.com/status-im/nim-toml-serialization.git url = https://github.com/status-im/nim-toml-serialization.git
ignore = untracked ignore = untracked
branch = master branch = master
[submodule "vendor/merge-testnets"]
path = vendor/merge-testnets
url = https://github.com/eth-clients/merge-testnets.git
branch = main

View File

@ -26,6 +26,7 @@ BASE_PORT := 9000
BASE_REST_PORT := 5052 BASE_REST_PORT := 5052
BASE_METRICS_PORT := 8008 BASE_METRICS_PORT := 8008
ROPSTEN_WEB3_URL := "--web3-url=wss://ropsten.infura.io/ws/v3/809a18497dd74102b5f37d25aae3c85a"
GOERLI_WEB3_URL := "--web3-url=wss://goerli.infura.io/ws/v3/809a18497dd74102b5f37d25aae3c85a" GOERLI_WEB3_URL := "--web3-url=wss://goerli.infura.io/ws/v3/809a18497dd74102b5f37d25aae3c85a"
GNOSIS_WEB3_URLS := "--web3-url=wss://rpc.gnosischain.com/wss --web3-url=wss://xdai.poanetwork.dev/wss" GNOSIS_WEB3_URLS := "--web3-url=wss://rpc.gnosischain.com/wss --web3-url=wss://xdai.poanetwork.dev/wss"
@ -399,6 +400,32 @@ prater-dev-deposit: | prater-build deposit_contract
clean-prater: clean-prater:
$(call CLEAN_NETWORK,prater) $(call CLEAN_NETWORK,prater)
###
### Ropsten
###
ropsten-build: | nimbus_beacon_node nimbus_signing_node
# https://www.gnu.org/software/make/manual/html_node/Call-Function.html#Call-Function
ropsten: | ropsten-build
$(call CONNECT_TO_NETWORK,ropsten,nimbus_beacon_node,$(ROPSTEN_WEB3_URL))
ropsten-vc: | ropsten-build nimbus_validator_client
$(call CONNECT_TO_NETWORK_WITH_VALIDATOR_CLIENT,ropsten,nimbus_beacon_node,$(ROPSTEN_WEB3_URL))
ifneq ($(LOG_LEVEL), TRACE)
ropsten-dev:
+ "$(MAKE)" LOG_LEVEL=TRACE $@
else
ropsten-dev: | ropsten-build
$(call CONNECT_TO_NETWORK_IN_DEV_MODE,ropsten,nimbus_beacon_node,$(ROPSTEN_WEB3_URL))
endif
ropsten-dev-deposit: | ropsten-build deposit_contract
$(call MAKE_DEPOSIT,ropsten,$(ROPSTEN_WEB3_URL))
clean-ropsten:
$(call CLEAN_NETWORK,ropsten)
### ###
### Gnosis chain binary ### Gnosis chain binary
### ###

View File

@ -1292,6 +1292,7 @@ proc startEth1Syncing(m: Eth1Monitor, delayBeforeStart: Duration) {.async.} =
providerNetwork = awaitWithRetries m.dataProvider.web3.provider.net_version() providerNetwork = awaitWithRetries m.dataProvider.web3.provider.net_version()
expectedNetwork = case m.eth1Network.get expectedNetwork = case m.eth1Network.get
of mainnet: "1" of mainnet: "1"
of ropsten: "3"
of rinkeby: "4" of rinkeby: "4"
of goerli: "5" of goerli: "5"
if expectedNetwork != providerNetwork: if expectedNetwork != providerNetwork:

View File

@ -37,6 +37,7 @@ type
Eth1Network* = enum Eth1Network* = enum
mainnet mainnet
ropsten
rinkeby rinkeby
goerli goerli
@ -86,6 +87,7 @@ type
const const
eth2NetworksDir = currentSourcePath.parentDir.replace('\\', '/') & "/../../vendor/eth2-networks" eth2NetworksDir = currentSourcePath.parentDir.replace('\\', '/') & "/../../vendor/eth2-networks"
mergeTestnetsDir = currentSourcePath.parentDir.replace('\\', '/') & "/../../vendor/merge-testnets"
proc readBootstrapNodes*(path: string): seq[string] {.raises: [IOError, Defect].} = proc readBootstrapNodes*(path: string): seq[string] {.raises: [IOError, Defect].} =
# Read a list of ENR values from a YAML file containing a flat list of entries # Read a list of ENR values from a YAML file containing a flat list of entries
@ -115,6 +117,7 @@ proc loadEth2NetworkMetadata*(path: string, eth1Network = none(Eth1Network)): Et
genesisPath = path & "/genesis.ssz" genesisPath = path & "/genesis.ssz"
genesisDepositsSnapshotPath = path & "/genesis_deposit_contract_snapshot.ssz" genesisDepositsSnapshotPath = path & "/genesis_deposit_contract_snapshot.ssz"
configPath = path & "/config.yaml" configPath = path & "/config.yaml"
deployBlockPath = path & "/deploy_block.txt"
depositContractBlockPath = path & "/deposit_contract_block.txt" depositContractBlockPath = path & "/deposit_contract_block.txt"
bootstrapNodesPath = path & "/bootstrap_nodes.txt" bootstrapNodesPath = path & "/bootstrap_nodes.txt"
bootEnrPath = path & "/boot_enr.yaml" bootEnrPath = path & "/boot_enr.yaml"
@ -134,8 +137,16 @@ proc loadEth2NetworkMetadata*(path: string, eth1Network = none(Eth1Network)): Et
readFile(depositContractBlockPath).strip readFile(depositContractBlockPath).strip
else: else:
"" ""
deployBlock = if fileExists(deployBlockPath):
readFile(deployBlockPath).strip
else:
""
depositContractDeployedAt = if depositContractBlock.len > 0: depositContractDeployedAt = if depositContractBlock.len > 0:
BlockHashOrNumber.init(depositContractBlock) BlockHashOrNumber.init(depositContractBlock)
elif deployBlock.len > 0:
BlockHashOrNumber.init(deployBlock)
else: else:
BlockHashOrNumber(isHash: false, number: 1) BlockHashOrNumber(isHash: false, number: 1)
@ -217,11 +228,16 @@ template eth2Network(path: string, eth1Network: Eth1Network): Eth2NetworkMetadat
loadCompileTimeNetworkMetadata(eth2NetworksDir & "/" & path, loadCompileTimeNetworkMetadata(eth2NetworksDir & "/" & path,
some eth1Network) some eth1Network)
template mergeTestnet(path: string, eth1Network: Eth1Network): Eth2NetworkMetadata =
loadCompileTimeNetworkMetadata(mergeTestnetsDir & "/" & path,
some eth1Network)
when not defined(gnosisChainBinary): when not defined(gnosisChainBinary):
when const_preset == "mainnet": when const_preset == "mainnet":
const const
mainnetMetadata* = eth2Network("shared/mainnet", mainnet) mainnetMetadata* = eth2Network("shared/mainnet", mainnet)
praterMetadata* = eth2Network("shared/prater", goerli) praterMetadata* = eth2Network("shared/prater", goerli)
ropstenMetadata = mergeTestnet("ropsten-beacon-chain", ropsten)
proc getMetadataForNetwork*(networkName: string): Eth2NetworkMetadata {.raises: [Defect, IOError].} = proc getMetadataForNetwork*(networkName: string): Eth2NetworkMetadata {.raises: [Defect, IOError].} =
template loadRuntimeMetadata: auto = template loadRuntimeMetadata: auto =
@ -242,6 +258,8 @@ when not defined(gnosisChainBinary):
mainnetMetadata mainnetMetadata
of "prater": of "prater":
praterMetadata praterMetadata
of "ropsten":
ropstenMetadata
else: else:
loadRuntimeMetadata() loadRuntimeMetadata()
else: else:

View File

@ -429,7 +429,8 @@ proc init*(T: type BeaconNode,
if snapshotRes.isErr: if snapshotRes.isErr:
fatal "Failed to locate the deposit contract deployment block", fatal "Failed to locate the deposit contract deployment block",
depositContract = cfg.DEPOSIT_CONTRACT_ADDRESS, depositContract = cfg.DEPOSIT_CONTRACT_ADDRESS,
deploymentBlock = $depositContractDeployedAt deploymentBlock = $depositContractDeployedAt,
err = snapshotRes.error
quit 1 quit 1
else: else:
some snapshotRes.get some snapshotRes.get

View File

@ -169,6 +169,7 @@ when const_preset == "mainnet":
# canonical network names include: # canonical network names include:
# * 'mainnet' - there can be only one # * 'mainnet' - there can be only one
# * 'prater' - testnet # * 'prater' - testnet
# * 'ropsten' - testnet
# Must match the regex: [a-z0-9\-] # Must match the regex: [a-z0-9\-]
CONFIG_NAME: "mainnet", CONFIG_NAME: "mainnet",
@ -271,6 +272,7 @@ elif const_preset == "minimal":
# canonical network names include: # canonical network names include:
# * 'mainnet' - there can be only one # * 'mainnet' - there can be only one
# * 'prater' - testnet # * 'prater' - testnet
# * 'ropsten' - testnet
# Must match the regex: [a-z0-9\-] # Must match the regex: [a-z0-9\-]
CONFIG_NAME: "minimal", CONFIG_NAME: "minimal",

View File

@ -67,5 +67,5 @@ The `prater` testnet runs on
```bash ```bash
# using a local Goerli instance # using a local Goerli instance
WEB3_URL="ws://localhost:8545" ./run-mainnet-node.sh --max-peers=150 WEB3_URL="ws://localhost:8545" ./run-prater-node.sh --max-peers=150
``` ```

View File

@ -178,7 +178,7 @@ Each era is identified by when it ends. Thus, the genesis era is era `0`, follow
`.era` file names follow a simple convention: `<config-name>-<era-number>-<era-count>-<short-historical-root>.era`: `.era` file names follow a simple convention: `<config-name>-<era-number>-<era-count>-<short-historical-root>.era`:
* `config-name` is the `CONFIG_NAME` field of the runtime configation (`mainnet`, `prater`, etc) * `config-name` is the `CONFIG_NAME` field of the runtime configation (`mainnet`, `prater`, `ropsten`, etc)
* `era-number` is the number of the _first_ era stored in the file - for example, the genesis era file has number 0 - as a 5-digit 0-filled decimal integer * `era-number` is the number of the _first_ era stored in the file - for example, the genesis era file has number 0 - as a 5-digit 0-filled decimal integer
* `short-era-root` is the first 4 bytes of the last historical root in the _last_ state in the era file, lower-case hex-encoded (8 characters), except the genesis era which instead uses the `genesis_validators_root` field from the genesis state. * `short-era-root` is the first 4 bytes of the last historical root in the _last_ state in the era file, lower-case hex-encoded (8 characters), except the genesis era which instead uses the `genesis_validators_root` field from the genesis state.
* The root is available as `state.historical_roots[era - 1]` except for genesis, which is `state.genesis_validators_root` * The root is available as `state.historical_roots[era - 1]` except for genesis, which is `state.genesis_validators_root`

View File

@ -32,9 +32,9 @@ The following options are available:
Where: Where:
- The `network` can either be `mainnet` or `prater` - The `network` can either be `mainnet`, `prater` or `ropsten`
- The default location of the `db` is either `build/data/shared_mainnet_0/db` or `build/data/shared_prater_0/db` - The default location of the `db` is either `build/data/shared_mainnet_0/db`, `build/data/shared_prater_0/db` or `build/data/shared_ropsten_0/db`
Near the bottom, you should see Near the bottom, you should see

12
run-ropsten-beacon-node.sh Executable file
View File

@ -0,0 +1,12 @@
#!/usr/bin/env bash
# Copyright (c) 2020-2021 Status Research & Development GmbH. Licensed under
# either of:
# - Apache License, version 2.0
# - MIT license
# at your option. This file may not be copied, modified, or distributed except
# according to those terms.
cd "$(dirname $0)"
# Allow the binary to receive signals directly.
exec scripts/run-beacon-node.sh nimbus_beacon_node ropsten $@

1
vendor/merge-testnets vendored Submodule

@ -0,0 +1 @@
Subproject commit 5b1b44aa912dd3433ba30d381345659c53918955