Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@libp2p/interface-pubsub

Package Overview
Dependencies
Maintainers
6
Versions
28
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@libp2p/interface-pubsub

PubSub interface for libp2p

  • 4.0.1
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
38K
decreased by-5.38%
Maintainers
6
Weekly downloads
 
Created
Source

@libp2p/interface-pubsub

libp2p.io Discuss codecov CI

PubSub interface for libp2p

Table of contents

Install

$ npm i @libp2p/interface-pubsub

The interface-pubsub contains the base implementation for a libp2p pubsub router implementation. This interface should be used to implement a pubsub router compatible with libp2p. It includes a test suite that pubsub routers should run, in order to ensure compatibility with libp2p.

Table of Contents

Implementations using this interface

You can check the following implementations as examples for building your own pubsub router.

Interface usage

interface-pubsub abstracts the implementation protocol registration within libp2p and takes care of all the protocol connections and streams, as well as the subscription management and the features describe in the libp2p pubsub specs. This way, a pubsub implementation can focus on its message routing algorithm, instead of also needing to create the setup for it.

Extend interface

A pubsub router implementation should start by extending the interface-pubsub class and MUST override the _publish function, according to the router algorithms. This function is responsible for forwarding publish messages to other peers, as well as forwarding received messages if the router provides the canRelayMessage option to the base implementation.

Other functions, such as start, stop, subscribe, unsubscribe, _encodeRpc, _decodeRpc, _processRpcMessage, _addPeer and _removePeer may be overwritten if the pubsub implementation needs to customize their logic. Implementations overriding these functions MUST call super.

The start and stop functions are responsible for the registration of the pubsub protocol with libp2p. The stop function also guarantees that the open streams in the protocol are properly closed.

The subscribe and unsubscribe functions take care of the subscription management and its inherent message propagation.

When using a custom protobuf definition for message marshalling, you should override _encodeRpc and _decodeRpc to use the new protobuf instead of the default one.

_processRpcMessage is responsible for handling messages received from other peers. This should be extended if further operations/validations are needed by the router.

The _addPeer and _removePeer functions are called when new peers running the pubsub router protocol establish a connection with the peer. They are used for tracking the open streams between the peers.

All the remaining functions MUST NOT be overwritten.

Example

The following example aims to show how to create your pubsub implementation extending this base protocol. The pubsub implementation will handle the subscriptions logic.

const Pubsub = require('libp2p-interfaces/src/pubsub')

class PubsubImplementation extends Pubsub {
  constructor({ libp2p, options })
    super({
      debugName: 'libp2p:pubsub',
      multicodecs: '/pubsub-implementation/1.0.0',
      libp2p,
      globalSigningPolicy: options.globalSigningPolicy
    })
  }

  _publish (message) {
    // Required to be implemented by the subclass
    // Routing logic for the message
  }
}

API

The interface aims to specify a common interface that all pubsub router implementation should follow. A pubsub router implementation should extend the EventEmitter. When peers receive pubsub messages, these messages will be emitted by the event emitter where the eventName will be the topic associated with the message.

Constructor

The base class constructor configures the pubsub instance for use with a libp2p instance. It includes settings for logging, signature policies, etc.

new Pubsub({options})
Parameters
NameTypeDescriptionDefault
options.libp2pLibp2plibp2p instancerequired, no default
options.debugNamestringlog namespacerequired, no default
options.multicodecsstring | Array<string>protocol identifier(s)required, no default
options.globalSignaturePolicy'StrictSign' | 'StrictNoSign'signature policy to be globally applied'StrictSign'
options.canRelayMessagebooleanif can relay messages if not subscribedfalse
options.emitSelfbooleanif publish should emit to self, if subscribedfalse

Start

Starts the pubsub subsystem. The protocol will be registered to libp2p, which will result in pubsub being notified when peers who support the protocol connect/disconnect to libp2p.

pubsub.start()

Stop

Stops the pubsub subsystem. The protocol will be unregistered from libp2p, which will remove all listeners for the protocol and the established connections will be closed.

pubsub.stop()

Publish

Publish data message to pubsub topics.

pubsub.publish(topic, message)
Parameters
NameTypeDescription
topicstringpubsub topic
messageUint8Arraymessage to publish
Returns
TypeDescription
Promise<void>resolves once the message is published to the network

Subscribe

Subscribe to the given topic.

pubsub.subscribe(topic)
Parameters
NameTypeDescription
topicstringpubsub topic

Unsubscribe

Unsubscribe from the given topic.

pubsub.unsubscribe(topic)
Parameters
NameTypeDescription
topicstringpubsub topic

Get Topics

Get the list of topics which the peer is subscribed to.

pubsub.getTopics()
Returns
TypeDescription
Array<String>Array of subscribed topics

Get Peers Subscribed to a topic

Get a list of the PeerId strings that are subscribed to one topic.

pubsub.getSubscribers(topic)
Parameters
NameTypeDescription
topicstringpubsub topic
Returns
TypeDescription
Array<string>Array of base-58 PeerId's

Validate

Validates a message according to the signature policy and topic-specific validation function.

pubsub.validate(message)
Parameters
NameTypeDescription
messageMessagea pubsub message
Returns
TypeDescription
Promise<void>resolves if the message is valid

Test suite usage

'use strict'

const tests = require('libp2p-interfaces-compliance-tests/pubsub')
const YourPubsubRouter = require('../src')

describe('compliance', () => {
  let peers
  let pubsubNodes = []

  tests({
    async setup (number = 1, options = {}) {
      // Create number pubsub nodes with libp2p
      peers = await createPeers({ number })

      peers.forEach((peer) => {
        const ps = new YourPubsubRouter(peer, options)

        pubsubNodes.push(ps)
      })

      return pubsubNodes
    },
    async teardown () {
      // Clean up any resources created by setup()
      await Promise.all(pubsubNodes.map(ps => ps.stop()))
      peers.length && await Promise.all(peers.map(peer => peer.stop()))
    }
  })
})

API Docs

License

Licensed under either of

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

Keywords

FAQs

Package last updated on 04 May 2023

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc