Skip to content

Commit

Permalink
implement dns discovery on failed dials
Browse files Browse the repository at this point in the history
  • Loading branch information
weboko committed Sep 2, 2024
1 parent da6cca4 commit 39d2389
Show file tree
Hide file tree
Showing 4 changed files with 43 additions and 5 deletions.
27 changes: 27 additions & 0 deletions packages/core/src/lib/connection_manager.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@ import type { Peer, PeerId, PeerInfo, PeerStore } from "@libp2p/interface";
import { CustomEvent, TypedEventEmitter } from "@libp2p/interface";
import {
ConnectionManagerOptions,
DiscoveryTrigger,
DNS_DISCOVERY_TAG,
EConnectionStateEvents,
EPeersByDiscoveryEvents,
IConnectionManager,
Expand Down Expand Up @@ -291,7 +293,11 @@ export class ConnectionManager
}

this.dialErrorsForPeer.delete(peerId.toString());
this.dialAttemptsForPeer.delete(peerId.toString());
await this.libp2p.peerStore.delete(peerId);

// if it was last available peer - attempt DNS discovery
await this.attemptDnsDiscovery();
} catch (error) {
throw new Error(
`Error deleting undialable peer ${peerId.toString()} from peer store - ${error}`
Expand All @@ -300,6 +306,27 @@ export class ConnectionManager
}
}

private async attemptDnsDiscovery(): Promise<void> {
if (this.libp2p.getConnections().length > 0) return;
if ((await this.libp2p.peerStore.all()).length > 0) return;

log.info("Attempting to trigger DNS discovery.");

const dnsDiscovery = Object.values(this.libp2p.components.components).find(
(v: unknown) => {
if (v && v.toString) {
return v.toString().includes(DNS_DISCOVERY_TAG);
}

return false;
}
) as DiscoveryTrigger;

if (!dnsDiscovery) return;

await dnsDiscovery.findPeers();
}

private processDialQueue(): void {
if (
this.pendingPeerDialQueue.length > 0 &&
Expand Down
4 changes: 2 additions & 2 deletions packages/discovery/src/dns/constants.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,6 @@ export const DEFAULT_BOOTSTRAP_TAG_TTL = 100_000_000;

export const DEFAULT_NODE_REQUIREMENTS: Partial<NodeCapabilityCount> = {
store: 1,
filter: 2,
lightPush: 2
filter: 1,
lightPush: 1
};
11 changes: 8 additions & 3 deletions packages/discovery/src/dns/dns_discovery.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,11 +7,13 @@ import {
import { peerDiscoverySymbol as symbol } from "@libp2p/interface";
import type { PeerInfo } from "@libp2p/interface";
import type {
DiscoveryTrigger,
DnsDiscOptions,
DnsDiscoveryComponents,
IEnr,
NodeCapabilityCount
} from "@waku/interfaces";
import { DNS_DISCOVERY_TAG } from "@waku/interfaces";
import { encodeRelayShard, Logger } from "@waku/utils";

import {
Expand All @@ -29,7 +31,7 @@ const log = new Logger("peer-discovery-dns");
*/
export class PeerDiscoveryDns
extends TypedEventEmitter<PeerDiscoveryEvents>
implements PeerDiscovery
implements PeerDiscovery, DiscoveryTrigger
{
private nextPeer: (() => AsyncGenerator<IEnr>) | undefined;
private _started: boolean;
Expand All @@ -56,8 +58,11 @@ export class PeerDiscoveryDns
log.info("Starting peer discovery via dns");

this._started = true;
await this.findPeers();
}

if (this.nextPeer === undefined) {
public async findPeers(): Promise<void> {
if (!this.nextPeer) {
let { enrUrls } = this._options;
if (!Array.isArray(enrUrls)) enrUrls = [enrUrls];

Expand Down Expand Up @@ -134,7 +139,7 @@ export class PeerDiscoveryDns
}

public get [Symbol.toStringTag](): string {
return "@waku/bootstrap";
return DNS_DISCOVERY_TAG;
}
}

Expand Down
6 changes: 6 additions & 0 deletions packages/interfaces/src/dns_discovery.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
import { PeerStore } from "@libp2p/interface";

export const DNS_DISCOVERY_TAG = "@waku/bootstrap";

export type SearchContext = {
domain: string;
publicKey: string;
Expand Down Expand Up @@ -45,3 +47,7 @@ export interface DnsDiscOptions {
*/
tagTTL?: number;
}

export interface DiscoveryTrigger {
findPeers: () => Promise<void>;
}

0 comments on commit 39d2389

Please sign in to comment.