nimbus-eth1/nimbus/core/block_import.nim
andri lim 4d9e288340
Wiring ForkedChainRef to other components (#2423)
* Wiring ForkedChainRef to other components

- Disable majority of hive simulators
- Only enable pyspec_sim for the moment
- The pyspec_sim is using a smaller RPC service wired to ForkedChainRef
- The RPC service will gradually grow

* Addressing PR review

* Fix test_beacon/setup_env

* Enable consensus_sim (#2441)

* Enable consensus_sim

* Remove isFile check

* Enable Engine API jwt auth tests and exchange cap tests

* Enable engine api in build_sim.sh

* Wire ForkedChainRef to Engine API newPayload

* Wire Engine API getBodies to ForkedChainRef

* Wire Engine API api_forkchoice to ForkedChainRef

* Wire more RPC methods to ForkedChainRef

* Implement eth_syncing

* Implement eth_call and eth_getlogs

* TxPool: simplify smartHead

* Fix smartHead usage

* Fix txpool headDiff

* Remove hasBlockHeader and use headerExists

* Addressing review
2024-09-04 09:54:54 +00:00

68 lines
1.9 KiB
Nim

# Nimbus
# Copyright (c) 2021-2024 Status Research & Development GmbH
# Licensed under either of
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE))
# * MIT license ([LICENSE-MIT](LICENSE-MIT))
# at your option.
# This file may not be copied, modified, or distributed except according to
# those terms.
{.push raises: [].}
import
chronicles,
eth/rlp, stew/io2,
./chain,
../common/common,
../utils/utils,
../config
proc importRlpBlocks*(blocksRlp: openArray[byte],
chain: ForkedChainRef,
finalize: bool):
Result[void, string] =
var
# the encoded rlp can contains one or more blocks
rlp = rlpFromBytes(blocksRlp)
blk: EthBlock
# even though the new imported blocks have block number
# smaller than head, we keep importing it.
# it maybe a side chain.
while rlp.hasData:
blk = try:
rlp.read(EthBlock)
except RlpError as e:
# terminate if there was a decoding error
return err($e.name & ": " & e.msg)
? chain.importBlock(blk)
if finalize:
? chain.forkChoice(chain.latestHash, chain.latestHash)
ok()
proc importRlpBlocks*(importFile: string,
chain: ForkedChainRef,
finalize: bool): Result[void, string] =
let bytes = io2.readAllBytes(importFile).valueOr:
return err($error)
importRlpBlocks(bytes, chain, finalize)
proc importRlpBlocks*(conf: NimbusConf, com: CommonRef) =
var head: BlockHeader
if not com.db.getCanonicalHead(head):
error "cannot get canonical head from db"
quit(QuitFailure)
let chain = newForkedChain(com, head, baseDistance = 0)
# success or not, we quit after importing blocks
for i, blocksFile in conf.blocksFile:
importRlpBlocks(string blocksFile, chain, i == conf.blocksFile.len-1).isOkOr:
warn "Error when importing blocks", msg=error
quit(QuitFailure)
quit(QuitSuccess)