5.2.0 • Published 5 years ago
error-middleware v5.2.0
Error Middleware for Express
This package handles errors on the express code and returns it with a fixed pattern, without leaks. It works with syncronous and asyncronous route functions.
Installation
npm install error-middleware
or
yarn add error-middleware
Error Types
Currently the middleware has exposed the following error types:
- BadRequestError
- ForbiddenError
- NotFoundError
- UnauthorizedError
- Validation Error
But you can also use
- CustomError
Error response format
The consumer will receive a JSON object with code, type and error as folows:
{
  code: <error code>,
  type: <error type>,
  error: <error message>
}Example of expected responses
How to use
- src/index.js Where you declare all your high level routes. The middleware should be last to be able to catch all errors. - import errorMiddleware from 'error-middleware' import routes from './routes' router.use(routes) router.use(errorMiddleware)
- src/routes.js - import { BadRequestError, ValidationError, NotFoundError } from 'error-middleware/errors' router.put('/user/:id', (req, res) => { const { id } = req.params const { name, email } = req.body const idRegex = /^\d{4}$/ if (!idRegex.test(id)) { throw new BadRequestError(`User 'id' is malformed.`) } if (!validate(name, email)) { throw new ValidationError({ name: 'Name should be at least 4 characters long', email: 'Invalid email', }) } // your update logic goes here // { ... } res.sendStatus(200) }) router.get('/error', (req, res) => { // an endpoint that simulates a pure error being thrown. It will be translated to InternalError and all its content will not be leaked. throw new Error('Internal error that should not be leaked.') }) // If no matches found, return 404 router.use((req, res) => { throw new NotFoundError() })
Check examples for more