Skip to content
This repository was archived by the owner on Jul 21, 2023. It is now read-only.

WebSockets module that libp2p uses and that implements the interface-transport spec

License

Unknown and 2 other licenses found

Licenses found

Unknown
LICENSE
Unknown
LICENSE-APACHE
MIT
LICENSE-MIT
Notifications You must be signed in to change notification settings

libp2p/js-libp2p-websockets

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

@libp2p/websockets

libp2p.io IRC Discuss codecov CI

JavaScript implementation of the WebSockets module that libp2p uses and that implements the interface-transport spec

Table of contents

Install

$ npm i @libp2p/websockets

Description

libp2p-websockets is the WebSockets implementation compatible with libp2p.

Usage

> npm i @libp2p/websockets

Constructor properties

import { WebSockets } from '@libp2p/websockets' const properties = { upgrader, filter } const ws = new WebSockets(properties)
Name Type Description Default
upgrader Upgrader connection upgrader object with upgradeOutbound and upgradeInbound REQUIRED
filter (multiaddrs: Array<Multiaddr>) => Array<Multiaddr> override transport addresses filter Browser: DNS+WSS multiaddrs / Node.js: DNS+{WS, WSS} multiaddrs

You can create your own address filters for this transports, or rely in the filters provided.

The available filters are:

  • filters.all
    • Returns all TCP and DNS based addresses, both with ws or wss.
  • filters.dnsWss
    • Returns all DNS based addresses with wss.
  • filters.dnsWsOrWss
    • Returns all DNS based addresses, both with ws or wss.

Libp2p Usage Example

import Libp2p from 'libp2p' import { Websockets } from '@libp2p/websockets' import filters from 'libp2p-websockets/filters' import { MPLEX } from 'libp2p-mplex' import { NOISE } from 'libp2p-noise' const transportKey = Websockets.prototype[Symbol.toStringTag] const node = await Libp2p.create({ modules: { transport: [Websockets], streamMuxer: [MPLEX], connEncryption: [NOISE] }, config: { transport: { [transportKey]: { // Transport properties -- Libp2p upgrader is automatically added filter: filters.dnsWsOrWss } } } })

For more information see libp2p/js-libp2p/doc/CONFIGURATION.md#customizing-transports.

API

Transport

Connection

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.

About

WebSockets module that libp2p uses and that implements the interface-transport spec

Resources

License

Unknown and 2 other licenses found

Licenses found

Unknown
LICENSE
Unknown
LICENSE-APACHE
MIT
LICENSE-MIT

Stars

Watchers

Forks

Packages

No packages published

Contributors 31