From 0227dfe592d59a48c5d6cf9410164e7e035714b8 Mon Sep 17 00:00:00 2001 From: weboko Date: Wed, 7 Dec 2022 23:46:22 +0100 Subject: [PATCH] add light-chat basic functionality + template for html Signed-off-by: weboko --- light-chat/index.html | 35 ++++++++++++++++++++++++++++++ light-chat/index.js | 48 +++++++++++++++++++++++++++++++++++++++++ light-chat/package.json | 14 ++++++++++++ 3 files changed, 97 insertions(+) create mode 100644 light-chat/index.html create mode 100644 light-chat/index.js create mode 100644 light-chat/package.json diff --git a/light-chat/index.html b/light-chat/index.html new file mode 100644 index 0000000..b35c91d --- /dev/null +++ b/light-chat/index.html @@ -0,0 +1,35 @@ + + + + + + JS-Waku light chat + + + +

Status

+
+ +

Local Peer Id

+
+ +

Remote Peer Id

+
+ +

Remote peer's multiaddr

+
+ +
+ +
+ +
+ +
+ + +
+ + + + diff --git a/light-chat/index.js b/light-chat/index.js new file mode 100644 index 0000000..2324b95 --- /dev/null +++ b/light-chat/index.js @@ -0,0 +1,48 @@ +import * as utils from 'https://unpkg.com/@waku/byte-utils@0.0.2/bundle/index.js'; +import * as wakuCreate from 'https://unpkg.com/@waku/create@0.0.4/bundle/index.js' +import { waitForRemotePeer } from 'https://unpkg.com/@waku/core@0.0.6/bundle/lib/wait_for_remote_peer.js' +import * as wakuMessage from 'https://unpkg.com/@waku/core@0.0.6/bundle/lib/waku_message/version_0.js' + +const MULTI_ADDR = "/dns4/node-01.ac-cn-hongkong-c.wakuv2.test.statusim.net/tcp/443/wss/p2p/16Uiu2HAkvWiyFsgRhuJEb9JfjYxEkoHLgnUQmr1N5mKWnYjxYRVm"; +const CONTENT_TOPIC = "/js-waku-examples/1/chat/utf8"; +const PROTOCOLS = ["filter", "lightpush"]; + +const { sendMessage, unsubscribeFromMessages } = await initializeWakuContext({ + multiAddr: MULTI_ADDR, + protocols: PROTOCOLS, + contentTopic: CONTENT_TOPIC, + onMessageReceived: (message) => { + console.log(message); + }, +}); + +async function initializeWakuContext({ + multiAddr, + protocols, + contentTopic, + onMessageReceived, +}) { + const Decoder = new wakuMessage.DecoderV0(contentTopic); + const Encoder = new wakuMessage.EncoderV0(contentTopic); + + const node = await wakuCreate.createLightNode(); + + await node.start(); + + await node.dial(multiAddr, protocols); + await waitForRemotePeer(node, protocols); + + const unsubscribeFromMessages = await node.filter.subscribe([Decoder], (wakuMessage) => { + const messageText = utils.bytesToUtf8(wakuMessage.payload); + onMessageReceived(messageText); + }); + + return { + unsubscribeFromMessages, + sendMessage: async (value) => { + await node.lightPush.push(Encoder, { + payload: utils.utf8ToBytes(value) + }); + } + }; +} diff --git a/light-chat/package.json b/light-chat/package.json new file mode 100644 index 0000000..63237e7 --- /dev/null +++ b/light-chat/package.json @@ -0,0 +1,14 @@ +{ + "name": "light-chat", + "version": "0.1.0", + "private": true, + "homepage": "/light-chat", + "devDependencies": { + "serve": "^14.1.2", + "gh-pages": "^4.0.0" + }, + "scripts": { + "start": "serve .", + "deploy": "gh-pages -d ." + } +}