-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
48 lines (46 loc) · 1.48 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
const express = require('express')
const compression = require('compression')
const helmet = require('helmet')
const session = require('express-session')
const cors = require('cors')
const expressWinston = require('express-winston')
const { keycloak } = require('./services/auth')
const mongoStore = require('./services/sessions')
const config = require('./config')
const log = require('./services/logger')
const init = require('./scripts/init')
const { NODE_ENV } = process.env
const loggerMiddleware = expressWinston.logger({ winstonInstance: log })
// Accept crazy weird CERTs
process.env['NODE_TLS_REJECT_UNAUTHORIZED'] = 0
module.exports = (async () => {
try {
const server = express()
// Apply middlewares
server.use(helmet())
server.use(cors())
server.use(compression())
server.use(express.json({limit: '50mb'}))
server.use(express.urlencoded({ limit: '50mb', extended: false }))
server.use(loggerMiddleware)
server.use(session({
secret: config.SESSION_SECRET,
resave: false,
saveUninitialized: true,
store: mongoStore
}))
server.use(keycloak.middleware())
// Apply API routes
server.use('/', require('./api'))
await init.checkInit()
return server.listen(config.PORT, (err) => {
if (err) {
throw err
}
log.info('> Ready on http://localhost:' + config.PORT + ' [' + NODE_ENV + ']')
})
} catch (err) {
log.error('An error occurred, unable to start the server')
log.error(err)
}
})()