npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@organicdesign/libp2p-rpc

v0.2.2

Published

An RPC module for Libp2p.

Downloads

5

Readme

libp2p-rpc

An RPC module for Libp2p.

Table of Contents

Install

npm i @organicdesign/libp2p-rpc

Usage

import { createRPC, RPCException } from "@organicdesign/libp2p-rpc";

const rpc = createRPC([options])(libp2p);

// Add an RPC method.
rpc.addMethod("log", (params, peerId) => {
	console.log(`received ${params} from ${peerId.toString()}`);

	const somethingHasGoneWrong = false;

	if (somethingHasGoneWrong) {
		// Respond with an error with a message and code.
		throw new RPCException("Something went wrong", 0);
	}

	// Return a response
	return new Uint8Array([3]);
});

// Start the rpc module.
await rpc.start();

// Call the 'log' method on the connected peer with ID peerId with parameter.
const response = await rpc.request(peerId, "log", new Uint8Array([1]));

console.log("Response: ", response); // Response:  Uint8Array [ 3 ]

// Call the 'log' method without expecting a response.
rpc.notify(peerId, "log", new Uint8Array([2]));

// Stop the rpc module.
await rpc.stop();

API

createRPC

createRPC([options])(libp2p);
  • options <Object> An optional object with the following properties:
    • protocol <string> A string which specifies the name of the protocol. Default: "/libp2p-rpc/0.0.1".
    • timeout <number> The timeout in milliseconds for requests. Set to -1 to disable. Default: 5000 (5s)
  • libp2p <Libp2p> The libp2p instance.
  • Returns: <RPC> The RPC instance.

Creates a Libp2p RPC module.

RPC

createRPC(libp2p, [options]);
  • options <Object> An optional object with the following properties:
    • protocol <string> A string which specifies the name of the protocol. Default: "/libp2p-rpc/0.0.1".
    • timeout <number> The timeout in milliseconds for requests. Set to -1 to disable. Default: 5000 (5s)
  • libp2p <Libp2p> The libp2p instance.

The RPC class. It is not recommended to instanciate it directly but rather use the createRPC function.

start

rpc.start();
  • Returns: <Promise>

Start the RPC module, resolves when it has finished starting.

stop

rpc.stop();
  • Returns: <Promise>

Stop the RPC module, resolves when it has finished stopping. This will clear all remote procedure call methods.

addMethod

rpc.addMethod(name, method);
  • name <string> The name of the method to add.
  • method <RPCMethod> The RPC method to add. RPCMethod is a method with the parameters:
    • params <Uint8Array> | <undefined> The paramters this method was called with.
    • sender <PeerId> The peer that called this method.

Add a remote procedure call method. Methods can be added dynamically (before or after the start call).

hasMethod

rpc.hasMethod(name);
  • name <string> The name of the method to check.
  • Returns: <boolean> True if there is a method handled by that name.

Check if a remote procedure call method exists.

removeMethod

rpc.removeMethod(name);
  • name <string> The name of the method to remove.
  • Returns: <boolean> True if the method did exist and was removed.

Remove a remote procedure call method. Methods can be removed dynamically (before or after the start call).

request

rpc.request(peerId, name, [params]);
  • peerId <PeerId> The ID of the peer to request the call on.
  • name <string> The name of the method to execute.
  • params <Uint8Array> The paramters to call the method with.
  • Returns: <Promise>

Request a remote peer to execute a method. The promise resolves with the result of the RPC method or rejects with an RPCException if the method fails or it fails to send the request (the peer is not connected) or it times out.

notify

rpc.notify(peerId, name, [params]);
  • peerId <PeerId> The ID of the peer to request the call on.
  • name <string> The name of the method to execute.
  • params <Uint8Array> The paramters to call the method with.

Request a remote peer to execute a method. This executes synchronously, does not return any value and will not throw even if it fails to send the request.

RPCException

new RPCException(message, code, [data]);
  • message <string> The error message.
  • code <number> The error code.
  • data <Uint8Array> Optional error data.

The RPCException class is an extention of the native Error class with additional properties to hold an error code and error data. You can throw RPCExceptions inside RPC methods to return additional data back to the remote caller.

The pre-defined error codes are:

  • -32601 Method not found Thrown when a method is called on a node that does not have a matching handler.
  • -32000 Thrown when the request could not be sent to the remote peer. The message is not static and is the reason why the request message could not be sent. This can be caused by not being connected to it.
  • -32001 RPC module stopped Thrown when a request is aborted due to the module stopping.
  • -32002 Thrown when the method throws an error but does not define a code. The message is not static and is the message of the error that was thrown.
  • -32003 Request timed out Thrown when a request timed out.

Logging

The logger has the following namespaces:

  • libp2p:rpc - Logs general actions like starting, stopping and incoming/outgoing rpc calls.

To enable logging in nodejs add the following environment variable (by prefixing the start command):

DEBUG=libp2p:rpc*

Or in the browser:

localStorage.setItem("debug", "libp2p:rpc*");

Protocol Design

This module is loosely based on the JSON-RPC 2.0 Specification but altered to work efficiently over libp2p.

The parameters are bytes instead of an object or array, the response is also bytes and all the fields are encoded into binary using protocol buffers instead of JSON.

Tests

To run the test suite:

npm run test

To-Do

  • [ ] More tests.