170 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			170 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # 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
 |