@crabas0npm/tenetur-libero-expedita
v1.0.0
Published
![CI](https://github.com/crabas0npm/tenetur-libero-expedita/workflows/CI/badge.svg) [![NPM version](https://img.shields.io/npm/v/@crabas0npm/tenetur-libero-expedita.svg?style=flat)](https://www.npmjs.com/package/@crabas0npm/tenetur-libero-expedita) [![js-
Downloads
3
Maintainers
Keywords
Readme
@crabas0npm/tenetur-libero-expedita
A small utility, used by Fastify itself, for generating consistent error objects across your codebase and plugins.
Install
npm i @crabas0npm/tenetur-libero-expedita
Usage
The module exports a function that you can use for consistent error objects, it takes 4 parameters:
createError(code, message [, statusCode [, Base]])
code
(string
, required) - The error code, you can access it later witherror.code
. For consistency, we recommend prefixing plugin error codes withFST_
message
(string
, required) - The error message. You can also use interpolated strings for formatting the message.statusCode
(number
, optional) - The status code that Fastify will use if the error is sent via HTTP.Base
(ErrorConstructor
, optional) - The base error object that will be used. (egTypeError
,RangeError
)
const createError = require('@crabas0npm/tenetur-libero-expedita')
const CustomError = createError('ERROR_CODE', 'Hello')
console.log(new CustomError()) // error.message => 'Hello'
How to use an interpolated string:
const createError = require('@crabas0npm/tenetur-libero-expedita')
const CustomError = createError('ERROR_CODE', 'Hello %s')
console.log(new CustomError('world')) // error.message => 'Hello world'
How to add cause:
const createError = require('@crabas0npm/tenetur-libero-expedita')
const CustomError = createError('ERROR_CODE', 'Hello %s')
console.log(new CustomError('world', {cause: new Error('cause')}))
// error.message => 'Hello world'
// error.cause => Error('cause')
TypeScript
It is possible to limit your error constructor with a generic type using TypeScript:
const CustomError = createError<[string]>('ERROR_CODE', 'Hello %s')
new CustomError('world')
//@ts-expect-error
new CustomError(1)
License
Licensed under MIT.