/* eslint-disable no-console */ 'use strict' const { Buffer } = require('buffer') const Libp2p = require('../../') const TCP = require('libp2p-tcp') const Mplex = require('libp2p-mplex') const { NOISE } = require('libp2p-noise') const SECIO = require('libp2p-secio') const Gossipsub = require('libp2p-gossipsub') const createNode = async () => { const node = await Libp2p.create({ addresses: { listen: ['/ip4/0.0.0.0/tcp/0'] }, modules: { transport: [TCP], streamMuxer: [Mplex], connEncryption: [NOISE, SECIO], pubsub: Gossipsub } }) await node.start() return node } ;(async () => { const topic = 'news' const [node1, node2] = await Promise.all([ createNode(), createNode() ]) // Add node's 2 data to the PeerStore node1.peerStore.addressBook.set(node2.peerId, node2.multiaddrs) await node1.dial(node2.peerId) await node1.pubsub.subscribe(topic, (msg) => { console.log(`node1 received: ${msg.data.toString()}`) }) await node2.pubsub.subscribe(topic, (msg) => { console.log(`node2 received: ${msg.data.toString()}`) }) // node2 publishes "news" every second setInterval(() => { node2.pubsub.publish(topic, Buffer.from('Bird bird bird, bird is the word!')) }, 1000) })()