Files
kami-parse-server/src/LiveQuery/ParseWebSocketServer.js

59 lines
1.5 KiB
JavaScript
Raw Normal View History

import { loadAdapter } from '../Adapters/AdapterLoader';
import { WSAdapter } from '../Adapters/WebSocketServer/WSAdapter';
import logger from '../logger';
import events from 'events';
2016-03-10 14:27:00 -08:00
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');
};
2020-07-13 13:06:52 -05:00
wss.onConnection = (ws) => {
ws.on('error', (error) => {
logger.error(error.message);
logger.error(JSON.stringify(ws));
});
2016-03-10 14:27:00 -08:00
onConnect(new ParseWebSocket(ws));
// Send ping to client periodically
2016-12-07 15:17:05 -08:00
const pingIntervalId = setInterval(() => {
2016-03-10 14:27:00 -08:00
if (ws.readyState == ws.OPEN) {
ws.ping();
} else {
clearInterval(pingIntervalId);
}
}, config.websocketTimeout || 10 * 1000);
};
2020-07-13 13:06:52 -05:00
wss.onError = (error) => {
logger.error(error);
};
wss.start();
2016-03-10 14:27:00 -08:00
this.server = wss;
}
close() {
if (this.server && this.server.close) {
this.server.close();
}
}
2016-03-10 14:27:00 -08:00
}
export class ParseWebSocket extends events.EventEmitter {
2016-03-10 14:27:00 -08:00
ws: any;
constructor(ws: any) {
super();
2020-07-13 13:06:52 -05:00
ws.onmessage = (request) =>
this.emit('message', request && request.data ? request.data : request);
ws.onclose = () => this.emit('disconnect');
2016-03-10 14:27:00 -08:00
this.ws = ws;
}
send(message: any): void {
2016-03-10 14:27:00 -08:00
this.ws.send(message);
}
}