diff --git a/beacon_chain/conf.nim b/beacon_chain/conf.nim index 5ba15e08b2..d89a655e26 100644 --- a/beacon_chain/conf.nim +++ b/beacon_chain/conf.nim @@ -1223,21 +1223,27 @@ proc readValue*(r: var TomlReader, a: var Address) proc loadEth2Network*( eth2Network: Option[string] ): Eth2NetworkMetadata {.raises: [Defect, IOError].} = - network_name.set(2, labelValues = [eth2Network.get(otherwise = "mainnet")]) - when not defined(gnosisChainBinary): - if eth2Network.isSome: - getMetadataForNetwork(eth2Network.get) + const defaultName = + when defined(gnosisChainBinary) and const_preset == "mainnet": + "gnosis" + elif const_preset == "mainnet": + "mainnet" else: - when const_preset == "mainnet": - mainnetMetadata - else: - # Presumably other configurations can have other defaults, but for now - # this simplifies the flow - echo "Must specify network on non-mainnet node" - quit 1 + "(unspecified)" + network_name.set(2, labelValues = [eth2Network.get(otherwise = defaultName)]) + + if eth2Network.isSome: + getMetadataForNetwork(eth2Network.get) else: - checkNetworkParameterUse eth2Network - gnosisMetadata + when defined(gnosisChainBinary) and const_preset == "mainnet": + gnosisMetadata + elif const_preset == "mainnet": + mainnetMetadata + else: + # Presumably other configurations can have other defaults, but for now + # this simplifies the flow + fatal "Must specify network on non-mainnet node" + quit 1 template loadEth2Network*(config: BeaconNodeConf): Eth2NetworkMetadata = loadEth2Network(config.eth2Network) diff --git a/beacon_chain/networking/network_metadata.nim b/beacon_chain/networking/network_metadata.nim index 34ac104ed7..7bc919217b 100644 --- a/beacon_chain/networking/network_metadata.nim +++ b/beacon_chain/networking/network_metadata.nim @@ -200,76 +200,79 @@ template mergeTestnet(path: string, eth1Network: Eth1Network): Eth2NetworkMetada loadCompileTimeNetworkMetadata(mergeTestnetsDir & "/" & path, some eth1Network) -when not defined(gnosisChainBinary): - when const_preset == "mainnet": - const - mainnetMetadata* = eth2Network("shared/mainnet", mainnet) - praterMetadata* = eth2Network("shared/prater", goerli) - ropstenMetadata* = mergeTestnet("ropsten-beacon-chain", ropsten) - sepoliaMetadata* = mergeTestnet("sepolia", sepolia) - static: - for network in [mainnetMetadata, praterMetadata, ropstenMetadata, sepoliaMetadata]: - checkForkConsistency(network.cfg) - - proc getMetadataForNetwork*(networkName: string): Eth2NetworkMetadata {.raises: [Defect, IOError].} = - template loadRuntimeMetadata: auto = - if fileExists(networkName / "config.yaml"): - try: - loadEth2NetworkMetadata(networkName) - except CatchableError as exc: - fatal "Cannot load network", msg = exc.msg, networkName - quit 1 - else: - fatal "config.yaml not found for network", networkName +when defined(gnosisChainBinary) and const_preset == "mainnet": + const + gnosisMetadata* = loadCompileTimeNetworkMetadata( + currentSourcePath.parentDir.replace('\\', '/') & + "/../../media/gnosis") + static: + for network in [gnosisMetadata]: + checkForkConsistency(network.cfg) + +elif const_preset == "mainnet": + const + mainnetMetadata* = eth2Network("shared/mainnet", mainnet) + praterMetadata* = eth2Network("shared/prater", goerli) + ropstenMetadata* = mergeTestnet("ropsten-beacon-chain", ropsten) + sepoliaMetadata* = mergeTestnet("sepolia", sepolia) + static: + for network in [ + mainnetMetadata, praterMetadata, ropstenMetadata, sepoliaMetadata]: + checkForkConsistency(network.cfg) + +proc getMetadataForNetwork*( + networkName: string): Eth2NetworkMetadata {.raises: [Defect, IOError].} = + template loadRuntimeMetadata(): auto = + if fileExists(networkName / "config.yaml"): + try: + loadEth2NetworkMetadata(networkName) + except CatchableError as exc: + fatal "Cannot load network", msg = exc.msg, networkName quit 1 + else: + fatal "config.yaml not found for network", networkName + quit 1 - var - metadata = when const_preset == "mainnet": - case toLowerAscii(networkName) - of "mainnet": - mainnetMetadata - of "prater", "goerli": - praterMetadata - of "ropsten": - ropstenMetadata - of "sepolia": - sepoliaMetadata - else: - loadRuntimeMetadata() + let metadata = + when defined(gnosisChainBinary) and const_preset == "mainnet": + case toLowerAscii(networkName) + of "gnosis": + gnosisMetadata + of "gnosis-chain": + warn "`--network:gnosis-chain` is deprecated, " & + "use `--network:gnosis` instead" + gnosisMetadata else: loadRuntimeMetadata() - if metadata.incompatible: - fatal "The selected network is not compatible with the current build", - reason = metadata.incompatibilityDesc - quit 1 - metadata - - proc getRuntimeConfig*( - eth2Network: Option[string]): RuntimeConfig {.raises: [Defect, IOError].} = - if eth2Network.isSome: - return getMetadataForNetwork(eth2Network.get).cfg - defaultRuntimeConfig - -else: - const - gnosisMetadata* = loadCompileTimeNetworkMetadata( - currentSourcePath.parentDir.replace('\\', '/') & "/../../media/gnosis") + elif const_preset == "mainnet": + case toLowerAscii(networkName) + of "mainnet": + mainnetMetadata + of "prater", "goerli": + praterMetadata + of "ropsten": + ropstenMetadata + of "sepolia": + sepoliaMetadata + else: + loadRuntimeMetadata() - static: checkForkConsistency(gnosisMetadata.cfg) + else: + loadRuntimeMetadata() - proc checkNetworkParameterUse*(eth2Network: Option[string]) = - # Support `gnosis-chain` as network name which was used in v22.3 - if eth2Network.isSome and eth2Network.get notin ["gnosis", "gnosis-chain"]: - fatal "The only supported value for the --network parameter is 'gnosis'" - quit 1 + if metadata.incompatible: + fatal "The selected network is not compatible with the current build", + reason = metadata.incompatibilityDesc + quit 1 - if eth2Network.isSome and eth2Network.get == "gnosis-chain": - warn "`--network:gnosis-chain` is deprecated, use `--network:gnosis` instead" + metadata - proc getRuntimeConfig*(eth2Network: Option[string]): RuntimeConfig {.raises: [Defect, IOError].} = - checkNetworkParameterUse eth2Network - gnosisMetadata.cfg +proc getRuntimeConfig*( + eth2Network: Option[string]): RuntimeConfig {.raises: [Defect, IOError].} = + if eth2Network.isSome: + return getMetadataForNetwork(eth2Network.get).cfg + defaultRuntimeConfig proc extractGenesisValidatorRootFromSnapshot*( snapshot: string): Eth2Digest {.raises: [Defect, IOError, SszError].} =