Review comments by Dmitriy
This commit is contained in:
parent
64e691b824
commit
ed3e91cbde
|
@ -399,33 +399,15 @@ proc wantListHandler*(
|
||||||
address = e.address
|
address = e.address
|
||||||
wantType = $e.wantType
|
wantType = $e.wantType
|
||||||
|
|
||||||
if idx < 0: # new entry
|
# Update metrics
|
||||||
peerCtx.peerWants.add(e)
|
|
||||||
|
|
||||||
let
|
|
||||||
have = await e.address in b.localStore
|
|
||||||
price = @(
|
|
||||||
b.pricing.get(Pricing(price: 0.u256))
|
|
||||||
.price.toBytesBE)
|
|
||||||
|
|
||||||
if e.wantType == WantType.WantHave:
|
if e.wantType == WantType.WantHave:
|
||||||
codex_block_exchange_want_have_lists_received.inc()
|
codex_block_exchange_want_have_lists_received.inc()
|
||||||
elif e.wantType == WantType.WantBlock:
|
elif e.wantType == WantType.WantBlock:
|
||||||
codex_block_exchange_want_block_lists_received.inc()
|
codex_block_exchange_want_block_lists_received.inc()
|
||||||
|
|
||||||
if not have and e.sendDontHave:
|
# Update peerCtx
|
||||||
presence.add(
|
if idx < 0: # new entry
|
||||||
BlockPresence(
|
peerCtx.peerWants.add(e)
|
||||||
address: e.address,
|
|
||||||
`type`: BlockPresenceType.DontHave,
|
|
||||||
price: price))
|
|
||||||
elif have and e.wantType == WantType.WantHave:
|
|
||||||
presence.add(
|
|
||||||
BlockPresence(
|
|
||||||
address: e.address,
|
|
||||||
`type`: BlockPresenceType.Have,
|
|
||||||
price: price))
|
|
||||||
|
|
||||||
else: # update existing entry
|
else: # update existing entry
|
||||||
# peer doesn't want this block anymore
|
# peer doesn't want this block anymore
|
||||||
if e.cancel:
|
if e.cancel:
|
||||||
|
@ -435,13 +417,37 @@ proc wantListHandler*(
|
||||||
# different want params
|
# different want params
|
||||||
peerCtx.peerWants[idx] = e # update entry
|
peerCtx.peerWants[idx] = e # update entry
|
||||||
|
|
||||||
|
if not e.cancel:
|
||||||
|
# Respond to wantHaves immediately
|
||||||
|
if e.wantType == WantType.WantHave:
|
||||||
|
let
|
||||||
|
have = await e.address in b.localStore
|
||||||
|
price = @(
|
||||||
|
b.pricing.get(Pricing(price: 0.u256))
|
||||||
|
.price.toBytesBE)
|
||||||
|
|
||||||
|
if not have and e.sendDontHave:
|
||||||
|
presence.add(
|
||||||
|
BlockPresence(
|
||||||
|
address: e.address,
|
||||||
|
`type`: BlockPresenceType.DontHave,
|
||||||
|
price: price))
|
||||||
|
elif have:
|
||||||
|
presence.add(
|
||||||
|
BlockPresence(
|
||||||
|
address: e.address,
|
||||||
|
`type`: BlockPresenceType.Have,
|
||||||
|
price: price))
|
||||||
|
|
||||||
|
# Schedule handling of wantBlocks
|
||||||
|
if e.wantType == WantType.WantBlock:
|
||||||
|
if not b.scheduleTask(peerCtx):
|
||||||
|
warn "Unable to schedule task for peer", peer
|
||||||
|
|
||||||
if presence.len > 0:
|
if presence.len > 0:
|
||||||
trace "Sending presence to remote", items = presence.mapIt($it).join(",")
|
trace "Sending presence to remote", items = presence.mapIt($it).join(",")
|
||||||
await b.network.request.sendPresence(peer, presence)
|
await b.network.request.sendPresence(peer, presence)
|
||||||
|
|
||||||
if not b.scheduleTask(peerCtx):
|
|
||||||
warn "Unable to schedule task for peer", peer
|
|
||||||
|
|
||||||
proc accountHandler*(
|
proc accountHandler*(
|
||||||
engine: BlockExcEngine,
|
engine: BlockExcEngine,
|
||||||
peer: PeerId,
|
peer: PeerId,
|
||||||
|
|
|
@ -32,7 +32,7 @@ logScope:
|
||||||
type
|
type
|
||||||
PeerCtxStore* = ref object of RootObj
|
PeerCtxStore* = ref object of RootObj
|
||||||
peers*: OrderedTable[PeerId, BlockExcPeerCtx]
|
peers*: OrderedTable[PeerId, BlockExcPeerCtx]
|
||||||
PeersForBlock* = ref object of RootObj
|
PeersForBlock* = object of RootObj
|
||||||
with*: seq[BlockExcPeerCtx]
|
with*: seq[BlockExcPeerCtx]
|
||||||
without*: seq[BlockExcPeerCtx]
|
without*: seq[BlockExcPeerCtx]
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue