-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
107 lines (94 loc) · 3.21 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
if(process.env.NODE_ENV == "dev")
require('dotenv').config();
// environment variables:
// NODE_ENV
// PORT
// BODYPARSER_URLENCODED_LIM
// BODYPARSER_URLENCODED_EXTENDED
// SESSION_SECRET
// SESSION_COOKIE_MAXAGE
// DB_CONNECTION_LIM
// DB_HOST
// DB_USER
// DB_PASS
// EMAIL
// REFRESH_TOKEN
// CLIENT_SECRET
// CLIENT_ID
const express = require('express');
const app = express();
const expressLayout = require('express-ejs-layouts');
const bodyParser = require('body-parser');
const db = require('./modules/db');
const mailer = require('./modules/mailer');
const {writeLog} = require('./modules/log');
app.set('view engine', 'ejs');
app.set('views', __dirname + '/views');
app.set('layout', 'layouts/layout');
app.use(expressLayout);
app.use(express.static('public'));
app.use(bodyParser.urlencoded({limit: process.env.BODYPARSER_URLENCODED_LIM || '10mb', extended: false}));
const ppconfig = require('./modules/ppconfig');
const flash = require('express-flash');
const session = require('express-session');
const methodOverride = require('method-override');
app.use(flash());
const cookieAge = parseInt(process.env.SESSION_COOKIE_MAXAGE) || 3600000;
app.use(session({
secret: process.env.SESSION_SECRET || 'vj34rc249123rn',
resave: false,
saveUninitialized: false,
cookie: {expires: cookieAge}
}));
app.use(ppconfig.passport.initialize())
app.use(ppconfig.passport.session());
app.use(methodOverride('_method'));
// render objects
app.use((req, res, next)=>{
res.locals.cats = db.cats;
res.locals.path = req.path.slice(req.path.lastIndexOf('/')+1);
if(req.isAuthenticated()){
res.locals.user = req.user;
req.session.cookie.expires = new Date(Date.now() + cookieAge);
if(req.user.role == 'member'){
db.uquery(`CALL getNotifications(${req.user.id})`)
.then((results)=>{
results.pop();
res.locals.notifications = results;
next();
}).catch((err)=>{
console.error(err);
res.locals.notifications = db.error(err);
next();
})
}else{next();}
}else{next();}
});
const indexRouter = require('./routes/index');
const authorRouter = require('./routes/authors');
const bookRouter = require('./routes/books');
const userRouter = require('./routes/users');
const staffRouter = require('./routes/staffs');
const adminRouter = require('./routes/admin');
app.use('/', indexRouter);
app.use('/authors', authorRouter);
app.use('/books', bookRouter);
app.use('/users', userRouter);
app.use('/staffs', staffRouter);
app.use('/admin', adminRouter);
const port = process.env.PORT || 3000;
const server = app.listen(port, () => console.log(`Listening on port ${port}`));
const proc = require('process');
function shutdown(err){
console.error(`About to exit with code ${err}`);
writeLog(`About to exit with code ${err}`);
db.books.end((err)=>console.error(err));
db.users.end((err)=>console.error(err));
mailer.transporter.close();
server.close();
process.exit(0);
}
// proc.on('exit', shutdown);
proc.on('SIGINT', shutdown);
proc.on('SIGTERM', shutdown);
proc.on('SIGABRT', shutdown);