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

59 lines
1.3 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');
};
wss.onConnection = (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);
};
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();
ws.onmessage = (request) => this.emit('message', 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);
}
}