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

webrtc-mesh

Package Overview
Dependencies
Maintainers
1
Versions
12
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

webrtc-mesh

using a signaler, mesh between node, browsers and other applications

  • 0.9.8-beta
  • latest
  • npm
  • Socket score

Version published
Weekly downloads
1
decreased by-92.86%
Maintainers
1
Weekly downloads
 
Created
Source

webrtc-mesh

** BETA Release API in the work, Subject to Change **

What does it do??

Prerequisite Disclaimer

WebRTC allows direct communication between RTC capable Peers (usually browser to browser), thanks to the modern Robinhood Style of Coding (aka take from the geniuses and give to the masses) we can make node talk to webRTC peers. (Shoutout to my dependency contributors @theturtle32, @markandrus and @modeswitch)

The sauce

Using your websocket signaling server (echo server to all connected peers for sdp exchange) do automagically connect all clients running this lib with a network of datachannels

API - Beta

Initialize

const Mesh = require('webrtc-mesh').Mesh;

var config = {
  url: 'wss:websocket.url.server:port/',
  key: 'appKey or Token for message filtering', //optional, default is 'mesh'
  debug: false, //optional, default is false
}

var mesh = Mesh(config);

mesh.pipe( (ev) => { //handle incoming data
  console.log('we got some data from another peer', ev.data)
  });

mesh.sendToAll( arrayBuffer(12) ) // or even just 'string of Json'

Initialize as Stream

var Mesh = require('webrtc-mesh').Mesh;

var config = {
  url: 'wss:websocket.url.server:port/',
  key: 'appKey or Token for message filtering', //optional, default is 'mesh'
  debug: false, //optional, default is false
}

var mesh = Mesh(config)

var meshedStream = mesh.getStream();
mesh.pipe(meshedStream.push.bind(meshedStream));

process.stdin.pipe(meshedStream).pipe(process.stdout);

Utilities

mesh.getPeerList() // returns a map of connected Peers with KEY: peerID Value: object with {status:connectionStatus, conn:reference to Peer Connection, channel: reference to data channel}
mesh.getPeer(peerId) // returns a specific peer from the map
mesh.getPeerId() //return your peerId
mesh.printPeers() // console print for quick check against connection status
mesh.sendToAll(buffer || blob || string) //send to all peers
mesh.onNewPeer( function ) // register a function to receive the 'onOpen' event of a new data channel

Keywords

FAQs

Package last updated on 16 Dec 2020

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