/ws-await

Modification of the module ws to wait for a response

Primary LanguageJavaScriptMIT LicenseMIT

ws-await: modification of the module ws to wait for a response

Version npm Linux Build Coverage Status

ws-await adds new methods and options to the ws module to allow you to wait for a specific message.

Note: This module does not work in the browser. All the basic ws documentation is here. This module only adds new methods and properties and does not affect the old ones(except Send method - it became asynchronous).

This module has Typescript definitions!

Table of Contents

npm install ws-await

See /doc/ws.md to view detailed information.

New methods and options have been added to this module. Be careful when using them: read the API documentation carefully.

The module includes several settings and options for convenient operation. All options are passed as options(for both client and server):

const WebSocketAwait = require('ws-await');

const options = {
    awaitTimeout: 10000,
    leaveAwaitId: false,
    packMessage: data => JSON.stringify(data),
    unpackMessage: data => JSON.parse(data),
    generateAwaitId: () => `_${Math.random()
        .toString(36)
        .substr(2, 10)}`,
    attachAwaitId: (data, id) => Object.assign({awaitId: id}, data),
    extractAwaitId: data => data &&
        Object.prototype.hasOwnProperty.call(data, 'awaitId') && data.awaitId,
    deleteAwaitId: data => delete data.awaitId,
};
const wss = new WebSocketAwait.Server({port: 5050, ...options});
const ws = new WebSocketAwait(`ws://localhost:5050`, options);

All settings and options presented above are set by default. Please consider this. For example, the package Message method is triggered immediately before the message is sent by all available methods (send, sendAwait, resAwait). That is, by default, function JSON.stringify(data) will work before sending and JSON will be sent. The situation is similar with the unpack Message. The function JSON.parse(data) will fire immediately before the message event is triggered. To disable these two methods (pack Message and unpack Message), use the setSettings method and set the values of these methods to null. Disabling works only on these two methods!

const options = {
    packMessage: null,
    unpackMessage: null,
}

If you do not want to use the sendAwait and resAwait methods, set extractAwaitId to null(due to the fact that there will be no checks for the presence of the awaitId(default) key , performance will be improved).

const options = {
    extractAwaitId: null,
}

All methods and properties are described in detail in the docs.

Examples are for informational purposes only!

Send and receive a message waiting for a response.

const WebSocketAwait = require('ws-await');

const wss = new WebSocketAwait.Server({
    port: 8080
});

wss.on('connection', ws => {
    ws.on('messageAwait', (msg, id) => {
        console.log(`Server get messageAwait <<< ${msg.foo} and ${id}`);
        ws.resAwait({
            bar: 'foo'
        }, id);
    });
});

const ws = new WebSocketAwait('ws://localhost:8080');

ws.on('open', async () => {
    const waiting = await ws.sendAwait({
        foo: 'bar'
    });
    console.log(`Client get waiting <<< ${waiting.bar}`);
});

Sending to two servers and waiting for messages from them using Promise.all().

const WebSocketAwait = require('ws-await');

const wssOne = new WebSocketAwait.Server({
    port: 5050
});

const wssTwo = new WebSocketAwait.Server({
    port: 8080
});

wssOne.on('connection', ws => {
    ws.on('messageAwait', (msg, id) => {
        console.log(`Server One get messageAwait <<< ${msg.foo} and ${id}`);
        ws.resAwait({
            bar: 'fooOne'
        }, id);
    });
});

wssTwo.on('connection', ws => {
    ws.on('messageAwait', (msg, id) => {
        console.log(`Server Two get messageAwait <<< ${msg.foo} and ${id}`);
        ws.resAwait({
            bar: 'fooTwo'
        }, id);
    });
});

const wsOne = new WebSocketAwait('ws://localhost:5050');
const wsTwo = new WebSocketAwait('ws://localhost:8080');

setTimeout(async () => {
    const wsOneData ={
        foo: 'barOne',
    };
    const wsTwoData ={
        foo: 'barTwo',
    };
    const [waitingOne, waitingTwo] = await Promise.all([wsOne.sendAwait(wsOneData), wsTwo.sendAwait(wsTwoData)]);
    console.log(`Client One get waiting <<< ${waitingOne.bar}`);
    console.log(`Client Two get waiting <<< ${waitingTwo.bar}`);
}, 1000);

Send and receive a message waiting for a response with change attachAwaitId settings and catch Error.

const WebSocketAwait = require('ws-await');

const wss = new WebSocketAwait.Server({
    port: 8080,
});

wss.on('connection', ws => {
    ws.on('messageAwait', (msg, id) => {
        console.log(`Server get messageAwait <<< ${msg.foo} and ${id}`);
        ws.resAwait({
            bar: 'foo',
        }, id);
    });
});

const ws = new WebSocketAwait('ws://localhost:8080', {
    attachAwaitId: (data, id) => {
        if (typeof data === 'object') {
            return Object.assign({awaitId: id}, data);
        }
        throw new Error('Data is not object');
    },
});

ws.on('open', async () => {
    try {
        const waitingOne = await ws.sendAwait({
            foo: 'bar',
        });
        console.log(`Client get waiting <<< ${waitingOne.bar}`);
        const waitingTwo = await ws.sendAwait(10);
        console.log(`Client get waiting <<< ${waitingTwo.bar}`);
    } catch (err) {
        console.log(err.message);
    }
});

Send and receive a message waiting for a response. The server also sends a waiting message to another server and sends it to the first server when it receives a response.

const WebSocketAwait = require('ws-await');

const wssOne = new WebSocketAwait.Server({
    port: 5050
});

const wssTwo = new WebSocketAwait.Server({
    port: 8080
});

const wsTwo = new WebSocketAwait('ws://localhost:8080');

wssOne.on('connection', ws => {
    wsOne.on('open', async () => {
        ws.on('messageAwait', async (msg, id) => {
            console.log(`Server One get messageAwait <<< ${msg.foo} and ${id}`);
            const resData = await wsTwo.sendAwait({
                foo: 'bar'
            });
            ws.resAwait(resData, id);
        });
    });
});

wssTwo.on('connection', ws => {
    ws.on('messageAwait', (msg, id) => {
        console.log(`Server Two get messageAwait <<< ${msg.foo} and ${id}`);
        ws.resAwait({
            bar: 'I am from wssTwo server'
        }, id);
    });
});

const wsOne = new WebSocketAwait('ws://localhost:5050');

wsOne.on('open', async () => {
    const waiting = await wsOne.sendAwait({
        foo: 'bar'
    });
    console.log(`Client get waiting <<< ${waiting.bar}`);
});

Send your suggestions and questions on GitHub or send to email. stas.ut21@gmail.com.

We're using the GitHub releases for changelog entries.

MIT