mirror of
https://gitlab.silvrtree.co.uk/martind2000/SODashServer.git
synced 2025-01-25 20:46:17 +00:00
147 lines
4.7 KiB
JavaScript
147 lines
4.7 KiB
JavaScript
|
/**
|
||
|
* Created by Martin on 08/02/2016.
|
||
|
*/
|
||
|
"use strict";
|
||
|
var express = require('express'), path = require('path'), http = require('http'), ejs = require('ejs'), morgan = require('morgan'), cookieparser = require('cookie-parser'), session = require('express-session');
|
||
|
var methodoverride = require('method-override'), bodyparser = require('body-parser'), errorhandler = require('errorhandler');
|
||
|
var mqttConnect = require('./lib/mqtt/mqttConnect');
|
||
|
var log4js = require('log4js');
|
||
|
var logger = log4js.getLogger();
|
||
|
|
||
|
var WebSocketServer = require('websocket').server;
|
||
|
|
||
|
var EventEmitter = require('events');
|
||
|
var lighting_v1 = require('./routes/lighting_v1'), heating_v1 = require('./routes/heating_v1'), projector_v1 = require('./routes/projector_v1');
|
||
|
|
||
|
var busEmitter = new EventEmitter();
|
||
|
|
||
|
mqttConnect.setEmitter(busEmitter);
|
||
|
mqttConnect.doConnection();
|
||
|
|
||
|
var app = express();
|
||
|
|
||
|
app.set('port', process.env.PORT || 4545);
|
||
|
app.set('views', __dirname + '/views');
|
||
|
app.set('view engine', 'ejs');
|
||
|
app.use(morgan('combined'));
|
||
|
app.use(cookieparser('your secret here'));
|
||
|
app.use(session({
|
||
|
secret: '1234567890QWERTY', resave: false,
|
||
|
saveUninitialized: false
|
||
|
}));
|
||
|
/* 'default', 'short', 'tiny', 'dev' */
|
||
|
app.use(methodoverride());
|
||
|
|
||
|
app.use(bodyparser.urlencoded({extended: false}));
|
||
|
|
||
|
// parse application/json
|
||
|
app.use(bodyparser.json());
|
||
|
|
||
|
app.use(function (req, res, next) {
|
||
|
res.header("Access-Control-Allow-Origin", "*");
|
||
|
res.header("Access-Control-Allow-Headers", "X-Requested-With");
|
||
|
next();
|
||
|
});
|
||
|
// app.use(app.router);
|
||
|
app.use(express.static(path.join(__dirname, 'app')));
|
||
|
app.use(errorhandler({dumpExceptions: true, showStack: true}));
|
||
|
|
||
|
lighting_v1.use(mqttConnect);
|
||
|
heating_v1.use(mqttConnect);
|
||
|
projector_v1.use(mqttConnect);
|
||
|
|
||
|
busEmitter.on('clientConnected', (socketSet) => {
|
||
|
console.log(socketSet.getClientStatus());
|
||
|
heating_v1.setsocket(socketSet).subscribe();
|
||
|
lighting_v1.setsocket(socketSet).subscribe();
|
||
|
projector_v1.setsocket(socketSet).subscribe();
|
||
|
});
|
||
|
|
||
|
|
||
|
busEmitter.on('clientStatusUpdated', (v) => {
|
||
|
console.log(v);
|
||
|
});
|
||
|
|
||
|
|
||
|
logger.info('Configuring WebSocket Listener...');
|
||
|
var server = http.createServer(function (request, response) {
|
||
|
console.log((new Date()) + ' Received request for ' + request.url);
|
||
|
response.writeHead(404);
|
||
|
response.end();
|
||
|
});
|
||
|
server.listen(8080, function () {
|
||
|
console.log((new Date()) + ' Server is listening on port 8080');
|
||
|
});
|
||
|
var wsServer = new WebSocketServer({
|
||
|
httpServer: server,
|
||
|
// You should not use autoAcceptConnections for production
|
||
|
// applications, as it defeats all standard cross-origin protection
|
||
|
// facilities built into the protocol and the browser. You should
|
||
|
// *always* verify the connection's origin and decide whether or not
|
||
|
// to accept it.
|
||
|
autoAcceptConnections: false
|
||
|
});
|
||
|
|
||
|
function originIsAllowed(origin) {
|
||
|
// put logic here to detect whether the specified origin is allowed.
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
wsServer.on('request', function (request) {
|
||
|
|
||
|
if (!originIsAllowed(request.origin)) {
|
||
|
// Make sure we only accept requests from an allowed origin
|
||
|
request.reject();
|
||
|
console.log((new Date()) + ' Connection from origin ' + request.origin + ' rejected.');
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
var connection = request.accept('stream', request.origin);
|
||
|
console.log((new Date()) + ' Connection accepted.');
|
||
|
|
||
|
var sendSocketHandler = (obj) => {
|
||
|
// logger.info('sendSocket: ' + JSON.stringify(obj));
|
||
|
connection.sendUTF(JSON.stringify(obj));
|
||
|
};
|
||
|
|
||
|
busEmitter.on('sendSocket', sendSocketHandler);
|
||
|
|
||
|
connection.on('message', function (message) {
|
||
|
if (message.type === 'utf8') {
|
||
|
console.log('Received Message: ' + message.utf8Data);
|
||
|
connection.sendUTF(message.utf8Data);
|
||
|
}
|
||
|
else if (message.type === 'binary') {
|
||
|
console.log('Received Binary Message of ' + message.binaryData.length + ' bytes');
|
||
|
connection.sendBytes(message.binaryData);
|
||
|
}
|
||
|
});
|
||
|
|
||
|
|
||
|
connection.on('close', function (reasonCode, description) {
|
||
|
console.log((new Date()) + ' Peer ' + connection.remoteAddress + ' disconnected.');
|
||
|
busEmitter.removeListener('sendSocket', sendSocketHandler);
|
||
|
});
|
||
|
});
|
||
|
|
||
|
mqttConnect.connectWS(function () {
|
||
|
console.log('Ready to plug in sockets...');
|
||
|
});
|
||
|
|
||
|
/*app.get('/', function( req, res) {
|
||
|
res.render('index');
|
||
|
});*/
|
||
|
|
||
|
app.post('/api/v1/lighting/off', lighting_v1.turnoff);
|
||
|
app.post('/api/v1/lighting/on', lighting_v1.turnon);
|
||
|
|
||
|
app.post('/api/v1/heating/off', heating_v1.turnoff);
|
||
|
app.post('/api/v1/heating/on', heating_v1.turnon);
|
||
|
|
||
|
app.post('/api/v1/projector/off', projector_v1.turnoff);
|
||
|
app.post('/api/v1/projector/on', projector_v1.turnon);
|
||
|
|
||
|
app.listen(3000, function () {
|
||
|
console.log('Express listening on 3000');
|
||
|
});
|