mirror of
https://github.com/status-im/nimbus-eth1.git
synced 2025-01-10 12:26:02 +00:00
36d430aaa2
* Add headers with proof content type and use it for verification - Add BlockHeaderWithProof content type & content - Use BlockHeaderWithProof content to verify if chain data is part of the canonical chain - Adjust parser & seeder code to be able to seed these headers with proof - Adjust eth_data_exporter to be able to export custom header ranges for which to build proofs (mostly for testing) There is currently quite some ugliness & clean-up needed for which a big part is due tos upporting both BlockHeader and BlockHeaderWithProof on the network. * Change accumulator proof to array / SSZ vector type - Change accumulator proof to SSZ vector instead of SSZ list. - Add and use general buildProof and buildHeaderWithProof func. * Make the BlockHeaderWithProof an SSZ Union with None option * Update portal-spec-tests to master commit
65 lines
2.8 KiB
Nim
65 lines
2.8 KiB
Nim
# Nimbus
|
|
# Copyright (c) 2022 Status Research & Development GmbH
|
|
# Licensed and distributed under either of
|
|
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
|
|
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
|
|
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
|
|
{.push raises: [Defect].}
|
|
|
|
import
|
|
std/[sequtils, strutils, os, macros]
|
|
|
|
proc loadBootstrapNodes(
|
|
path: string): seq[string] {.raises: [IOError, Defect].} =
|
|
# Read a list of ENR URIs from a file containing a flat list of entries.
|
|
# If the file can't be read, this will raise. This is intentionally.
|
|
splitLines(readFile(path)).
|
|
filterIt(it.startsWith("enr:")).
|
|
mapIt(it.strip())
|
|
|
|
proc loadCompileTimeBootstrapNodes(
|
|
path: string): seq[string] {.raises: [Defect].} =
|
|
try:
|
|
return loadBootstrapNodes(path)
|
|
# TODO: This error doesn't seem to get printed. It instead dies with an
|
|
# unhandled exception (IOError)
|
|
except IOError as err:
|
|
macros.error "Failed to load bootstrap nodes metadata at '" &
|
|
path & "': " & err.msg
|
|
|
|
# Need to use std/io readFile because:
|
|
# https://github.com/status-im/nim-stew/issues/145
|
|
proc loadEncodedAccumulator(path: string): string =
|
|
try:
|
|
return readFile(path).string
|
|
except IOError as err:
|
|
macros.error "Failed to read finished accumulator at '" &
|
|
path & "': " & err.msg
|
|
|
|
const
|
|
# TODO: Change this from our local repo to an eth-client repo if/when this
|
|
# gets created for the Portal networks.
|
|
portalNetworksDir =
|
|
currentSourcePath.parentDir.replace('\\', '/') / "network_data"
|
|
|
|
# TODO: Using a repo for test vectors for now, as it is something to test
|
|
# against, but at the same time could also go in a network metadata repo.
|
|
portalTestDir =
|
|
currentSourcePath.parentDir.parentDir.replace('\\', '/') / "vendor" / "portal-spec-tests" / "tests"
|
|
# Note:
|
|
# For now it gets called testnet0 but this Portal network serves Eth1 mainnet
|
|
# data. Giving the actual Portal (test)networks different names might not be
|
|
# that useful as there is no way to distinguish the networks currently.
|
|
#
|
|
# When more config data is required per Portal network, a metadata object can
|
|
# be created, but right now only bootstrap nodes can be different.
|
|
# TODO: It would be nice to be able to use `loadBootstrapFile` here, but that
|
|
# doesn't work at compile time. The main issue seems to be the usage of
|
|
# rlp.rawData() in the enr code.
|
|
testnet0BootstrapNodes* = loadCompileTimeBootstrapNodes(
|
|
portalNetworksDir / "testnet0" / "bootstrap_nodes.txt")
|
|
|
|
finishedAccumulator* = loadEncodedAccumulator(
|
|
portalTestDir / "mainnet" / "history" / "accumulator" / "finished_accumulator.ssz")
|