Skip to content

trojs/error

Repository files navigation

@trojs/error

NPM version

With this package you can throw a custom error with more details. The object extends an Error object.

Types:

  • NoContent (204)
  • ValidationError (400)
  • AuthenticationError (401)
  • AccessError (403)
  • NotFoundError (404)
  • NotImplementedError (405)
  • TimeoutError (408)
  • ProcessingError (422)
  • RateLimitError (429)
  • AppError (500)
  • ServerError (500)
  • ResponseError (502)

You can send:

  • message (type: String)
  • value (type: mixed)
  • type (String|Array|Object|Number|Boolean|Date|...)
  • me (current method, no validation on the value)

It validate the values by this schema:

{
    name: String,
    message: String,
    'value?': 'mixed',
    status: Number,
    'type?': Function,
    date: Date,
};

In the catch method, you can use these fields:

  • name (type: String)
  • message (type: String)
  • value (optional, type: mixed)
  • errorStatus (type: Number)
  • status (type: Number, like errorStatus, but it will return 500 if there are validation errors)
  • type (optional, type: Function)
  • date (type: Date, current timestamp)
  • me (type: mixed)
  • values (type: Object, all fields)
  • hasErrors (type: Boolean, returns true if there are validation errors)

Install the package:

npm install @trojs/error or yarn add @trojs/error

Example usage:

import { NotFoundError } from '@trojs/error'

class Test {
    /**
     * Throw an error.
     */
    doSomethingWrong () {
        throw new NotFoundError({
            value: 'test',
            type: String,
            message: 'Example text',
            me: this.constructor,
        });
    }

    /**
     * Catch the error.
     */
    run() {
        try {
            this.doSomethingWrong()
        } catch(error) {
            console.error(error.message)
            console.log({ value: error.value })
        }
    }
}