mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-27 23:27:27 +00:00
XXX: Try to use .PubSub on WakuRelay
This commit is contained in:
parent
37c24a2634
commit
3a3139e4cf
@ -27,7 +27,8 @@ proc setupWakuRPC*(node: WakuNode, rpcsrv: RpcServer) =
|
||||
# XXX also future return type
|
||||
# TODO: Shouldn't we really be doing WakuNode publish here?
|
||||
debug "waku_publish", topic=topic, payload=payload
|
||||
discard wakuRelay.publish(topic, payload)
|
||||
# XXX Doesn't work, remove this - using waku_publish2 instead now, except for simulation
|
||||
#discard wakuRelay.publish(topic, payload)
|
||||
return true
|
||||
#if not result:
|
||||
# raise newException(ValueError, "Message could not be posted")
|
||||
|
@ -32,7 +32,9 @@ type
|
||||
# NOTE based on Eth2Node in NBC eth2_network.nim
|
||||
WakuNode* = ref object of RootObj
|
||||
switch*: Switch
|
||||
wakuRelay*: WakuRelay
|
||||
#XXX
|
||||
#wakuRelay*: WakuRelay
|
||||
wakuRelay*: PubSub
|
||||
peerInfo*: PeerInfo
|
||||
libp2pTransportLoops*: seq[Future[void]]
|
||||
# TODO Revist messages field indexing as well as if this should be Message or WakuMessage
|
||||
|
@ -7,7 +7,7 @@ import
|
||||
libp2p/crypto/crypto,
|
||||
libp2p/protocols/protocol,
|
||||
# NOTE For TopicHandler, solve with exports?
|
||||
libp2p/protocols/pubsub/pubsub,
|
||||
libp2p/protocols/pubsub/[pubsub, floodsub, gossipsub],
|
||||
libp2p/peerinfo,
|
||||
libp2p/standard_setup,
|
||||
../../protocol/v2/[waku_relay, waku_store, waku_filter],
|
||||
@ -73,22 +73,23 @@ proc init*(T: type WakuNode, nodeKey: crypto.PrivateKey,
|
||||
|
||||
var switch = newStandardSwitch(some(nodekey), hostAddress)
|
||||
# TODO Untested - verify behavior after switch interface change
|
||||
# More like this:
|
||||
let wakuRelay = WakuRelay.init(
|
||||
switch = switch,
|
||||
triggerSelf = true,
|
||||
sign = false,
|
||||
verifySignature = false).PubSub
|
||||
switch.mount(wakuRelay)
|
||||
|
||||
#NBC
|
||||
#let pubsub = GossipSub.init(
|
||||
# switch = switch,
|
||||
# msgIdProvider = msgIdProvider,
|
||||
# triggerSelf = true, sign = false,
|
||||
# verifySignature = false).PubSub
|
||||
let wakuRelay = WakuRelay.init(
|
||||
switch = switch,
|
||||
# Use default
|
||||
#msgIdProvider = msgIdProvider,
|
||||
triggerSelf = true,
|
||||
sign = false,
|
||||
verifySignature = false)
|
||||
# This gets messy with: .PubSub
|
||||
switch.mount(wakuRelay)
|
||||
#switch.mount(pubsub)
|
||||
|
||||
|
||||
# XXX: pubSub and wakuRelay a bit confusing here
|
||||
result = WakuNode(switch: switch, peerInfo: peerInfo, wakuRelay: wakuRelay)
|
||||
|
||||
for topic in topics:
|
||||
|
@ -39,10 +39,12 @@ method initPubSub*(w: WakuRelay) =
|
||||
# Not using GossipSub
|
||||
w.gossipEnabled = false
|
||||
|
||||
if w.gossipEnabled:
|
||||
procCall GossipSub(w).initPubSub()
|
||||
else:
|
||||
procCall FloodSub(w).initPubSub()
|
||||
# XXX: Unclear how we toggle with gossip/flood here?
|
||||
#if w.gossipEnabled:
|
||||
# procCall GossipSub(w).initPubSub()
|
||||
#else:
|
||||
# procCall FloodSub(w).initPubSub()
|
||||
procCall PubSub(w).initPubSub()
|
||||
|
||||
w.init()
|
||||
|
||||
@ -50,10 +52,12 @@ method subscribe*(w: WakuRelay,
|
||||
pubSubTopic: string,
|
||||
handler: TopicHandler) {.async.} =
|
||||
debug "subscribe", pubSubTopic=pubSubTopic
|
||||
if w.gossipEnabled:
|
||||
await procCall GossipSub(w).subscribe(pubSubTopic, handler)
|
||||
else:
|
||||
await procCall FloodSub(w).subscribe(pubSubTopic, handler)
|
||||
|
||||
await procCall PubSub(w).subscribe(pubSubTopic, handler)
|
||||
#if w.gossipEnabled:
|
||||
# await procCall GossipSub(w).subscribe(pubSubTopic, handler)
|
||||
#else:
|
||||
# await procCall FloodSub(w).subscribe(pubSubTopic, handler)
|
||||
|
||||
method publish*(w: WakuRelay,
|
||||
pubSubTopic: string,
|
||||
@ -61,30 +65,36 @@ method publish*(w: WakuRelay,
|
||||
): Future[int] {.async.} =
|
||||
debug "publish", pubSubTopic=pubSubTopic, message=message
|
||||
|
||||
if w.gossipEnabled:
|
||||
return await procCall GossipSub(w).publish(pubSubTopic, message)
|
||||
else:
|
||||
return await procCall FloodSub(w).publish(pubSubTopic, message)
|
||||
return await procCall PubSub(w).publish(pubSubTopic, message)
|
||||
#if w.gossipEnabled:
|
||||
# return await procCall GossipSub(w).publish(pubSubTopic, message)
|
||||
#else:
|
||||
# return await procCall FloodSub(w).publish(pubSubTopic, message)
|
||||
|
||||
method unsubscribe*(w: WakuRelay,
|
||||
topics: seq[TopicPair]) {.async.} =
|
||||
debug "unsubscribe"
|
||||
if w.gossipEnabled:
|
||||
await procCall GossipSub(w).unsubscribe(topics)
|
||||
else:
|
||||
await procCall FloodSub(w).unsubscribe(topics)
|
||||
await procCall PubSub(w).unsubscribe(topics)
|
||||
#if w.gossipEnabled:
|
||||
# await procCall GossipSub(w).unsubscribe(topics)
|
||||
#else:
|
||||
# await procCall FloodSub(w).unsubscribe(topics)
|
||||
|
||||
# GossipSub specific methods --------------------------------------------------
|
||||
method start*(w: WakuRelay) {.async.} =
|
||||
debug "start"
|
||||
if w.gossipEnabled:
|
||||
await procCall GossipSub(w).start()
|
||||
else:
|
||||
await procCall FloodSub(w).start()
|
||||
# XXX: This is in GossipSub
|
||||
await procCall PubSub(w).start()
|
||||
# if w.gossipEnabled:
|
||||
# await procCall GossipSub(w).start()
|
||||
# else:
|
||||
# await procCall FloodSub(w).start()
|
||||
|
||||
method stop*(w: WakuRelay) {.async.} =
|
||||
debug "stop"
|
||||
if w.gossipEnabled:
|
||||
await procCall GossipSub(w).stop()
|
||||
else:
|
||||
await procCall FloodSub(w).stop()
|
||||
# XXX: This is in GossipSub
|
||||
await procCall PubSub(w).start()
|
||||
# if w.gossipEnabled:
|
||||
# await procCall GossipSub(w).stop()
|
||||
# else:
|
||||
# await procCall FloodSub(w).stop()
|
||||
|
Loading…
x
Reference in New Issue
Block a user