forked from Gobie/luncher
-
Notifications
You must be signed in to change notification settings - Fork 0
/
server.js
38 lines (30 loc) · 982 Bytes
/
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
'use strict'
let config = require('./config.js')
let throng = require('throng')
let start = (workerId) => {
let helmet = require('helmet')
let compression = require('compression')
let morgan = require('morgan')
let winston = require('winston')
let express = require('express')
let app = express()
let bus = require('./lib/bus')(config, winston)
let onListen = () => winston.info('SERVER: worker', workerId, 'is listening on', config.PORT)
let errorHandler = (err, req, res, next) => {
winston.error('SERVER: error', err.stack)
if (res.headersSent) return next(err)
res.status(500)
res.send({error: err})
}
app
.use(morgan(config.LOGGING))
.use(compression())
.use(helmet())
.use('/api', require('./server/route/api/index')(express.Router(), bus, config))
.get('/', require('./server/route/index')(bus, config))
.use(errorHandler)
.listen(config.PORT, onListen)
}
throng({
workers: config.WORKERS
}, start)