mirror of
https://github.com/logos-messaging/js-waku.git
synced 2026-01-02 13:53:12 +00:00
* set peer-exchange with default bootstrap * only initialise protocols with bootstrap peers * update package * update package-lock * refactor `getPeers` while setting up a protocol * move codecs to `@waku/interfaces` * lightpush: send messages to multiple peers * only use multiple peers for LP and Filter * fix: ts warnings * lightpush: tests pass * update breaking changes for new API * move codecs back into protocol files * refactor: `getPeers()` * rm: log as an arg * add tsdoc for getPeers * add import * add prettier rule to eslint * add: peer exchange to sdk as a dep * fix eslint error * add try catch * revert unecessary diff * revert unecessary diff * fix imports * convert relaycodecs to array * remove: peerId as an arg for protocol methods * keep peerId as an arg for peer-exchange * remove: peerId from getPeers() * lightpush: extract hardcoded numPeers as a constant * return all peers if numPeers is 0 and increase readability for random peers * refactor considering more than 1 bootstrap peers can exist * use `getPeers` * change arg for `getPeers` to object * address comments * refactor tests for new API * lightpush: make constant the class variable * use `maxBootstrapPeers` instead of `includeBootstrap` * refactor protocols for new API * add tests for `getPeers` * skip getPeers test * rm: only from test * move tests to `base_protocol.spec.ts` * break down `getPeers` into a `filter` method * return all bootstrap peers if arg is 0 * refactor test without stubbing * address comments * update test title * move `filterPeers` to a separate file * address comments & add more test * make test title more verbose * address comments * remove ProtocolOptions * chore: refactor tests for new API * add defaults for getPeers * address comments * rm unneeded comment * address comment: add diversity of node tags to test * address comments * fix: imports
93 lines
2.8 KiB
TypeScript
93 lines
2.8 KiB
TypeScript
import type { Libp2p } from "@libp2p/interface";
|
|
import type { Stream } from "@libp2p/interface/connection";
|
|
import type { PeerId } from "@libp2p/interface/peer-id";
|
|
import { Peer, PeerStore } from "@libp2p/interface/peer-store";
|
|
import type { IBaseProtocol, Libp2pComponents } from "@waku/interfaces";
|
|
import { getPeersForProtocol, selectPeerForProtocol } from "@waku/utils/libp2p";
|
|
|
|
import { filterPeers } from "./filterPeers.js";
|
|
import { StreamManager } from "./stream_manager.js";
|
|
|
|
/**
|
|
* A class with predefined helpers, to be used as a base to implement Waku
|
|
* Protocols.
|
|
*/
|
|
export class BaseProtocol implements IBaseProtocol {
|
|
public readonly addLibp2pEventListener: Libp2p["addEventListener"];
|
|
public readonly removeLibp2pEventListener: Libp2p["removeEventListener"];
|
|
protected streamManager: StreamManager;
|
|
|
|
constructor(
|
|
public multicodec: string,
|
|
private components: Libp2pComponents
|
|
) {
|
|
this.addLibp2pEventListener = components.events.addEventListener.bind(
|
|
components.events
|
|
);
|
|
this.removeLibp2pEventListener = components.events.removeEventListener.bind(
|
|
components.events
|
|
);
|
|
|
|
this.streamManager = new StreamManager(
|
|
multicodec,
|
|
components.connectionManager.getConnections.bind(
|
|
components.connectionManager
|
|
),
|
|
this.addLibp2pEventListener
|
|
);
|
|
}
|
|
protected async getStream(peer: Peer): Promise<Stream> {
|
|
return this.streamManager.getStream(peer);
|
|
}
|
|
|
|
public get peerStore(): PeerStore {
|
|
return this.components.peerStore;
|
|
}
|
|
|
|
/**
|
|
* Returns known peers from the address book (`libp2p.peerStore`) that support
|
|
* the class protocol. Waku may or may not be currently connected to these
|
|
* peers.
|
|
*/
|
|
public async peers(): Promise<Peer[]> {
|
|
return getPeersForProtocol(this.peerStore, [this.multicodec]);
|
|
}
|
|
|
|
protected async getPeer(peerId?: PeerId): Promise<Peer> {
|
|
const { peer } = await selectPeerForProtocol(
|
|
this.peerStore,
|
|
[this.multicodec],
|
|
peerId
|
|
);
|
|
return peer;
|
|
}
|
|
|
|
/**
|
|
* Retrieves a list of peers based on the specified criteria.
|
|
*
|
|
* @param numPeers - The total number of peers to retrieve. If 0, all peers are returned.
|
|
* @param maxBootstrapPeers - The maximum number of bootstrap peers to retrieve.
|
|
* @returns A Promise that resolves to an array of peers based on the specified criteria.
|
|
*/
|
|
protected async getPeers(
|
|
{
|
|
numPeers,
|
|
maxBootstrapPeers
|
|
}: {
|
|
numPeers: number;
|
|
maxBootstrapPeers: number;
|
|
} = {
|
|
maxBootstrapPeers: 1,
|
|
numPeers: 0
|
|
}
|
|
): Promise<Peer[]> {
|
|
// Retrieve all peers that support the protocol
|
|
const allPeersForProtocol = await getPeersForProtocol(this.peerStore, [
|
|
this.multicodec
|
|
]);
|
|
|
|
// Filter the peers based on the specified criteria
|
|
return filterPeers(allPeersForProtocol, numPeers, maxBootstrapPeers);
|
|
}
|
|
}
|