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

spacebro-client

Package Overview
Dependencies
Maintainers
1
Versions
47
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

spacebro-client

๐ŸŒŸ Connect easily to a Spacebro server

  • 0.4.0-beta.5
  • beta
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
40
increased by566.67%
Maintainers
1
Weekly downloads
ย 
Created
Source

spacebro client

๐ŸŒŸ Connect easily to a spacebro server.

js-standard-style node node node

๐ŸŒ Installation

yarn add spacebro-client
# or
npm i -S spacebro-client

๐Ÿ‘‹ Usage

First, you need to start a spacebro server.

$ npm i -g spacebro # or yarn global add spacebro
$ spacebro

Then, it's time to write some code:

const spacebroClient = require('spacebro-client')

spacebroClient.connect('127.0.0.1', 8888, {
  clientName: 'foo',
  channelName: 'bar'
})

spacebroClient.on('hello', function () { console.log('world') })
spacebroClient.emit('hello')

๐Ÿš€ API

spacebroClient.connect([[address, ]port, ]options)

Look for a server.

// For more details about possible options, see below.
const option = {
  clientName: 'foo',
  channelName: 'bar'
}

// this call does not use any auto-discovery (mdns/avahi/bonjour) feature
// and just perfoms a basic connection request on `ws://${address}:${port}`.
spacebroClient.connect('127.0.0.1', 8888, options)
options:
namedefaultrequiredย description
clientNamenullrecommendedYour client name. Can be useful to perform targeted events and for monitoring.
channelNamenullrecommendedThe channel your app will communicate in. This is especially usefull if you have multiple apps using the same server.
packers[]optionalArray of packers, see hooks below.
unpackers[]optionalArray of unpackers, see hooks below.
verbosetrueoptionalShould spacebro-client display logs (connection / emission / reception) ?
sendBacktrueoptionalShould this client receive its own events ?
multiServicefalseoptionalShould spacebro-client connects to every zeroconfName service it finds on the network ?

spacebroClient.emit(eventName[, data])

Broadcast a specific event to all the clients in channel. data must be a JSON object.

spacebroClient.sendTo(eventName, target[, data])

Send an event to a specific target in the channel. data must be a JSON object.

spacebroClient.on(eventName, handler)

Listen to a specific event.

spacebroClient.once(eventName, handler)

Listen to a specific event only once.

spacebroClient.off(eventName)

Remove a specific event listener.

โ†ช๏ธ Hooks

Packers

Before you send an event to the server, all packers associated with that event and all global packers (with no associated event) are called and applied to that event. They receive a single argument which is an object with two properties, the eventName and the data, and can return a new version of those data. If nothing is returned, the message will remain unchanged.

Unpackers

Unpackers are call when you receive a message from the server, before any handler is called. You can use to alter data (same as packers) but also to check the message as if an unpacker returns false, the message will not be sent to the handlers, it will also break the unpacking chain.

๐Ÿ–ฅ Browser

You can use spacebro-client in the browser. You will need few depencies that you can find bellow:

<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/1.4.8/socket.io.min.js"></script>
<script src="https://wzrd.in/standalone/socketio-wildcard@latest"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/js-signals/1.0.0/js-signals.min.js"></script>

After adding this depencies you can include the spacebro-client lib like any script:

<script src="./dist/spacebro-client.js"></script>

Then use the window.spacebroClient object.

โš› Electron

Spacebro-client also works in Electron. You just require('spacebro-client') in your electron main process and use ipc or web-contents to forward events to the renderer process.

From the example/electron/ folder of this repository:

// In the main process.
const { app, BrowserWindow } = require('electron')
const spacebroClient = require('../../dist/spacebro-client')

let win = null

spacebroClient.connect('127.0.0.1', 8888, {
  clientName: 'foo',
  channelName: 'bar'
})

app.on('ready', () => {
  win = new BrowserWindow({ width: 800, height: 600 })
  win.loadURL(`file://${__dirname}/index.html`)

  const events = ['hello', 'world']
  events.forEach((event) => {
    spacebroClient.on(event, (data) => {
      win.webContents.send(event, data)
    })
  })

  win.webContents.on('did-finish-load', () => {
    setTimeout(() => { spacebroClient.emit('hello', { hello: 'world' }) }, 3000)
    setTimeout(() => { spacebroClient.emit('world', { world: 'hello' }) }, 5000)
  })
})

<!-- index.html -->
<html>
<body>
  <script>
    require('electron').ipcRenderer.on('hello', (event, message) => {
      console.log(message)
    })
    require('electron').ipcRenderer.on('world', (event, message) => {
      console.log(message)
    })
  </script>
</body>
</html>

Examples

You can find many real life examples in the example/ folder of this repository.

๐Ÿ•ณ Troubleshooting

new-member event ๐Ÿ‘‹

Spacebro server automatically broadcasts a new-memeber event when a client connects. Thus, you should avoid using that event name. See the example/simple-node script more details.

Using native module in Electron ๐ŸŒ€

If you want to use spacebro-client into an Electron app, you'll have to use electron-rebuild in order to rebuild MDNS according to version of Node.js that is embedded with Electron.

Basically, you do:

$ npm i --save-dev electron-rebuild # or yarn
$ ./node_modules/.bin/electron-rebuild # call the executable every time you add a new native module

You can also add "rebuild": "./node_modules/.bin/electron-rebuild" to your package.json and run npm run rebuild for convenience.

source

yarn and node-gyp issue (i.e not compiling) ๐Ÿค–

You need to use at least yarn version 0.17.8. You might have similar problem with outdated versions of npm, simply try to update it.

source

ping pong ๐Ÿ“

Do not try to test with 'ping' and 'pong' events, those are reserved.

- `ping`. Fired when a ping packet is written out to the server.
- `pong`. Fired when a pong is received from the server.

source

โค๏ธ Contribute

Please follow standard style conventions.

We will name our version by the name of the stars that you can find here

Currently latest correspond to Sirrah, which belongs to the Andromeda galaxy.

You can modify the source in src/index.js.

Run npm run build to transpile and test.

Enjoy !

FAQs

Package last updated on 29 Jun 2017

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