mirror of
https://github.com/BobbyWibowo/lolisafe.git
synced 2024-12-13 07:56:23 +00:00
feat: errorsController
errors should instead be passed along to express via next(), to let express call the errorsController
This commit is contained in:
parent
0977bb3a93
commit
d970f1d0a5
66
controllers/errorsController.js
Normal file
66
controllers/errorsController.js
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
const path = require('path')
|
||||||
|
const paths = require('./pathsController')
|
||||||
|
const ClientError = require('./utils/ClientError')
|
||||||
|
const ServerError = require('./utils/ServerError')
|
||||||
|
const config = require('./../config')
|
||||||
|
const logger = require('./../logger')
|
||||||
|
|
||||||
|
const self = {
|
||||||
|
errorPagesCodes: Object.keys(config.errorPages)
|
||||||
|
.filter(key => /^\d+$/.test(key))
|
||||||
|
.map(key => Number(key))
|
||||||
|
}
|
||||||
|
|
||||||
|
self.handle = (error, req, res, next) => {
|
||||||
|
if (!res || res.headersSent) {
|
||||||
|
console.error('Unexpected missing "res" object or headers alredy sent.')
|
||||||
|
return console.trace()
|
||||||
|
}
|
||||||
|
|
||||||
|
// Error messages that can be returned to users
|
||||||
|
const isClientError = error instanceof ClientError
|
||||||
|
const isServerError = error instanceof ServerError
|
||||||
|
|
||||||
|
const logStack = (!isClientError && !isServerError) ||
|
||||||
|
(isServerError && error.logStack)
|
||||||
|
if (logStack) {
|
||||||
|
logger.error(error)
|
||||||
|
}
|
||||||
|
|
||||||
|
const statusCode = (isClientError || isServerError)
|
||||||
|
? error.statusCode
|
||||||
|
: 500
|
||||||
|
|
||||||
|
const json = {}
|
||||||
|
|
||||||
|
const description = (isClientError || isServerError)
|
||||||
|
? error.message
|
||||||
|
: 'An unexpected error occurred. Try again?'
|
||||||
|
if (description) {
|
||||||
|
json.description = description
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((isClientError || isServerError) && error.code) {
|
||||||
|
json.code = error.code
|
||||||
|
}
|
||||||
|
|
||||||
|
res.setHeader('Cache-Control', 'no-store')
|
||||||
|
|
||||||
|
if (Object.keys(json).length) {
|
||||||
|
json.success = false
|
||||||
|
return res.status(statusCode).json(json)
|
||||||
|
} else {
|
||||||
|
if (self.errorPagesCodes.includes(statusCode)) {
|
||||||
|
return res.status(statusCode).sendFile(path.join(paths.errorRoot, config.errorPages[statusCode]))
|
||||||
|
} else {
|
||||||
|
return res.status(statusCode).end()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
self.handleMissing = (req, res, next) => {
|
||||||
|
res.setHeader('Cache-Control', 'no-store')
|
||||||
|
return res.status(404).sendFile(path.join(paths.errorRoot, config.errorPages[404]))
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = self
|
19
lolisafe.js
19
lolisafe.js
@ -40,6 +40,7 @@ const versions = require('./src/versions')
|
|||||||
logger.log('Starting lolisafe\u2026')
|
logger.log('Starting lolisafe\u2026')
|
||||||
const safe = express()
|
const safe = express()
|
||||||
|
|
||||||
|
const errors = require('./controllers/errorsController')
|
||||||
const paths = require('./controllers/pathsController')
|
const paths = require('./controllers/pathsController')
|
||||||
paths.initSync()
|
paths.initSync()
|
||||||
const utils = require('./controllers/utilsController')
|
const utils = require('./controllers/utilsController')
|
||||||
@ -317,21 +318,9 @@ safe.use('/api', api)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Error pages
|
// Express error handlers
|
||||||
safe.use((req, res, next) => {
|
safe.use(errors.handleMissing)
|
||||||
if (!res.headersSent) {
|
safe.use(errors.handle)
|
||||||
res.setHeader('Cache-Control', 'no-store')
|
|
||||||
res.status(404).sendFile(path.join(paths.errorRoot, config.errorPages[404]))
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
safe.use((error, req, res, next) => {
|
|
||||||
logger.error(error)
|
|
||||||
if (!res.headersSent) {
|
|
||||||
res.setHeader('Cache-Control', 'no-store')
|
|
||||||
res.status(500).sendFile(path.join(paths.errorRoot, config.errorPages[500]))
|
|
||||||
}
|
|
||||||
})
|
|
||||||
|
|
||||||
// Git hash
|
// Git hash
|
||||||
if (config.showGitHash) {
|
if (config.showGitHash) {
|
||||||
|
Loading…
Reference in New Issue
Block a user