ws-messaging
data:image/s3,"s3://crabby-images/d4b3b/d4b3b3a3d8edcb4fd0a55804ef2dd85c0bd11bbc" alt="JavaScript Style Guide"
Just a really thin abstraction layer on top of WebSocket for Node.js
and Web browsers with a Promises and EventEmitter based APIs.
Features
-
Send notifications via an EventEmitter-like API.
-
Request-reply API using promises (works in both directions, without
any connection blocking during processing).
-
Built-in auth via WebSocket messages exchange (no more query
strings).
-
Reconnection method is provided.
-
Binary messages support via custom encoders/decoders.
-
Reasonable client size (15KB minified, including a Promise
polyfill).
Table of Contents
Installation
npm i ws-messaging
Usage
On a server:
const Server = require('ws-messaging')
const port = 8000
function connectionHook (client, authData) {
}
let server = new Server({port}, {connectionHook})
On a client:
const Client = require('ws-messaging/client')
const url = `ws://localhost:${port}`
const auth = { }
let client = new Client(url, auth)
client.on('someEvent', (...data) => { })
client.register('someMethod', (..args) => { })
client.on('connection', () => {
client.send('myEvent', ...someData)
client.invoke('myMethod', ...someArgs)
.then(result => { })
.catch(error => { })
})
client.on('close', ev => {
if (!client.terminated) {
setTimeout(client.reconnect.bind(client), 2000)
}
})
See tests in test/index.js
for more usage examples.
API
Server API and
Client API
documentation is available online.
Contribute
If you encounter a bug in this package, please submit a bug report to
github repo issues.
PRs are also accepted.
License
MIT