modern-errors
plugin to create HTTP error
responses.
This adds error.httpResponse() which converts error to
a plain object (RFC 7807, "problem
details") to use in an HTTP response.
Adding the plugin to
modern-errors.
import ModernError from 'modern-errors'
import modernErrorsHttp from 'modern-errors-http'
export const BaseError = ModernError.subclass('BaseError', {
plugins: [modernErrorsHttp],
})Configuring error fields.
export const AuthError = BaseError.subclass('AuthError', {
http: {
type: 'https://example.com/probs/auth',
status: 401,
},
})Creating an HTTP error response.
const error = new AuthError('Could not authenticate.', {
http: {
instance: '/users/62',
extra: { userId: 62 },
},
})
const object = error.httpResponse()
// {
// type: 'https://example.com/probs/auth',
// status: 401,
// title: 'AuthError',
// detail: 'Could not authenticate.',
// instance: '/users/62',
// stack: `AuthError: Could not authenticate.
// at ...`,
// extra: { userId: 62 },
// }npm install modern-errors-httpThis package works in both Node.js >=14.18.0 and
browsers.
It is an ES module and must be loaded using
an import or import() statement,
not require().
Type: Plugin
Plugin object to pass to the
plugins option of
ErrorClass.subclass().
Return value: HttpResponse
Converts error to a plain object to use in an HTTP response. Its shape follows
RFC 7807 ("problem details").
Type: object
Type: urlString
Default: undefined
URI identifying and documenting the error class. Ideally, each error class should set one.
Type: integer
Default: undefined
HTTP status code.
Type: string
Default: error.name
Error class name.
Type: string
Default: error.message
Error description.
Type: urlString
Default: undefined
URI identifying the value which errored.
Type: string
Default: error.stack
Error stack trace. Can be set to an empty string.
Type: object
Default: any additional error properties
Additional information. This is always safe to serialize as JSON. Can be set to an empty object.
Options can apply to (in priority order):
- Any error: second argument to
ModernError.subclass()
export const BaseError = ModernError.subclass('BaseError', {
plugins: [modernErrorsHttp],
http: { ...options },
})- Any error of a specific class (and its subclasses): second argument to
ErrorClass.subclass()
export const AuthError = BaseError.subclass('AuthError', {
http: { ...options },
})- A specific error: second argument to
new ErrorClass()
throw new AuthError('...', { http: { ...options } })- A specific
error.httpResponse()call
error.httpResponse(...args, { ...options })safe-json-value: ⛑️ JSON serialization should never failmodern-errors: Handle errors like it's 2022 🔮modern-errors-cli: Handle errors in CLI modulesmodern-errors-process: Handle process errorsmodern-errors-bugs: Print where to report bugsmodern-errors-serialize: Serialize/parse errorsmodern-errors-clean: Clean stack tracesmodern-errors-winston: Log errors with Winston
For any question, don't hesitate to submit an issue on GitHub.
Everyone is welcome regardless of personal background. We enforce a Code of conduct in order to promote a positive and inclusive environment.
This project was made with ❤️. The simplest way to give back is by starring and sharing it online.
If the documentation is unclear or has a typo, please click on the page's Edit
button (pencil icon) and suggest a correction.
If you would like to help us fix a bug or add a new feature, please check our guidelines. Pull requests are welcome!