mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-10 14:56:31 +00:00
8987d4a3ff
* feat: add filter-lightpush example * chore: examples/v2/filter_subscriber.nim Co-authored-by: Ivan Folgueira Bande <128452529+Ivansete-status@users.noreply.github.com> * chore: update examples/v2/filter_subscriber.nim Co-authored-by: Ivan Folgueira Bande <128452529+Ivansete-status@users.noreply.github.com> --------- Co-authored-by: Ivan Folgueira Bande <128452529+Ivansete-status@users.noreply.github.com>
58 lines
2.1 KiB
Nim
58 lines
2.1 KiB
Nim
## Example showing how a resource restricted client may
|
|
## use lightpush to publish messages without relay
|
|
|
|
import
|
|
chronicles,
|
|
chronos,
|
|
stew/byteutils,
|
|
stew/results
|
|
import
|
|
../../../waku/common/logging,
|
|
../../../waku/v2/node/peer_manager,
|
|
../../../waku/v2/waku_core,
|
|
../../../waku/v2/waku_lightpush/client
|
|
|
|
const
|
|
LightpushPeer = "/ip4/134.209.139.210/tcp/30303/p2p/16Uiu2HAmPLe7Mzm8TsYUubgCAW1aJoeFScxrLj8ppHFivPo97bUZ" # node-01.do-ams3.wakuv2.test.statusim.net on wakuv2.test
|
|
LightpushPubsubTopic = PubsubTopic("/waku/2/default-waku/proto")
|
|
LightpushContentTopic = ContentTopic("/examples/1/light-pubsub-example/proto")
|
|
|
|
proc publishMessages(wlc: WakuLightpushClient,
|
|
lightpushPeer: RemotePeerInfo,
|
|
lightpushPubsubTopic: PubsubTopic,
|
|
lightpushContentTopic: ContentTopic) {.async.} =
|
|
while true:
|
|
let text = "hi there i'm a lightpush publisher"
|
|
let message = WakuMessage(payload: toBytes(text), # content of the message
|
|
contentTopic: lightpushContentTopic, # content topic to publish to
|
|
ephemeral: true, # tell store nodes to not store it
|
|
timestamp: getNowInNanosecondTime()) # current timestamp
|
|
|
|
let wlpRes = await wlc.publish(lightpushPubsubTopic, message, lightpushPeer)
|
|
|
|
if wlpRes.isOk():
|
|
notice "published message using lightpush", message=message
|
|
else:
|
|
notice "failed to publish message using lightpush", err=wlpRes.error()
|
|
|
|
await sleepAsync(5000) # Publish every 5 seconds
|
|
|
|
proc setupAndPublish(rng: ref HmacDrbgContext) =
|
|
let lightpushPeer = parsePeerInfo(LightpushPeer).get()
|
|
|
|
setupLogLevel(logging.LogLevel.NOTICE)
|
|
notice "starting lightpush publisher"
|
|
|
|
var
|
|
switch = newStandardSwitch()
|
|
pm = PeerManager.new(switch)
|
|
wlc = WakuLightpushClient.new(pm, rng)
|
|
|
|
# Start maintaining subscription
|
|
asyncSpawn publishMessages(wlc, lightpushPeer, LightpushPubsubTopic, LightpushContentTopic)
|
|
|
|
when isMainModule:
|
|
let rng = newRng()
|
|
setupAndPublish(rng)
|
|
runForever()
|