-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmiddleware.js
More file actions
58 lines (48 loc) · 1.43 KB
/
middleware.js
File metadata and controls
58 lines (48 loc) · 1.43 KB
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
const pinoNoir = require('pino-noir')
const pinoLogger = require('express-pino-logger')
const { STATUS_CODES } = require('http')
module.exports = {
logger: logger(),
cors,
notFound,
handleError,
handleValidationError
}
function logger () {
return pinoLogger({
serializers: pinoNoir([
'res.headers.set-cookie',
'req.headers.cookie',
'req.headers.authorization'
])
})
}
function cors (req, res, next) {
const origin = req.headers.origin
res.setHeader('Access-Control-Allow-Origin', origin || '*')
res.setHeader(
'Access-Control-Allow-Methods',
'POST, GET, PUT, DELETE, OPTIONS, XMODIFY'
)
res.setHeader('Access-Control-Allow-Credentials', 'true')
res.setHeader('Access-Control-Max-Age', '86400')
res.setHeader(
'Access-Control-Allow-Headers',
'X-Requested-With, X-HTTP-Method-Override, Content-Type, Accept'
)
next()
}
function handleError (err, req, res, next) {
if (res.headersSent) return next(err)
if (!err.statusCode) console.error(err)
const statusCode = err.statusCode || 500
const errorMessage = STATUS_CODES[statusCode] || 'Internal Error'
res.status(statusCode).json({ error: errorMessage })
}
function notFound (req, res) {
res.status(404).json({ error: 'Not Found' })
}
function handleValidationError (err, req, res, next) {
if (err.name !== 'ValidationError') return next(err)
res.status(400).json({ error: err._message, errorDetails: err.errors })
}