mirror of
https://github.com/status-im/js-waku-examples.git
synced 2025-01-13 15:34:58 +00:00
feat(light-js): add discovery of a peer (#250)
* add discovery of a peer * rename
This commit is contained in:
parent
6de29d7f02
commit
0ba66bcb20
@ -20,11 +20,7 @@
|
|||||||
<div id="remote-peer-id"></div>
|
<div id="remote-peer-id"></div>
|
||||||
|
|
||||||
<label for="remote-multiaddr">Remote peer's multiaddr</label>
|
<label for="remote-multiaddr">Remote peer's multiaddr</label>
|
||||||
<input
|
<input id="remote-multiaddr" type="text" value="" />
|
||||||
id="remote-multiaddr"
|
|
||||||
type="text"
|
|
||||||
value="/dns4/node-01.ac-cn-hongkong-c.wakuv2.test.statusim.net/tcp/8000/wss/p2p/16Uiu2HAkvWiyFsgRhuJEb9JfjYxEkoHLgnUQmr1N5mKWnYjxYRVm"
|
|
||||||
/>
|
|
||||||
<button disabled id="dial" type="button">Dial</button>
|
<button disabled id="dial" type="button">Dial</button>
|
||||||
<br />
|
<br />
|
||||||
<button disabled id="subscribe" type="button">Subscribe with Filter</button>
|
<button disabled id="subscribe" type="button">Subscribe with Filter</button>
|
||||||
@ -50,6 +46,10 @@
|
|||||||
utf8ToBytes,
|
utf8ToBytes,
|
||||||
bytesToUtf8,
|
bytesToUtf8,
|
||||||
} from "https://unpkg.com/@waku/sdk@0.0.16/bundle/index.js";
|
} from "https://unpkg.com/@waku/sdk@0.0.16/bundle/index.js";
|
||||||
|
import {
|
||||||
|
enrTree,
|
||||||
|
DnsNodeDiscovery,
|
||||||
|
} from "https://unpkg.com/@waku/dns-discovery@0.0.14/bundle/index.js";
|
||||||
|
|
||||||
const peerIdDiv = document.getElementById("peer-id");
|
const peerIdDiv = document.getElementById("peer-id");
|
||||||
const remotePeerIdDiv = document.getElementById("remote-peer-id");
|
const remotePeerIdDiv = document.getElementById("remote-peer-id");
|
||||||
@ -74,6 +74,14 @@
|
|||||||
div.innerHTML += "</ul>";
|
div.innerHTML += "</ul>";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
try {
|
||||||
|
await searchForPeer(statusDiv, remoteMultiAddrDiv);
|
||||||
|
} catch (e) {
|
||||||
|
console.log("Failed to find a peer", e);
|
||||||
|
remoteMultiAddrDiv.value =
|
||||||
|
"/dns4/node-01.ac-cn-hongkong-c.wakuv2.test.statusim.net/tcp/8000/wss/p2p/16Uiu2HAkvWiyFsgRhuJEb9JfjYxEkoHLgnUQmr1N5mKWnYjxYRVm";
|
||||||
|
}
|
||||||
|
|
||||||
statusDiv.innerHTML = "<p>Creating Waku node.</p>";
|
statusDiv.innerHTML = "<p>Creating Waku node.</p>";
|
||||||
const node = await createLightNode();
|
const node = await createLightNode();
|
||||||
|
|
||||||
@ -130,6 +138,21 @@
|
|||||||
console.log("Message sent!");
|
console.log("Message sent!");
|
||||||
textInput.value = null;
|
textInput.value = null;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
async function searchForPeer(statusNode, multiaddrNode) {
|
||||||
|
statusDiv.innerHTML = "<p>Discovering peer</p>";
|
||||||
|
|
||||||
|
const dnsDiscovery = await DnsNodeDiscovery.dnsOverHttp();
|
||||||
|
const peersIterator = await dnsDiscovery.getNextPeer(
|
||||||
|
[enrTree["TEST"]],
|
||||||
|
{ lightPush: 1, filter: 1 }
|
||||||
|
);
|
||||||
|
const peerEnr = await peersIterator.next();
|
||||||
|
const ma = peerEnr.value.multiaddrs.map((v) => v.toString())[1];
|
||||||
|
const peerId = peerEnr.value.peerId.toString();
|
||||||
|
|
||||||
|
multiaddrNode.value = `${ma}/p2p/${peerId}`;
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user