forked from vincentbernat/dashkiosk
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
64 lines (57 loc) · 1.61 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
'use strict';
var http = require('http'),
socketio = require('socket.io'),
path = require('path'),
util = require('util'),
glob = require('glob'),
logger = require('./lib/logger'),
config = require('./lib/config'),
chromecast = require('./lib/chromecast');
var app = require('./lib/express'),
server = http.createServer(app),
io = socketio.listen(server, {
logger: logger
});
// Static files
app.get('/', function(req, res) { res.redirect('/receiver'); });
app.get('/firefox', function(req, res) { res.redirect('/receiver'); });
// API
var api = require('./lib/api');
api.socketio(io);
api.rest(app);
// DB
var db = require('./lib/db'),
models = require('./lib/models');
db
.initialize()
.then(function() { return models.Group.run(); })
.catch(function(err) {
if (err instanceof Array) {
throw err[0];
}
throw err;
})
.then(function() {
if (config.get('chromecast:enabled')) {
chromecast();
}
server.listen(config.get('port'), function() {
logger.info('Express server listening on port %d in %s mode',
config.get('port'),
config.get('environment'));
});
})
.catch(function(err) {
logger.exception('fatal error', err);
process.exit(1);
});
// Demo: halt after the given number of minutes
if (config.get('demo')) {
var end = ((config.get('demo') * 1) || 60);
logger.info('Demo mode enabled, will stop in ' + end + ' minutes');
setTimeout(function() {
logger.info('End of demo mode, quitting');
process.exit(5);
}, end * 60 * 1000);
}
module.exports = app;