mirror of
https://github.com/waku-org/js-waku.git
synced 2025-01-13 22:15:04 +00:00
Move waku relay codec and default topic to constants module
This commit is contained in:
parent
7bd48b6220
commit
433a490dec
@ -3,7 +3,7 @@ import util from 'util';
|
|||||||
|
|
||||||
import Waku from '../lib/waku';
|
import Waku from '../lib/waku';
|
||||||
import { WakuMessage } from '../lib/waku_message';
|
import { WakuMessage } from '../lib/waku_message';
|
||||||
import { TOPIC } from '../lib/waku_relay';
|
import { RelayDefaultTopic } from '../lib/waku_relay';
|
||||||
import { delay } from '../test_utils/delay';
|
import { delay } from '../test_utils/delay';
|
||||||
|
|
||||||
import { ChatMessage } from './chat_message';
|
import { ChatMessage } from './chat_message';
|
||||||
@ -29,7 +29,7 @@ import { ChatMessage } from './chat_message';
|
|||||||
|
|
||||||
// TODO: Bubble event to waku, infer topic, decode msg
|
// TODO: Bubble event to waku, infer topic, decode msg
|
||||||
// Tracked with https://github.com/status-im/js-waku/issues/19
|
// Tracked with https://github.com/status-im/js-waku/issues/19
|
||||||
waku.libp2p.pubsub.on(TOPIC, (event) => {
|
waku.libp2p.pubsub.on(RelayDefaultTopic, (event) => {
|
||||||
const wakuMsg = WakuMessage.decode(event.data);
|
const wakuMsg = WakuMessage.decode(event.data);
|
||||||
if (wakuMsg.payload) {
|
if (wakuMsg.payload) {
|
||||||
const chatMsg = ChatMessage.decode(wakuMsg.payload);
|
const chatMsg = ChatMessage.decode(wakuMsg.payload);
|
||||||
|
@ -5,7 +5,7 @@ import { makeLogFileName } from '../test_utils/log_file';
|
|||||||
import { NimWaku } from '../test_utils/nim_waku';
|
import { NimWaku } from '../test_utils/nim_waku';
|
||||||
|
|
||||||
import Waku from './waku';
|
import Waku from './waku';
|
||||||
import { CODEC } from './waku_relay';
|
import { RelayCodec } from './waku_relay';
|
||||||
|
|
||||||
describe('Waku', function () {
|
describe('Waku', function () {
|
||||||
describe('Interop: Nim', function () {
|
describe('Interop: Nim', function () {
|
||||||
@ -28,7 +28,7 @@ describe('Waku', function () {
|
|||||||
expect(nimPeers).to.deep.equal([
|
expect(nimPeers).to.deep.equal([
|
||||||
{
|
{
|
||||||
multiaddr: multiAddrWithId,
|
multiaddr: multiAddrWithId,
|
||||||
protocol: CODEC,
|
protocol: RelayCodec,
|
||||||
connected: true,
|
connected: true,
|
||||||
},
|
},
|
||||||
]);
|
]);
|
||||||
|
@ -6,7 +6,7 @@ import TCP from 'libp2p-tcp';
|
|||||||
import Multiaddr from 'multiaddr';
|
import Multiaddr from 'multiaddr';
|
||||||
import PeerId from 'peer-id';
|
import PeerId from 'peer-id';
|
||||||
|
|
||||||
import { CODEC, WakuRelay, WakuRelayPubsub } from './waku_relay';
|
import { RelayCodec, WakuRelay, WakuRelayPubsub } from './waku_relay';
|
||||||
|
|
||||||
export interface CreateOptions {
|
export interface CreateOptions {
|
||||||
listenAddresses: string[];
|
listenAddresses: string[];
|
||||||
@ -56,12 +56,12 @@ export default class Waku {
|
|||||||
* @param peer The peer to dial
|
* @param peer The peer to dial
|
||||||
*/
|
*/
|
||||||
async dial(peer: PeerId | Multiaddr | string) {
|
async dial(peer: PeerId | Multiaddr | string) {
|
||||||
return this.libp2p.dialProtocol(peer, CODEC);
|
return this.libp2p.dialProtocol(peer, RelayCodec);
|
||||||
}
|
}
|
||||||
|
|
||||||
async dialWithMultiAddr(peerId: PeerId, multiaddr: Multiaddr[]) {
|
async dialWithMultiAddr(peerId: PeerId, multiaddr: Multiaddr[]) {
|
||||||
this.libp2p.peerStore.addressBook.set(peerId, multiaddr);
|
this.libp2p.peerStore.addressBook.set(peerId, multiaddr);
|
||||||
await this.libp2p.dialProtocol(peerId, CODEC);
|
await this.libp2p.dialProtocol(peerId, RelayCodec);
|
||||||
}
|
}
|
||||||
|
|
||||||
async stop() {
|
async stop() {
|
||||||
|
@ -1,6 +1,16 @@
|
|||||||
export const second = 1000;
|
export const second = 1000;
|
||||||
export const minute = 60 * second;
|
export const minute = 60 * second;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* RelayCodec is the libp2p identifier for the waku relay protocol
|
||||||
|
*/
|
||||||
|
export const RelayCodec = '/vac/waku/relay/2.0.0-beta2';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* RelayDefaultTopic is the default gossipsub topic to use for waku relay
|
||||||
|
*/
|
||||||
|
export const RelayDefaultTopic = '/waku/2/default-waku/proto';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* GossipsubHeartbeatInitialDelay is the short delay before the heartbeat timer begins
|
* GossipsubHeartbeatInitialDelay is the short delay before the heartbeat timer begins
|
||||||
* after the router is initialized.
|
* after the router is initialized.
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
import { shuffle } from 'libp2p-gossipsub/src/utils';
|
import { shuffle } from 'libp2p-gossipsub/src/utils';
|
||||||
|
|
||||||
import { CODEC, WakuRelayPubsub } from './index';
|
import { RelayCodec, WakuRelayPubsub } from './index';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Given a topic, returns up to count peers subscribed to that topic
|
* Given a topic, returns up to count peers subscribed to that topic
|
||||||
@ -32,7 +32,7 @@ export function getWakuPeers(
|
|||||||
if (!peerStreams) {
|
if (!peerStreams) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (peerStreams.protocol == CODEC && filter(id)) {
|
if (peerStreams.protocol == RelayCodec && filter(id)) {
|
||||||
peers.push(id);
|
peers.push(id);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -8,7 +8,7 @@ import { NimWaku } from '../../test_utils/nim_waku';
|
|||||||
import Waku from '../waku';
|
import Waku from '../waku';
|
||||||
import { WakuMessage } from '../waku_message';
|
import { WakuMessage } from '../waku_message';
|
||||||
|
|
||||||
import { CODEC, TOPIC } from './index';
|
import { RelayCodec, RelayDefaultTopic } from './index';
|
||||||
|
|
||||||
describe('Waku Relay', () => {
|
describe('Waku Relay', () => {
|
||||||
afterEach(function () {
|
afterEach(function () {
|
||||||
@ -61,8 +61,8 @@ describe('Waku Relay', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it('Subscribe', async function () {
|
it('Subscribe', async function () {
|
||||||
const subscribers1 = waku1.libp2p.pubsub.getSubscribers(TOPIC);
|
const subscribers1 = waku1.libp2p.pubsub.getSubscribers(RelayDefaultTopic);
|
||||||
const subscribers2 = waku2.libp2p.pubsub.getSubscribers(TOPIC);
|
const subscribers2 = waku2.libp2p.pubsub.getSubscribers(RelayDefaultTopic);
|
||||||
|
|
||||||
expect(subscribers1).to.contain(waku2.libp2p.peerId.toB58String());
|
expect(subscribers1).to.contain(waku2.libp2p.peerId.toB58String());
|
||||||
expect(subscribers2).to.contain(waku1.libp2p.peerId.toB58String());
|
expect(subscribers2).to.contain(waku1.libp2p.peerId.toB58String());
|
||||||
@ -71,7 +71,7 @@ describe('Waku Relay', () => {
|
|||||||
it('Register correct protocols', async function () {
|
it('Register correct protocols', async function () {
|
||||||
const protocols = Array.from(waku1.libp2p.upgrader.protocols.keys());
|
const protocols = Array.from(waku1.libp2p.upgrader.protocols.keys());
|
||||||
|
|
||||||
expect(protocols).to.contain(CODEC);
|
expect(protocols).to.contain(RelayCodec);
|
||||||
expect(protocols.findIndex((value) => value.match(/sub/))).to.eq(-1);
|
expect(protocols.findIndex((value) => value.match(/sub/))).to.eq(-1);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -124,7 +124,9 @@ describe('Waku Relay', () => {
|
|||||||
|
|
||||||
it('nim subscribes to js', async function () {
|
it('nim subscribes to js', async function () {
|
||||||
const nimPeerId = await nimWaku.getPeerId();
|
const nimPeerId = await nimWaku.getPeerId();
|
||||||
const subscribers = waku.libp2p.pubsub.getSubscribers(TOPIC);
|
const subscribers = waku.libp2p.pubsub.getSubscribers(
|
||||||
|
RelayDefaultTopic
|
||||||
|
);
|
||||||
|
|
||||||
expect(subscribers).to.contain(nimPeerId.toB58String());
|
expect(subscribers).to.contain(nimPeerId.toB58String());
|
||||||
});
|
});
|
||||||
@ -196,7 +198,9 @@ describe('Waku Relay', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it('nim subscribes to js', async function () {
|
it('nim subscribes to js', async function () {
|
||||||
const subscribers = waku.libp2p.pubsub.getSubscribers(TOPIC);
|
const subscribers = waku.libp2p.pubsub.getSubscribers(
|
||||||
|
RelayDefaultTopic
|
||||||
|
);
|
||||||
|
|
||||||
const nimPeerId = await nimWaku.getPeerId();
|
const nimPeerId = await nimWaku.getPeerId();
|
||||||
expect(subscribers).to.contain(nimPeerId.toB58String());
|
expect(subscribers).to.contain(nimPeerId.toB58String());
|
||||||
@ -265,7 +269,9 @@ describe('Waku Relay', () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it('nim subscribes to js', async function () {
|
it('nim subscribes to js', async function () {
|
||||||
const subscribers = waku.libp2p.pubsub.getSubscribers(TOPIC);
|
const subscribers = waku.libp2p.pubsub.getSubscribers(
|
||||||
|
RelayDefaultTopic
|
||||||
|
);
|
||||||
|
|
||||||
const nimPeerId = await nimWaku.getPeerId();
|
const nimPeerId = await nimWaku.getPeerId();
|
||||||
expect(subscribers).to.contain(nimPeerId.toB58String());
|
expect(subscribers).to.contain(nimPeerId.toB58String());
|
||||||
@ -381,7 +387,7 @@ describe('Waku Relay', () => {
|
|||||||
|
|
||||||
function waitForNextData(pubsub: Pubsub): Promise<WakuMessage> {
|
function waitForNextData(pubsub: Pubsub): Promise<WakuMessage> {
|
||||||
return new Promise((resolve) => {
|
return new Promise((resolve) => {
|
||||||
pubsub.once(TOPIC, resolve);
|
pubsub.once(RelayDefaultTopic, resolve);
|
||||||
}).then((msg: any) => {
|
}).then((msg: any) => {
|
||||||
return WakuMessage.decode(msg.data);
|
return WakuMessage.decode(msg.data);
|
||||||
});
|
});
|
||||||
|
@ -6,17 +6,13 @@ import { SignaturePolicy } from 'libp2p-interfaces/src/pubsub/signature-policy';
|
|||||||
|
|
||||||
import { WakuMessage } from '../waku_message';
|
import { WakuMessage } from '../waku_message';
|
||||||
|
|
||||||
|
import { RelayCodec, RelayDefaultTopic } from './constants';
|
||||||
import { getWakuPeers } from './get_waku_peers';
|
import { getWakuPeers } from './get_waku_peers';
|
||||||
import { RelayHeartbeat } from './relay_heartbeat';
|
import { RelayHeartbeat } from './relay_heartbeat';
|
||||||
|
|
||||||
export * from './constants';
|
export * from './constants';
|
||||||
export * from './relay_heartbeat';
|
export * from './relay_heartbeat';
|
||||||
|
|
||||||
export const CODEC = '/vac/waku/relay/2.0.0-beta2';
|
|
||||||
|
|
||||||
// As per waku specs, the topic is fixed, value taken from nim-waku
|
|
||||||
export const TOPIC = '/waku/2/default-waku/proto';
|
|
||||||
|
|
||||||
// This is the class to pass to libp2p as pubsub protocol
|
// This is the class to pass to libp2p as pubsub protocol
|
||||||
export class WakuRelayPubsub extends Gossipsub {
|
export class WakuRelayPubsub extends Gossipsub {
|
||||||
heartbeat: RelayHeartbeat;
|
heartbeat: RelayHeartbeat;
|
||||||
@ -34,7 +30,7 @@ export class WakuRelayPubsub extends Gossipsub {
|
|||||||
|
|
||||||
this.heartbeat = new RelayHeartbeat(this);
|
this.heartbeat = new RelayHeartbeat(this);
|
||||||
|
|
||||||
const multicodecs = [CODEC];
|
const multicodecs = [RelayCodec];
|
||||||
|
|
||||||
// This is the downside of using `libp2p-gossipsub` instead of
|
// This is the downside of using `libp2p-gossipsub` instead of
|
||||||
// implementing WakuRelay from scratch.
|
// implementing WakuRelay from scratch.
|
||||||
@ -175,11 +171,11 @@ export class WakuRelay {
|
|||||||
|
|
||||||
// At this stage we are always using the same topic so we do not pass it as a parameter
|
// At this stage we are always using the same topic so we do not pass it as a parameter
|
||||||
async subscribe() {
|
async subscribe() {
|
||||||
await this.pubsub.subscribe(TOPIC);
|
await this.pubsub.subscribe(RelayDefaultTopic);
|
||||||
}
|
}
|
||||||
|
|
||||||
async publish(message: WakuMessage) {
|
async publish(message: WakuMessage) {
|
||||||
const msg = message.toBinary();
|
const msg = message.toBinary();
|
||||||
await this.pubsub.publish(TOPIC, msg);
|
await this.pubsub.publish(RelayDefaultTopic, msg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -8,7 +8,7 @@ import multiaddr from 'multiaddr';
|
|||||||
import PeerId from 'peer-id';
|
import PeerId from 'peer-id';
|
||||||
|
|
||||||
import { WakuMessage } from '../lib/waku_message';
|
import { WakuMessage } from '../lib/waku_message';
|
||||||
import { TOPIC } from '../lib/waku_relay';
|
import { RelayDefaultTopic } from '../lib/waku_relay';
|
||||||
|
|
||||||
import { existsAsync, mkdirAsync, openAsync } from './async_fs';
|
import { existsAsync, mkdirAsync, openAsync } from './async_fs';
|
||||||
import waitForLine from './log_file';
|
import waitForLine from './log_file';
|
||||||
@ -145,7 +145,7 @@ export class NimWaku {
|
|||||||
};
|
};
|
||||||
|
|
||||||
const res = await this.rpcCall('post_waku_v2_relay_v1_message', [
|
const res = await this.rpcCall('post_waku_v2_relay_v1_message', [
|
||||||
TOPIC,
|
RelayDefaultTopic,
|
||||||
rpcMessage,
|
rpcMessage,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
@ -155,7 +155,9 @@ export class NimWaku {
|
|||||||
async messages() {
|
async messages() {
|
||||||
this.checkProcess();
|
this.checkProcess();
|
||||||
|
|
||||||
const res = await this.rpcCall('get_waku_v2_relay_v1_messages', [TOPIC]);
|
const res = await this.rpcCall('get_waku_v2_relay_v1_messages', [
|
||||||
|
RelayDefaultTopic,
|
||||||
|
]);
|
||||||
|
|
||||||
return res.result;
|
return res.result;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user