|
# http-errors |
|
|
|
[![NPM Version][npm-version-image]][npm-url] |
|
[![NPM Downloads][npm-downloads-image]][node-url] |
|
[![Node.js Version][node-image]][node-url] |
|
[![Build Status][ci-image]][ci-url] |
|
[![Test Coverage][coveralls-image]][coveralls-url] |
|
|
|
Create HTTP errors for Express, Koa, Connect, etc. with ease. |
|
|
|
## Install |
|
|
|
This is a [Node.js](https://nodejs.org/en/) module available through the |
|
[npm registry](https://www.npmjs.com/). Installation is done using the |
|
[`npm install` command](https://docs.npmjs.com/getting-started/installing-npm-packages-locally): |
|
|
|
```console |
|
$ npm install http-errors |
|
``` |
|
|
|
## Example |
|
|
|
```js |
|
var createError = require('http-errors') |
|
var express = require('express') |
|
var app = express() |
|
|
|
app.use(function (req, res, next) { |
|
if (!req.user) return next(createError(401, 'Please login to view this page.')) |
|
next() |
|
}) |
|
``` |
|
|
|
## API |
|
|
|
This is the current API, currently extracted from Koa and subject to change. |
|
|
|
### Error Properties |
|
|
|
- `expose` - can be used to signal if `message` should be sent to the client, |
|
defaulting to `false` when `status` >= 500 |
|
- `headers` - can be an object of header names to values to be sent to the |
|
client, defaulting to `undefined`. When defined, the key names should all |
|
be lower-cased |
|
- `message` - the traditional error message, which should be kept short and all |
|
single line |
|
- `status` - the status code of the error, mirroring `statusCode` for general |
|
compatibility |
|
- `statusCode` - the status code of the error, defaulting to `500` |
|
|
|
### createError([status], [message], [properties]) |
|
|
|
Create a new error object with the given message `msg`. |
|
The error object inherits from `createError.HttpError`. |
|
|
|
```js |
|
var err = createError(404, 'This video does not exist!') |
|
``` |
|
|
|
- `status: 500` - the status code as a number |
|
- `message` - the message of the error, defaulting to node's text for that status code. |
|
- `properties` - custom properties to attach to the object |
|
|
|
### createError([status], [error], [properties]) |
|
|
|
Extend the given `error` object with `createError.HttpError` |
|
properties. This will not alter the inheritance of the given |
|
`error` object, and the modified `error` object is the |
|
return value. |
|
|
|
<!-- eslint-disable no-redeclare --> |
|
|
|
```js |
|
fs.readFile('foo.txt', function (err, buf) { |
|
if (err) { |
|
if (err.code === 'ENOENT') { |
|
var httpError = createError(404, err, { expose: false }) |
|
} else { |
|
var httpError = createError(500, err) |
|
} |
|
} |
|
}) |
|
``` |
|
|
|
- `status` - the status code as a number |
|
- `error` - the error object to extend |
|
- `properties` - custom properties to attach to the object |
|
|
|
### createError.isHttpError(val) |
|
|
|
Determine if the provided `val` is an `HttpError`. This will return `true` |
|
if the error inherits from the `HttpError` constructor of this module or |
|
matches the "duck type" for an error this module creates. All outputs from |
|
the `createError` factory will return `true` for this function, including |
|
if an non-`HttpError` was passed into the factory. |
|
|
|
### new createError\[code || name\](\[msg]\)) |
|
|
|
Create a new error object with the given message `msg`. |
|
The error object inherits from `createError.HttpError`. |
|
|
|
```js |
|
var err = new createError.NotFound() |
|
``` |
|
|
|
- `code` - the status code as a number |
|
- `name` - the name of the error as a "bumpy case", i.e. `NotFound` or `InternalServerError`. |
|
|
|
#### List of all constructors |
|
|
|
|Status Code|Constructor Name | |
|
|-----------|-----------------------------| |
|
|400 |BadRequest | |
|
|401 |Unauthorized | |
|
|402 |PaymentRequired | |
|
|403 |Forbidden | |
|
|404 |NotFound | |
|
|405 |MethodNotAllowed | |
|
|406 |NotAcceptable | |
|
|407 |ProxyAuthenticationRequired | |
|
|408 |RequestTimeout | |
|
|409 |Conflict | |
|
|410 |Gone | |
|
|411 |LengthRequired | |
|
|412 |PreconditionFailed | |
|
|413 |PayloadTooLarge | |
|
|414 |URITooLong | |
|
|415 |UnsupportedMediaType | |
|
|416 |RangeNotSatisfiable | |
|
|417 |ExpectationFailed | |
|
|418 |ImATeapot | |
|
|421 |MisdirectedRequest | |
|
|422 |UnprocessableEntity | |
|
|423 |Locked | |
|
|424 |FailedDependency | |
|
|425 |TooEarly | |
|
|426 |UpgradeRequired | |
|
|428 |PreconditionRequired | |
|
|429 |TooManyRequests | |
|
|431 |RequestHeaderFieldsTooLarge | |
|
|451 |UnavailableForLegalReasons | |
|
|500 |InternalServerError | |
|
|501 |NotImplemented | |
|
|502 |BadGateway | |
|
|503 |ServiceUnavailable | |
|
|504 |GatewayTimeout | |
|
|505 |HTTPVersionNotSupported | |
|
|506 |VariantAlsoNegotiates | |
|
|507 |InsufficientStorage | |
|
|508 |LoopDetected | |
|
|509 |BandwidthLimitExceeded | |
|
|510 |NotExtended | |
|
|511 |NetworkAuthenticationRequired| |
|
|
|
## License |
|
|
|
[MIT](LICENSE) |
|
|
|
[ci-image]: https://badgen.net/github/checks/jshttp/http-errors/master?label=ci |
|
[ci-url]: https://github.com/jshttp/http-errors/actions?query=workflow%3Aci |
|
[coveralls-image]: https://badgen.net/coveralls/c/github/jshttp/http-errors/master |
|
[coveralls-url]: https://coveralls.io/r/jshttp/http-errors?branch=master |
|
[node-image]: https://badgen.net/npm/node/http-errors |
|
[node-url]: https://nodejs.org/en/download |
|
[npm-downloads-image]: https://badgen.net/npm/dm/http-errors |
|
[npm-url]: https://npmjs.org/package/http-errors |
|
[npm-version-image]: https://badgen.net/npm/v/http-errors |
|
[travis-image]: https://badgen.net/travis/jshttp/http-errors/master |
|
[travis-url]: https://travis-ci.org/jshttp/http-errors |
|
|