-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathapp.js
61 lines (52 loc) · 1.45 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
const dotenv = require('dotenv')
dotenv.config()
const express = require('express')
const app = express()
const routeManager = require('./route/route.manager.js')
const db = require("./models/index");
const cors = require('cors')
const bodyParser = require('body-parser')
const swaggerDocs = require('./swagger.js')
const passport = require('passport');
const { jwtStrategy } = require('./config/passport');
const helmet = require('helmet');
const xss = require('xss-clean');
// set security HTTP headers
app.use(helmet());
app.use(xss());
app.use(express.json())
app.use(bodyParser.json())
app.use(bodyParser.urlencoded({extended: false}));
app.use(cors());
db.sequelize.sync()
.then(() => {
console.log("sync db.");
})
.catch((err) => {
console.log("Failed to sync db: " + err.message);
});
// jwt authentication
app.use(passport.initialize());
passport.use('jwt', jwtStrategy);
routeManager(app)
swaggerDocs(app, process.env.PORT)
// error handler
app.use(function (err, req, res, next) {
console.error(err.stack)
res.status(500).json({
status: 'fail',
code : 500,
error : `Can't find ${err.stack}`
});
});
// 404 handler
app.use(function (req, res, next) {
res.status(404).json({
status: 'fail',
code : 404,
error : `Can't find ${req.originalUrl}`
});
});
app.listen(process.env.PORT, () => {
console.log(`:::::::::::::::: SERVER RUNNING ON ${process.env.PORT}.`);
});