# nim-eth # Copyright (c) 2018-2021 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. import ../common/[eth_types, state_accessors] # TODO: Perhaps we can move this to eth-common proc getBlockHeaders*(db: AbstractChainDB, req: BlocksRequest): seq[BlockHeader] {.gcsafe, raises: [RlpError, Defect].} = 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 req.reverse: if not db.getSuccessorHeader(foundBlock, foundBlock, req.skip): break else: if not db.getAncestorHeader(foundBlock, foundBlock, req.skip): break result.add foundBlock template fetcher*(fetcherName, fetchingFunc, InputType, ResultType: untyped) = proc fetcherName*(db: AbstractChainDB, lookups: openArray[InputType]): seq[ResultType] {.gcsafe.} = 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