🚀 Socket Launch Week 🚀 Day 4: Introducing Historical Analytics.Learn More
Socket
Sign inDemoInstall
Socket

websocketserver

Package Overview
Dependencies
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

websocketserver

A WebSocket Server implementation for Node.js

1.0.0
latest
Source
npm
Version published
Weekly downloads
12
-40%
Maintainers
1
Weekly downloads
 
Created
Source

WebSocketServer

A WebSocket server implementation for Node.js, various features to still implement such as support for wss:// and performance analytics centre.

Installation

Install using npm - https://npmjs.org/package/websocketserver

npm install websocketserver

Basic Usage

In a project require the websocketserver module and create an instance of it:

var WebSocketServer = require("websocketserver");
var server = new WebSocketServer("all", 9000);

This will create a WebSocket server that runs on 9000 (default 8080) and uses a sendMethod that sends recieved connections to all server connections. Four sendMethods can be used:

  • all - will send received messages to all users

  • others - will send messages to all users apart from the sender

  • echo - will echo the message back to the sender

  • none - will not automatically send any messages (useful for when more control is needed over message sending, use API to send messages)

Events

The server emits events on a new connection, message and a closed connection:

  • connection event - use to built a list of connections
var connectionList = [];
server.on("connection", function(id) {
    connectionList.push(id);
});
  • message event - get hold of the message
server.on("message", function(data, id) {
    var mes = server.unmaskMessage(data);
    var str = server.convertToString(mes.message);
    console.log(str);
});
  • connectionclosed - log a connection has left (can also use id to remove from connectionList)
server.on("closedconnection", function(id) {
    console.log("Connection " + id + " has left the server");
});

Functions

  • WebSocketServer.sendMessage(people, data, id); - send a message to specified people (all, others or one), data supports strings and packaged WebSocket messages (use packageMessage function for packaging), id is relates to the connection that you would like (or not to if others has been selected for the people argument, id not required if all has been selected).

This example shows how new connections to the server can be welcomed with a message:

server.on('connection', function(id) {
    server.sendMessage("one", "Welcome to the server!", id);
});
  • WebSocketServer.unmaskMessage(frame); - unmasks a WebSocket frame recieved by the server - returns a JavaScript objects with two properties: opcode and message (message is an array of bytes holding character codes - use convertToString(message) function to get the string representation)

Example shows how a message could be logged to the console:

server.on('message', function(data, id) {
    var mesObj = server.unmaskMessage(data);
    console.log(server.convertToString(mesObj.message));
});
  • WebSocketServer.convertToString(bytes); - converts an array of bytes containing character codes to a string.

  • WebSocketServer.packageMessage(opcode, message); - packages a recieved WebSocket message into a sendable WebSocket message - this function is only really necessary after use of unmaskMessage() as it is only really necessary for data that needs to pass through the server (primarily binary messages)

Example shows how we may filter binary data to send straight through the server as most of the time we have no reason to log it.

server.on('message', function(data, id) {
     var mes = server.unmaskMessage(data);
     if (mes.opcode == 130) {
         var packagedMessage = server.packageMessage(mes.opcode, mes.message);
         server.sendMessage('all', packagedMessage);
     }
});
  • WebSocketServer.closeConnection(id); close a specific connection

FAQs

Package last updated on 09 Sep 2013

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