-
Notifications
You must be signed in to change notification settings - Fork 156
/
server.js
151 lines (126 loc) · 4.78 KB
/
server.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
'use strict';
// Default node environment to development
process.env.NODE_ENV = process.env.NODE_ENV || 'development';
var express = require('express'),
oldSocketio = require('919.socket.io'),
socketio = require('socket.io'),
WebSocket = require('ws'),
mongoose= require('mongoose');
var path = require('path'),
url = require('url'),
fs = require('fs');
// Application Config
var config = require(path.join(__dirname,'/config/config'));
// Connect to database
mongoose.Promise = global.Promise;
mongoose.connect(config.mongo.uri,function(error){
if (error) {
console.log('********************************************');
console.log('* MongoDB Process not running *');
console.log('********************************************\n');
process.exit(1);
}
});
//create docker directories if needed
fs.mkdir(config.releasesDir, function(err) {
if (err && (err.code != 'EEXIST')) {
console.log("Error creating logs directory, "+err.code)
}
});
fs.mkdir(config.licenseDir, function(err) {
if (err && (err.code != 'EEXIST')) {
console.log("Error creating logs directory, "+err.code)
}
});
fs.mkdir(config.syncDir, function(err) {
if (err && (err.code != 'EEXIST')) {
console.log("Error creating logs directory, "+err.code)
}
});
fs.mkdir(config.thumbnailDir, function(err) {
if (err && (err.code != 'EEXIST')) {
console.log("Error creating logs directory, "+err.code)
}
});
// check system
require('./app/others/system-check')();
// Bootstrap models
var modelsPath = path.join(__dirname, 'app/models');
fs.readdirSync(modelsPath).forEach(function (file) {
require(modelsPath + '/' + file);
});
console.log('********************************************************************');
console.log('* After update if you do not see your groups, please change *');
console.log('* change the uri variable to "mongodb://localhost/pisignage-dev"*');
console.log('* in config/env/development.js and restart the server *');
console.log('******************************************************************\n');
var app = express();
// Express settings
require('./config/express')(app);
// Start server
var server;
if (config.https) {
var https_options = {
key: fs.readFileSync("./pisignage-server-key.pem"),
cert: fs.readFileSync("./pisignage-server-cert.pem"),
passphrase: 'pisignage'
};
server = require('https').createServer(https_options, app);
}
else {
server = require('http').createServer(app);
}
var io = oldSocketio.listen(server,{'destroy upgrade':false});
var ioNew = socketio(server,{
path: '/newsocket.io',
serveClient: true,
// below are engine.IO options
pingInterval: 45000,
pingTimeout: 45000,
upgradeTimeout: 60000,
maxHttpBufferSize: 10e7
});
var ioNewWebsocketOnly = socketio(server, {
path: "/wssocket.io",
serveClient: true,
// below are engine.IO options
pingInterval: 45000,
pingTimeout: 180000,
upgradeTimeout: 180000,
maxHttpBufferSize: 10e7
});
//Bootstrap socket.io
require('./app/controllers/server-socket').startSIO(io);
require('./app/controllers/server-socket-new').startSIO(ioNew);
require("./app/controllers/server-socket-new").startSIOWebsocketOnly(ioNewWebsocketOnly);
var wss = new WebSocket.Server({server:server,path:"/websocket"});
require("./app/controllers/server-socket-ws").startSIO(wss);
server.on('upgrade', function upgrade(request, socket, head) {
var pathname = url.parse(request.url).pathname;
if (pathname === '/WebSocket') {
wss.handleUpgrade(request, socket, head, function done(ws) {
wss.emit('connection', ws, request);
});
}
});
require('./app/controllers/scheduler');
server.listen(config.port, function () {
console.log('Express server listening on port %d in %s mode', config.port, app.get('env'));
});
server.on('connection', function(socket) {
// 60 minutes timeout
socket.setTimeout(3600000);
});
server.on('error', function (err) {console.log("caught ECONNRESET error 1");console.log(err)});
io.on('error', function (err) {console.log("caught ECONNRESET error 2");console.log(err)});
io.sockets.on('error', function (err) {console.log("caught ECONNRESET error 3");console.log(err)});
ioNew.on('error', function (err) {console.log("caught ECONNRESET error 4");console.log(err)});
ioNew.sockets.on('error', function (err) {console.log("caught ECONNRESET error 5");console.log(err)});
process.on('uncaughtException', function(err, origin) {
fs.writeSync(
process.stderr.fd,
'***WARNING*** Caught exception: '+err+', Exception origin: '+origin + '*******\n'
);
})
// Expose app
module.exports = app;