trying events from repostore

This commit is contained in:
Ben 2024-04-24 16:08:05 +02:00
parent eb8f468880
commit bf650fc2fd
No known key found for this signature in database
GPG Key ID: 541B9D8C9F1426A1
4 changed files with 54 additions and 4 deletions

View File

@ -308,7 +308,7 @@ proc getAnnouceCids(blocksDelivery: seq[BlockDelivery]): seq[Cid] =
cids.incl(bd.address.cid)
return cids.toSeq
proc resolveBlocks*(b: BlockExcEngine, blocksDelivery: seq[BlockDelivery]) {.async.} =
proc resolveBlocks(b: BlockExcEngine, blocksDelivery: seq[BlockDelivery]) {.async.} =
trace "Resolving blocks", blocks = blocksDelivery.len
b.pendingBlocks.resolve(blocksDelivery)
@ -318,7 +318,7 @@ proc resolveBlocks*(b: BlockExcEngine, blocksDelivery: seq[BlockDelivery]) {.asy
b.discovery.queueProvideBlocksReq(announceCids)
proc resolveBlocks*(b: BlockExcEngine, blocks: seq[Block]) {.async.} =
proc resolveBlocks(b: BlockExcEngine, blocks: seq[Block]) {.async.} =
await b.resolveBlocks(
blocks.mapIt(
BlockDelivery(blk: it, address: BlockAddress(leaf: false, cid: it.cid)
@ -400,7 +400,7 @@ proc blocksDeliveryHandler*(
validatedBlocksDelivery.add(bd)
await b.resolveBlocks(validatedBlocksDelivery)
# await b.resolveBlocks(validatedBlocksDelivery)
codex_block_exchange_blocks_received.inc(validatedBlocksDelivery.len.int64)
let
@ -679,6 +679,26 @@ proc new*(
proc paymentHandler(peer: PeerId, payment: SignedState): Future[void] {.gcsafe.} =
engine.paymentHandler(peer, payment)
proc onBlockPutHandler(event: BlockPutEvent): Future[?!void] {.async.} =
let delivery = BlockDelivery(
address: event.address,
proof: CodexProof.none
)
engine.resolveBlocks(@[delivery])
success()
proc onCidAndProofHandler(event: ProofPutEvent): Future[?!void] {.async.} =
let delivery = BlockDelivery(
address: BlockAddress(leaf: true, cid: event.blockCid),
proof: event.proof.some
)
engine.resolveBlocks(@[delivery])
success()
localStore.onBlockPutEvent.subscribe(onBlockPutHandler)
localStore.onCidAndProofPutEvent.subscribe(onCidAndProofHandler)
network.handlers = BlockExcHandlers(
onWantList: blockWantListHandler,
onBlocksDelivery: blocksDeliveryHandler,

View File

@ -29,7 +29,19 @@ type
BlockType* {.pure.} = enum
Manifest, Block, Both
BlockPutEvent* = object
blk*: Block
address*: BlockAddress
ProofPutEvent* = object
treeCid*: Cid
index*: Natural
blockCid*: Cid
proof*: CodexProof
BlockStore* = ref object of RootObj
onBlockPutEvent*: AsyncDataEvent[BlockPutEvent]
onCidAndProofPutEvent*: AsyncDataEvent[ProofPutEvent]
method getBlock*(self: BlockStore, cid: Cid): Future[?!Block] {.base.} =
## Get a block from the blockstore

View File

@ -76,7 +76,7 @@ method putBlock*(
if res.isErr:
return res
await self.engine.resolveBlocks(@[blk])
# await self.engine.resolveBlocks(@[blk])
return success()
method putCidAndProof*(

View File

@ -125,6 +125,15 @@ method putCidAndProof*(
await self.metaDs.put(key, value)
let event = ProofPutEvent(
treeCid: treeCid,
index: index,
blockCid: blockCid,
proof: proof
)
await self.onCidAndProofPutEvent.fire(event)
method getCidAndProof*(
self: RepoStore,
treeCid: Cid,
@ -360,6 +369,15 @@ method putBlock*(
trace "Unable to update block total metadata"
return failure("Unable to update block total metadata")
let event = BlockPutEvent(
blk: blk,
address: BlockAddress(leaf: false, cid: blk.cid)
)
? await self.onBlockPutEvent.fire(event)
# # todo propagate error message!
# return failure("Error during put-block event.")
self.updateMetrics()
return success()