* fix: upgrade ws from 7.4.6 to 7.5.0 Snyk has created this PR to upgrade ws from 7.4.6 to 7.5.0. See this package in npm: https://www.npmjs.com/package/ws See this project in Snyk: https://app.snyk.io/org/acinader/project/8c1a9edb-c8f5-4dc1-b221-4d6030a323eb?utm_source=github&utm_medium=upgrade-pr * changed logging for circular obj * upgraded to ws 7.5.3 Co-authored-by: Manuel Trezza <5673677+mtrezza@users.noreply.github.com>
60 lines
1.5 KiB
JavaScript
60 lines
1.5 KiB
JavaScript
import { loadAdapter } from '../Adapters/AdapterLoader';
|
|
import { WSAdapter } from '../Adapters/WebSocketServer/WSAdapter';
|
|
import logger from '../logger';
|
|
import events from 'events';
|
|
import { inspect } from 'util';
|
|
|
|
export class ParseWebSocketServer {
|
|
server: Object;
|
|
|
|
constructor(server: any, onConnect: Function, config) {
|
|
config.server = server;
|
|
const wss = loadAdapter(config.wssAdapter, WSAdapter, config);
|
|
wss.onListen = () => {
|
|
logger.info('Parse LiveQuery Server starts running');
|
|
};
|
|
wss.onConnection = ws => {
|
|
ws.on('error', error => {
|
|
logger.error(error.message);
|
|
logger.error(inspect(ws, false));
|
|
});
|
|
onConnect(new ParseWebSocket(ws));
|
|
// Send ping to client periodically
|
|
const pingIntervalId = setInterval(() => {
|
|
if (ws.readyState == ws.OPEN) {
|
|
ws.ping();
|
|
} else {
|
|
clearInterval(pingIntervalId);
|
|
}
|
|
}, config.websocketTimeout || 10 * 1000);
|
|
};
|
|
wss.onError = error => {
|
|
logger.error(error);
|
|
};
|
|
wss.start();
|
|
this.server = wss;
|
|
}
|
|
|
|
close() {
|
|
if (this.server && this.server.close) {
|
|
this.server.close();
|
|
}
|
|
}
|
|
}
|
|
|
|
export class ParseWebSocket extends events.EventEmitter {
|
|
ws: any;
|
|
|
|
constructor(ws: any) {
|
|
super();
|
|
ws.onmessage = request =>
|
|
this.emit('message', request && request.data ? request.data : request);
|
|
ws.onclose = () => this.emit('disconnect');
|
|
this.ws = ws;
|
|
}
|
|
|
|
send(message: any): void {
|
|
this.ws.send(message);
|
|
}
|
|
}
|