mirror of
https://github.com/codex-storage/nim-codex.git
synced 2025-01-23 19:31:53 +00:00
Add handler for pricing messages
This commit is contained in:
parent
364d3a9277
commit
5f9215a371
@ -17,10 +17,12 @@ import pkg/nitro
|
||||
|
||||
import ../blocktype as bt
|
||||
import ./protobuf/bitswap as pb
|
||||
import ./protobuf/payments
|
||||
import ./networkpeer
|
||||
|
||||
export pb, networkpeer
|
||||
export nitro
|
||||
export payments
|
||||
|
||||
logScope:
|
||||
topics = "dagger bitswap network"
|
||||
@ -31,11 +33,13 @@ type
|
||||
WantListHandler* = proc(peer: PeerID, wantList: WantList) {.gcsafe.}
|
||||
BlocksHandler* = proc(peer: PeerID, blocks: seq[bt.Block]) {.gcsafe.}
|
||||
BlockPresenceHandler* = proc(peer: PeerID, precense: seq[BlockPresence]) {.gcsafe.}
|
||||
PricingHandler* = proc(peer: PeerID, pricing: Pricing) {.gcsafe.}
|
||||
|
||||
BitswapHandlers* = object
|
||||
onWantList*: WantListHandler
|
||||
onBlocks*: BlocksHandler
|
||||
onPresence*: BlockPresenceHandler
|
||||
onPricing*: PricingHandler
|
||||
|
||||
WantListBroadcaster* = proc(
|
||||
id: PeerID,
|
||||
@ -195,6 +199,13 @@ proc broadcastBlockPresence*(
|
||||
trace "Sending presence to peer", peer = id
|
||||
asyncSpawn b.peers[id].send(Message(blockPresences: presence))
|
||||
|
||||
proc handlePricing(network: BitswapNetwork,
|
||||
peer: NetworkPeer,
|
||||
pricing: Pricing) =
|
||||
if network.handlers.onPricing.isNil:
|
||||
return
|
||||
network.handlers.onPricing(peer.id, pricing)
|
||||
|
||||
proc rpcHandler(b: BitswapNetwork, peer: NetworkPeer, msg: Message) {.async.} =
|
||||
try:
|
||||
if msg.wantlist.entries.len > 0:
|
||||
@ -209,6 +220,9 @@ proc rpcHandler(b: BitswapNetwork, peer: NetworkPeer, msg: Message) {.async.} =
|
||||
if msg.blockPresences.len > 0:
|
||||
b.handleBlockPresence(peer, msg.blockPresences)
|
||||
|
||||
if pricing =? Pricing.init(msg.pricing):
|
||||
b.handlePricing(peer, pricing)
|
||||
|
||||
except CatchableError as exc:
|
||||
trace "Exception in bitswap rpc handler", exc = exc.msg
|
||||
|
||||
|
@ -9,11 +9,13 @@ import pkg/protobuf_serialization
|
||||
|
||||
import pkg/dagger/stores/memorystore
|
||||
import pkg/dagger/bitswap/network
|
||||
import pkg/dagger/bitswap/protobuf/payments
|
||||
import pkg/dagger/p2p/rng
|
||||
import pkg/dagger/chunker
|
||||
import pkg/dagger/blocktype as bt
|
||||
|
||||
import ../helpers
|
||||
import ../examples
|
||||
|
||||
suite "Bitswap network":
|
||||
let
|
||||
@ -102,6 +104,20 @@ suite "Bitswap network":
|
||||
|
||||
await done.wait(500.millis)
|
||||
|
||||
test "handles pricing messages":
|
||||
let pricing = Pricing.example
|
||||
|
||||
proc handlePricing(peer: PeerID, received: Pricing) =
|
||||
check received == pricing
|
||||
done.complete()
|
||||
|
||||
network.handlers.onPricing = handlePricing
|
||||
|
||||
let message = Message(pricing: PricingMessage.init(pricing))
|
||||
await buffer.pushData(lenPrefix(Protobuf.encode(message)))
|
||||
|
||||
await done.wait(100.millis)
|
||||
|
||||
suite "Bitswap Network - e2e":
|
||||
let
|
||||
chunker = newRandomChunker(Rng.instance(), size = 1024, chunkSize = 256)
|
||||
|
@ -1,5 +1,6 @@
|
||||
import std/random
|
||||
import pkg/nitro
|
||||
import pkg/dagger/bitswap/protobuf/payments
|
||||
|
||||
proc example*(_: type EthAddress): EthAddress =
|
||||
EthPrivateKey.random().toPublicKey.toAddress
|
||||
@ -21,3 +22,10 @@ proc example*(_: type SignedState): SignedState =
|
||||
let nonce = UInt48.example
|
||||
let channel = wallet.openLedgerChannel(hub, chainId, nonce, asset, amount).get
|
||||
wallet.pay(channel, asset, receiver, amount).get
|
||||
|
||||
proc example*(_: type Pricing): Pricing =
|
||||
Pricing(
|
||||
address: EthAddress.example,
|
||||
asset: EthAddress.example,
|
||||
price: UInt256.example()
|
||||
)
|
||||
|
Loading…
x
Reference in New Issue
Block a user