silvrgit/lib/wshandlerv2.js

51 lines
1.2 KiB
JavaScript
Raw Normal View History

2016-10-05 14:09:12 +00:00
/**
*
* User: Martin Donnelly
* Date: 2016-09-07
* Time: 15:33
*
*/
const url = require('url');
const logger = require('log4js').getLogger();
2016-10-05 14:09:12 +00:00
module.exports = function(events, wsServer) {
'use strict';
logger.debug('>> new WS', wsServer);
2016-10-05 14:09:12 +00:00
wsServer.on('connection', function connection(ws) {
logger.debig('>> WS:', ws);
const location = url.parse(ws.upgradeReq.url, true);
2016-10-05 14:09:12 +00:00
logger.info('Creating event for this connection');
logger.info(`${new Date() } Connection accepted.`);
2016-10-05 14:09:12 +00:00
const sendSocketHandler = (obj) => {
logger.debug('sendSocketHandler', obj);
try {
ws.send(JSON.stringify(obj));
}
catch (err) {
logger.error(err);
logger.warn('Offending object: ', obj);
}
};
2016-10-05 14:09:12 +00:00
events.on('sendSocket', sendSocketHandler);
ws.on('message', function(message) {
console.log('received:', message);
2016-10-05 14:09:12 +00:00
if (message === 'update')
2016-10-05 14:09:12 +00:00
events.emit('update');
});
2016-10-05 14:09:12 +00:00
ws.on('close', function(reasonCode, description) {
logger.info(`${new Date() } Peer ${ connection.remoteAddress } disconnected.`);
2016-10-05 14:09:12 +00:00
events.removeListener('sendSocket', sendSocketHandler);
});
});
return module;
};