chore: rename node interfaces to include Node in name

Also rename node with only relay to `RelayNode`.
This commit is contained in:
fryorcraken.eth 2022-12-06 13:18:32 +11:00
parent d946e443ad
commit f743cfd1ca
No known key found for this signature in database
GPG Key ID: A82ED75A8DFC50A4
10 changed files with 61 additions and 66 deletions

View File

@ -15,12 +15,7 @@ import {
} from "@waku/core";
import { DefaultUserAgent } from "@waku/core";
import { getPredefinedBootstrapNodes } from "@waku/core/lib/predefined_bootstrap_nodes";
import type {
IRelay,
WakuFull,
WakuLight,
WakuPrivacy,
} from "@waku/interfaces";
import type { FullNode, IRelay, LightNode, RelayNode } from "@waku/interfaces";
import { wakuPeerExchange } from "@waku/peer-exchange";
import type { Libp2p } from "libp2p";
import { createLibp2p, Libp2pOptions } from "libp2p";
@ -74,7 +69,7 @@ export interface CreateOptions {
*/
export async function createLightNode(
options?: CreateOptions & WakuOptions
): Promise<WakuLight> {
): Promise<LightNode> {
const libp2pOptions = options?.libp2p ?? {};
const peerDiscovery = libp2pOptions.peerDiscovery ?? [];
if (options?.defaultBootstrap) {
@ -100,16 +95,16 @@ export async function createLightNode(
lightPush,
filter,
peerExchange
) as WakuLight;
) as LightNode;
}
/**
* Create a Waku node that uses Waku Relay to send and receive messages,
* enabling some privacy preserving properties.
*/
export async function createPrivacyNode(
export async function createRelayNode(
options?: CreateOptions & WakuOptions & Partial<RelayCreateOptions>
): Promise<WakuPrivacy> {
): Promise<RelayNode> {
const libp2pOptions = options?.libp2p ?? {};
const peerDiscovery = libp2pOptions.peerDiscovery ?? [];
if (options?.defaultBootstrap) {
@ -123,7 +118,7 @@ export async function createPrivacyNode(
options?.userAgent
);
return new WakuNode(options ?? {}, libp2p) as WakuPrivacy;
return new WakuNode(options ?? {}, libp2p) as RelayNode;
}
/**
@ -141,7 +136,7 @@ export async function createPrivacyNode(
*/
export async function createFullNode(
options?: CreateOptions & WakuOptions & Partial<RelayCreateOptions>
): Promise<WakuFull> {
): Promise<FullNode> {
const libp2pOptions = options?.libp2p ?? {};
const peerDiscovery = libp2pOptions.peerDiscovery ?? [];
if (options?.defaultBootstrap) {
@ -167,7 +162,7 @@ export async function createFullNode(
lightPush,
filter,
peerExchange
) as WakuFull;
) as FullNode;
}
export function defaultPeerDiscovery(): (

View File

@ -27,7 +27,7 @@ export interface Waku {
isStarted(): boolean;
}
export interface WakuLight extends Waku {
export interface LightNode extends Waku {
relay: undefined;
store: IStore;
filter: IFilter;
@ -35,7 +35,7 @@ export interface WakuLight extends Waku {
peerExchange: IPeerExchange;
}
export interface WakuPrivacy extends Waku {
export interface RelayNode extends Waku {
relay: IRelay;
store: undefined;
filter: undefined;
@ -43,7 +43,7 @@ export interface WakuPrivacy extends Waku {
peerExchange: undefined;
}
export interface WakuFull extends Waku {
export interface FullNode extends Waku {
relay: IRelay;
store: IStore;
filter: IFilter;

View File

@ -1,14 +1,14 @@
import { waitForRemotePeer } from "@waku/core";
import { createPrivacyNode } from "@waku/create";
import { createRelayNode } from "@waku/create";
import { ENR } from "@waku/enr";
import type { WakuPrivacy } from "@waku/interfaces";
import type { RelayNode } from "@waku/interfaces";
import { Protocols } from "@waku/interfaces";
import { expect } from "chai";
import { makeLogFileName, NOISE_KEY_1, Nwaku } from "../src/index.js";
describe("ENR Interop: nwaku", function () {
let waku: WakuPrivacy;
let waku: RelayNode;
let nwaku: Nwaku;
afterEach(async function () {
@ -27,7 +27,7 @@ describe("ENR Interop: nwaku", function () {
});
const multiAddrWithId = await nwaku.getMultiaddrWithId();
waku = await createPrivacyNode({
waku = await createRelayNode({
staticNoiseKey: NOISE_KEY_1,
});
await waku.start();
@ -59,7 +59,7 @@ describe("ENR Interop: nwaku", function () {
});
const multiAddrWithId = await nwaku.getMultiaddrWithId();
waku = await createPrivacyNode({
waku = await createRelayNode({
staticNoiseKey: NOISE_KEY_1,
});
await waku.start();
@ -91,7 +91,7 @@ describe("ENR Interop: nwaku", function () {
});
const multiAddrWithId = await nwaku.getMultiaddrWithId();
waku = await createPrivacyNode({
waku = await createRelayNode({
staticNoiseKey: NOISE_KEY_1,
});
await waku.start();

View File

@ -7,7 +7,7 @@ import {
} from "@waku/core";
import { createLightNode } from "@waku/create";
import { Protocols } from "@waku/interfaces";
import type { WakuLight } from "@waku/interfaces";
import type { LightNode } from "@waku/interfaces";
import {
createDecoder as eciesDecoder,
createEncoder as eciesEncoder,
@ -37,7 +37,7 @@ const TestEncoder = createEncoder(TestContentTopic);
const TestDecoder = createDecoder(TestContentTopic);
describe("Waku Message Ephemeral field", () => {
let waku: WakuLight;
let waku: LightNode;
let nwaku: Nwaku;
afterEach(async function () {

View File

@ -6,7 +6,7 @@ import {
waitForRemotePeer,
} from "@waku/core";
import { createLightNode } from "@waku/create";
import type { WakuLight } from "@waku/interfaces";
import type { LightNode } from "@waku/interfaces";
import { Protocols } from "@waku/interfaces";
import { expect } from "chai";
import debug from "debug";
@ -20,7 +20,7 @@ const TestEncoder = createEncoder(TestContentTopic);
const TestDecoder = createDecoder(TestContentTopic);
describe("Waku Filter", () => {
let waku: WakuLight;
let waku: LightNode;
let nwaku: Nwaku;
afterEach(async function () {

View File

@ -1,7 +1,7 @@
import { bytesToUtf8, utf8ToBytes } from "@waku/byte-utils";
import { createEncoder, waitForRemotePeer } from "@waku/core";
import { createLightNode } from "@waku/create";
import type { WakuLight } from "@waku/interfaces";
import type { LightNode } from "@waku/interfaces";
import { Protocols } from "@waku/interfaces";
import { expect } from "chai";
import debug from "debug";
@ -20,7 +20,7 @@ const TestContentTopic = "/test/1/waku-light-push/utf8";
const TestEncoder = createEncoder(TestContentTopic);
describe("Waku Light Push [node only]", () => {
let waku: WakuLight;
let waku: LightNode;
let nwaku: Nwaku;
afterEach(async function () {

View File

@ -7,8 +7,8 @@ import {
DefaultPubSubTopic,
waitForRemotePeer,
} from "@waku/core";
import { createPrivacyNode } from "@waku/create";
import type { WakuPrivacy } from "@waku/interfaces";
import { createRelayNode } from "@waku/create";
import type { RelayNode } from "@waku/interfaces";
import { Protocols } from "@waku/interfaces";
import {
createDecoder as createEciesDecoder,
@ -50,17 +50,17 @@ describe("Waku Relay [node only]", () => {
}
});
let waku1: WakuPrivacy;
let waku2: WakuPrivacy;
let waku1: RelayNode;
let waku2: RelayNode;
beforeEach(async function () {
this.timeout(10000);
log("Starting JS Waku instances");
[waku1, waku2] = await Promise.all([
createPrivacyNode({ staticNoiseKey: NOISE_KEY_1 }).then((waku) =>
createRelayNode({ staticNoiseKey: NOISE_KEY_1 }).then((waku) =>
waku.start().then(() => waku)
),
createPrivacyNode({
createRelayNode({
staticNoiseKey: NOISE_KEY_2,
libp2p: { addresses: { listen: ["/ip4/0.0.0.0/tcp/0/ws"] } },
}).then((waku) => waku.start().then(() => waku)),
@ -250,9 +250,9 @@ describe("Waku Relay [node only]", () => {
});
describe("Custom pubsub topic", () => {
let waku1: WakuPrivacy;
let waku2: WakuPrivacy;
let waku3: WakuPrivacy;
let waku1: RelayNode;
let waku2: RelayNode;
let waku3: RelayNode;
afterEach(async function () {
!!waku1 &&
waku1.stop().catch((e) => console.log("Waku failed to stop", e));
@ -270,16 +270,16 @@ describe("Waku Relay [node only]", () => {
// 1 and 2 uses a custom pubsub
// 3 uses the default pubsub
[waku1, waku2, waku3] = await Promise.all([
createPrivacyNode({
createRelayNode({
pubSubTopic: pubSubTopic,
staticNoiseKey: NOISE_KEY_1,
}).then((waku) => waku.start().then(() => waku)),
createPrivacyNode({
createRelayNode({
pubSubTopic: pubSubTopic,
staticNoiseKey: NOISE_KEY_2,
libp2p: { addresses: { listen: ["/ip4/0.0.0.0/tcp/0/ws"] } },
}).then((waku) => waku.start().then(() => waku)),
createPrivacyNode({
createRelayNode({
staticNoiseKey: NOISE_KEY_3,
}).then((waku) => waku.start().then(() => waku)),
]);
@ -331,12 +331,12 @@ describe("Waku Relay [node only]", () => {
});
describe("Interop: nwaku", function () {
let waku: WakuPrivacy;
let waku: RelayNode;
let nwaku: Nwaku;
beforeEach(async function () {
this.timeout(30_000);
waku = await createPrivacyNode({
waku = await createRelayNode({
staticNoiseKey: NOISE_KEY_1,
});
await waku.start();
@ -416,8 +416,8 @@ describe("Waku Relay [node only]", () => {
});
describe.skip("Two nodes connected to nwaku", function () {
let waku1: WakuPrivacy;
let waku2: WakuPrivacy;
let waku1: RelayNode;
let waku2: RelayNode;
let nwaku: Nwaku;
afterEach(async function () {
@ -431,11 +431,11 @@ describe("Waku Relay [node only]", () => {
it("Js publishes, other Js receives", async function () {
this.timeout(60_000);
[waku1, waku2] = await Promise.all([
createPrivacyNode({
createRelayNode({
staticNoiseKey: NOISE_KEY_1,
emitSelf: true,
}).then((waku) => waku.start().then(() => waku)),
createPrivacyNode({
createRelayNode({
staticNoiseKey: NOISE_KEY_2,
}).then((waku) => waku.start().then(() => waku)),
]);

View File

@ -7,7 +7,7 @@ import {
waitForRemotePeer,
} from "@waku/core";
import { createLightNode } from "@waku/create";
import type { IDecodedMessage, IMessage, WakuLight } from "@waku/interfaces";
import type { IDecodedMessage, IMessage, LightNode } from "@waku/interfaces";
import { Protocols } from "@waku/interfaces";
import {
createDecoder as createEciesDecoder,
@ -38,7 +38,7 @@ const TestEncoder = createEncoder(TestContentTopic);
const TestDecoder = createDecoder(TestContentTopic);
describe("Waku Store", () => {
let waku: WakuLight;
let waku: LightNode;
let nwaku: Nwaku;
beforeEach(async function () {
@ -559,7 +559,7 @@ describe("Waku Store", () => {
describe("Waku Store, custom pubsub topic", () => {
const customPubSubTopic = "/waku/2/custom-dapp/proto";
let waku: WakuLight;
let waku: LightNode;
let nwaku: Nwaku;
beforeEach(async function () {

View File

@ -1,14 +1,14 @@
import { waitForRemotePeer } from "@waku/core";
import { createLightNode, createPrivacyNode } from "@waku/create";
import type { WakuLight, WakuPrivacy } from "@waku/interfaces";
import { createLightNode, createRelayNode } from "@waku/create";
import type { LightNode, RelayNode } from "@waku/interfaces";
import { Protocols } from "@waku/interfaces";
import { expect } from "chai";
import { delay, makeLogFileName, NOISE_KEY_1, Nwaku } from "../src/index.js";
describe("Wait for remote peer", function () {
let waku1: WakuPrivacy;
let waku2: WakuLight;
let waku1: RelayNode;
let waku2: LightNode;
let nwaku: Nwaku | undefined;
afterEach(async function () {
@ -31,7 +31,7 @@ describe("Wait for remote peer", function () {
});
const multiAddrWithId = await nwaku.getMultiaddrWithId();
waku1 = await createPrivacyNode({
waku1 = await createRelayNode({
staticNoiseKey: NOISE_KEY_1,
});
await waku1.start();
@ -56,7 +56,7 @@ describe("Wait for remote peer", function () {
});
const multiAddrWithId = await nwaku.getMultiaddrWithId();
waku1 = await createPrivacyNode({
waku1 = await createRelayNode({
staticNoiseKey: NOISE_KEY_1,
});
await waku1.start();
@ -75,7 +75,7 @@ describe("Wait for remote peer", function () {
it("Relay - times out", function (done) {
this.timeout(5000);
createPrivacyNode({
createRelayNode({
staticNoiseKey: NOISE_KEY_1,
})
.then((waku1) => waku1.start().then(() => waku1))
@ -253,7 +253,7 @@ describe("Wait for remote peer", function () {
});
const multiAddrWithId = await nwaku.getMultiaddrWithId();
waku1 = await createPrivacyNode({
waku1 = await createRelayNode({
staticNoiseKey: NOISE_KEY_1,
});
await waku1.start();

View File

@ -6,8 +6,8 @@ import {
DefaultUserAgent,
waitForRemotePeer,
} from "@waku/core";
import { createLightNode, createPrivacyNode } from "@waku/create";
import type { Waku, WakuLight, WakuPrivacy } from "@waku/interfaces";
import { createLightNode, createRelayNode } from "@waku/create";
import type { LightNode, RelayNode, Waku } from "@waku/interfaces";
import { Protocols } from "@waku/interfaces";
import {
createDecoder,
@ -62,7 +62,7 @@ describe("Waku Dial [node only]", function () {
});
describe("Bootstrap", function () {
let waku: WakuLight;
let waku: LightNode;
let nwaku: Nwaku;
afterEach(async function () {
@ -134,15 +134,15 @@ describe("Decryption Keys", () => {
}
});
let waku1: WakuPrivacy;
let waku2: WakuPrivacy;
let waku1: RelayNode;
let waku2: RelayNode;
beforeEach(async function () {
this.timeout(5000);
[waku1, waku2] = await Promise.all([
createPrivacyNode({ staticNoiseKey: NOISE_KEY_1 }).then((waku) =>
createRelayNode({ staticNoiseKey: NOISE_KEY_1 }).then((waku) =>
waku.start().then(() => waku)
),
createPrivacyNode({
createRelayNode({
staticNoiseKey: NOISE_KEY_2,
libp2p: { addresses: { listen: ["/ip4/0.0.0.0/tcp/0/ws"] } },
}).then((waku) => waku.start().then(() => waku)),
@ -210,11 +210,11 @@ describe("User Agent", () => {
const waku1UserAgent = "test-user-agent";
[waku1, waku2] = await Promise.all([
createPrivacyNode({
createRelayNode({
staticNoiseKey: NOISE_KEY_1,
userAgent: waku1UserAgent,
}).then((waku) => waku.start().then(() => waku)),
createPrivacyNode({
createRelayNode({
staticNoiseKey: NOISE_KEY_2,
libp2p: { addresses: { listen: ["/ip4/0.0.0.0/tcp/0/ws"] } },
}).then((waku) => waku.start().then(() => waku)),