ipfs-pubsub-room
Creates a room based on an IPFS pub-sub channel. Emits membership events, listens for messages, broadcast and direct messeges to peers.
(Demo video)
js-ipfs
This package has been tested with js-ipfs version 0.28.0.
Install
$ npm install ipfs-pubsub-room
Use
const Room = require('ipfs-pubsub-room')
const IPFS = require('ipfs')
const ipfs = new IPFS({
EXPERIMENTAL: {
pubsub: true
},
config: {
Addresses: {
Swarm: [
'/dns4/ws-star.discovery.libp2p.io/tcp/443/wss/p2p-websocket-star'
]
}
}
})
ipfs.on('ready', () => {
const room = Room(ipfs, 'room-name')
room.on('peer joined', (peer) => {
console.log('Peer joined the room', peer)
})
room.on('peer left', (peer) => {
console.log('Peer left...', peer)
})
room.on('subscribed', () => {
console.log('Now connected!')
})
})
API
Room (ipfs:IPFS, roomName:string, options:object)
ipfs
: IPFS object. Must have pubsub activatedroomName
: string, global identifier for the roomoptions
: object:
pollInterval
: interval for polling the pubsub peers, in ms. Defaults to 1000.
const room = Room(ipfs, 'some-room-name')
room.broadcast(message)
Broacasts message (string or buffer).
room.sendTo(peer, message)
Sends message (string or buffer) to peer.
room.leave()
Leaves room, stopping everything.
room.getPeers()
Returns an array of peer identifiers (strings).
room.hasPeer(peer)
Returns a boolean indicating if the given peer is present in the room.
room.on('message', (message) => {})
Listens for messages. A message
is an object containing the following properties:
from
(string): peer iddata
(Buffer): message content
room.on('peer joined', (peer) => {})
Once a peer has joined the room.
room.on('peer left', (peer) => {})
Once a peer has left the room.
room.on('subscribed',() => {})
Once your program has subscribed the topic and announced through IPFS pubsub.
License
ISC