forked from aerohive/ClassWIFIAccess
-
Notifications
You must be signed in to change notification settings - Fork 0
/
app.js
executable file
·151 lines (126 loc) · 3.71 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
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
151
//var EventEmitter = require("events").EventEmitter;
//var messenger = new EventEmitter();
var express = require('express')
var path = require('path')
//var favicon = require('serve-favicon');
var cookieParser = require('cookie-parser')
var bodyParser = require('body-parser')
//===============CREATE ROOT PATH=================
var path = require('path')
global.appRoot = path.resolve(__dirname)
//===============CREATE APP=================
var app = express()
//=============CREATE LOGGER===============
var winston = require('winston')
winston.emitErrs = true
var logger = new winston.Logger({
transports: [
new winston.transports.File({
level: 'info',
filename: __dirname + '/logs/all-logs.log',
handleExceptions: true,
json: true,
maxsize: 5242880, //5MB
maxFiles: 5,
colorize: false
}),
new winston.transports.Console({
level: 'debug',
handleExceptions: true,
json: false,
colorize: true
})
],
exitOnError: false
})
module.exports.logger = logger
module.exports.logger.stream = {
write: function(message, encoding) {
logger.info(message)
}
}
//logger.debug("Overriding 'Express' logger");
app.use(require('morgan')({ stream: logger.stream }))
//===============CONF APP=================
// view engine setup
app.set('views', path.join(__dirname, 'views'))
app.set('view engine', 'pug')
// uncomment after placing your favicon in /public
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
app.use(bodyParser.json())
app.use(bodyParser.urlencoded({ extended: false }))
app.use(cookieParser())
app.use(express.static(path.join(__dirname, 'public')))
app.use('/bower_components', express.static(appRoot + '/bower_components'))
//===============SQLITE=================
var database = require(appRoot + '/bin/sqlite/sqlite')
var db = new database()
module.exports.db = db
//===============PASSPORT=================
var passport = require('passport')
var expressSession = require('express-session')
app.use(expressSession({ secret: 'mySecretKey' }))
app.use(passport.initialize())
app.use(passport.session())
// Using the flash middleware provided by connect-flash to store messages in session
// and displaying in templates
var flash = require('connect-flash')
app.use(flash())
// Initialize Passport
var initPassport = require('./passport/init')
initPassport(passport)
//===============ROUTES=================
//var routes = require(appRoot + '/routes/routes')(app, passport);
var login = require('./routes/login')
var webapp = require('./routes/web-app')
var api = require('./routes/api')
app.use('/login/', login)
app.use('/web-app/', webapp)
app.use('/api/', api)
app.get('*', function(req, res) {
res.redirect('/web-app/')
})
//===============ERRORS=================
// catch 404 and forward to error handler
app.use(function(req, res, next) {
var err = new Error('Not Found')
err.status = 404
next(err)
})
// error handlers
// 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: {}
})
})
//===============CREATE CRON=================
var CronJob = require('cron').CronJob
var Control = require('./bin/device_control')
Control.checkLessons()
try {
new CronJob({
cronTime: '0 */1 * * * *',
onTick: function() {
Control.checkLessons()
},
start: true
})
} catch (ex) {
logger.warn('cron pattern not valid')
}
module.exports = app