-
Notifications
You must be signed in to change notification settings - Fork 0
/
app.js
66 lines (48 loc) · 1.39 KB
/
app.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
var config = require('./config');
var express = require('express');
var app = express();
var exphbs = require('express3-handlebars');
var errorHandler = require('express-error-handler');
var fs = require('fs');
app.engine('.html', exphbs({
defaultLayout: 'template',
extname: '.html'
}));
app.set('view engine', '.html');
var controllers = [];
app.use(express.static(__dirname + '/public'));
// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
app.use(function (err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: err
});
});
}
// production error handler
// no stacktraces leaked to user
app.use(function (err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: {}
});
});
console.log("PORT " + config.CONFIG.Port);
LoadControllers();
var server = app.listen(config.CONFIG.Port, function () {
console.log('Listening on port %d', server.address().port);
});
function LoadControllers() {
// Load list of files
var pluginFiles = fs.readdirSync('./controllers');
for (var i = 0; i < pluginFiles.length; i++) {
console.log("Loading controller: " + pluginFiles[i]);
var c = require('./controllers/' + pluginFiles[i]);
c.Setup(app);
controllers.push(c);
}
}