mirror of
https://github.com/status-im/nimbus-eth1.git
synced 2025-01-23 10:40:51 +00:00
4d9e288340
* 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
68 lines
1.9 KiB
Nim
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)
|