2022-10-11 03:02:16 +00:00
|
|
|
import
|
|
|
|
chronos,
|
|
|
|
../../eth/[p2p, common]
|
|
|
|
|
|
|
|
# for testing purpose
|
|
|
|
# real eth protocol implementation is in nimbus-eth1 repo
|
|
|
|
|
|
|
|
type
|
2024-01-22 09:47:46 +00:00
|
|
|
PeerState = ref object of RootRef
|
2022-10-11 03:02:16 +00:00
|
|
|
initialized*: bool
|
|
|
|
|
|
|
|
p2pProtocol eth(version = 63,
|
|
|
|
peerState = PeerState,
|
|
|
|
useRequestIds = false):
|
|
|
|
|
|
|
|
onPeerConnected do (peer: Peer):
|
|
|
|
let
|
|
|
|
network = peer.network
|
|
|
|
|
2023-10-29 04:06:48 +00:00
|
|
|
discard await peer.status(63,
|
2022-10-11 03:02:16 +00:00
|
|
|
network.networkId,
|
|
|
|
0.u256,
|
|
|
|
Hash256(),
|
|
|
|
Hash256(),
|
|
|
|
timeout = chronos.seconds(10))
|
|
|
|
|
|
|
|
handshake:
|
|
|
|
proc status(peer: Peer,
|
|
|
|
protocolVersion: uint,
|
|
|
|
networkId: NetworkId,
|
|
|
|
totalDifficulty: DifficultyInt,
|
|
|
|
bestHash: KeccakHash,
|
|
|
|
genesisHash: KeccakHash)
|
|
|
|
|
|
|
|
requestResponse:
|
2024-02-19 07:16:33 +00:00
|
|
|
proc getBlockHeaders(peer: Peer, request: openArray[KeccakHash]) {.gcsafe.} =
|
|
|
|
var headers: seq[BlockHeader]
|
|
|
|
await response.send(headers)
|
|
|
|
|
2022-10-11 03:02:16 +00:00
|
|
|
proc blockHeaders(p: Peer, headers: openArray[BlockHeader])
|
|
|
|
|
|
|
|
requestResponse:
|
|
|
|
proc getBlockBodies(peer: Peer, hashes: openArray[KeccakHash]) {.gcsafe.} = discard
|
|
|
|
proc blockBodies(peer: Peer, blocks: openArray[BlockBody])
|
|
|
|
|
|
|
|
nextID 13
|
|
|
|
|
|
|
|
requestResponse:
|
|
|
|
proc getNodeData(peer: Peer, hashes: openArray[KeccakHash]) = discard
|
|
|
|
proc nodeData(peer: Peer, data: openArray[Blob])
|
|
|
|
|
|
|
|
requestResponse:
|
|
|
|
proc getReceipts(peer: Peer, hashes: openArray[KeccakHash]) = discard
|
|
|
|
proc receipts(peer: Peer, receipts: openArray[Receipt])
|