Improve count of relay peers

Active relay peers are peer which are part of the gossip mesh.
Which means that it's not just a peer we are connect to but a peer on
subscribed to the same pubsub topic, with a good score, part of the
mesh, etc.

Mesh maintenance is done during the gossipsub hearbeat so it's the best
time to review the count.

A store peer is any peer we are connected to that support the store
protocol, so it can be counted when a new peer is added to the store.

This does not cater for store peers that disconnect, but we are not
handling those just yet.
This commit is contained in:
Franck Royer 2022-02-28 17:23:30 +11:00
parent 88a92e277c
commit e6d3c2f595
No known key found for this signature in database
GPG Key ID: A82ED75A8DFC50A4

View File

@ -7,7 +7,6 @@ import { TitleBar } from "@livechat/ui-kit";
import { Message } from "./Message"; import { Message } from "./Message";
import { ChatMessage } from "./chat_message"; import { ChatMessage } from "./chat_message";
import { useEffect, useState } from "react"; import { useEffect, useState } from "react";
import PeerId from "peer-id";
interface Props { interface Props {
messages: Message[]; messages: Message[];
@ -18,41 +17,31 @@ interface Props {
export default function Room(props: Props) { export default function Room(props: Props) {
const { waku } = useWaku(); const { waku } = useWaku();
const [peers, setPeers] = useState<PeerId[]>([]);
const [storePeers, setStorePeers] = useState(0); const [storePeers, setStorePeers] = useState(0);
const [relayPeers, setRelayPeers] = useState(0); const [relayPeers, setRelayPeers] = useState(0);
useEffect(() => { useEffect(() => {
// Add a peer to the list every time a connection happen to ensure the stats update correctly
if (!waku) return; if (!waku) return;
const addPeer = (event: { peerId: PeerId }) => { // Update relay peer count on heartbeat
setPeers((peers) => { waku.relay.on("gossipsub:heartbeat", () => {
return [...peers, event.peerId]; setRelayPeers(waku.relay.getPeers().size);
}); });
};
waku.libp2p.peerStore.on("change:protocols", addPeer);
return () => {
waku.libp2p.connectionManager.removeListener("change:protocols", addPeer);
};
}, [waku]); }, [waku]);
useEffect(() => { useEffect(() => {
if (!waku) return; if (!waku) return;
setRelayPeers(waku.relay.getPeers().size); // Update store peer when new peer connected & identified
waku.libp2p.peerStore.on("change:protocols", async () => {
(async () => {
let counter = 0; let counter = 0;
// eslint-disable-next-line @typescript-eslint/no-unused-vars // eslint-disable-next-line @typescript-eslint/no-unused-vars
for await (const _peer of waku.store.peers) { for await (const _peer of waku.store.peers) {
counter++; counter++;
} }
setStorePeers(counter); setStorePeers(counter);
})(); });
}, [waku, peers]); }, [waku]);
return ( return (
<div <div