mirror of
https://github.com/status-im/nim-eth-p2p.git
synced 2025-01-23 05:09:26 +00:00
7828ef0481
This also restores the old module structure of having separate `peer_pool` and `rlpx` modules. This is made possible by the new Nim package `package_visible_types` (please refer to its README for an explanation). Also introduces more error handling in the low-level RLPx routines. All detected errors will result in immediate disconnection of the corresponding peer, which may be detected in the protocols though the `onPeerDisconnected` event handler.
42 lines
1.6 KiB
Nim
42 lines
1.6 KiB
Nim
import
|
|
eth_common/[eth_types, state_accessors]
|
|
|
|
# TODO: Perhaps we can move this to eth-common
|
|
|
|
proc getBlockHeaders*(db: AbstractChainDb,
|
|
req: BlocksRequest): seq[BlockHeader] =
|
|
result = newSeqOfCap[BlockHeader](req.maxResults)
|
|
|
|
var foundBlock: BlockHeader
|
|
if db.getBlockHeader(req.startBlock, foundBlock):
|
|
result.add foundBlock
|
|
|
|
while uint64(result.len) < req.maxResults:
|
|
if not db.getSuccessorHeader(foundBlock, foundBlock):
|
|
break
|
|
result.add foundBlock
|
|
|
|
template fetcher*(fetcherName, fetchingFunc, InputType, ResultType: untyped) =
|
|
proc fetcherName*(db: AbstractChainDb,
|
|
lookups: openarray[InputType]): seq[ResultType] =
|
|
for lookup in lookups:
|
|
let fetched = fetchingFunc(db, lookup)
|
|
if fetched.hasData:
|
|
# TODO: should there be an else clause here.
|
|
# Is the peer responsible of figuring out that
|
|
# some of the requested items were not found?
|
|
result.add deref(fetched)
|
|
|
|
fetcher getContractCodes, getContractCode, ContractCodeRequest, Blob
|
|
fetcher getBlockBodies, getBlockBody, KeccakHash, BlockBody
|
|
fetcher getStorageNodes, getStorageNode, KeccakHash, Blob
|
|
fetcher getReceipts, getReceipt, KeccakHash, Receipt
|
|
fetcher getProofs, getProof, ProofRequest, Blob
|
|
fetcher getHeaderProofs, getHeaderProof, ProofRequest, Blob
|
|
|
|
proc getHelperTrieProofs*(db: AbstractChainDb,
|
|
reqs: openarray[HelperTrieProofRequest],
|
|
outNodes: var seq[Blob], outAuxData: var seq[Blob]) =
|
|
discard
|
|
|