Create HTTP error objects for xprezzo
npm install xprezzo-http-errorsCreate HTTP errors for Xprezzo.
This is a Node.js module available through the
npm registry. Installation is done using thenpm install command:
``bash`
$ npm install xprezzo-http-errors
`js
var createError = require('xprezzo-http-errors')
var xprezzo = require('xprezzo')
var app = xprezzo()
app.use(function (req, res, next) {
if (!req.user) return next(createError(401, 'Please login to view this page.'))
next()
})
`
This is the current API, currently extracted from Koa and subject to change.
- expose - can be used to signal if message should be sent to the client,false
defaulting to when status >= 500headers
- - can be an object of header names to values to be sent to theundefined
client, defaulting to . When defined, the key names should allmessage
be lower-cased
- - the traditional error message, which should be kept short and allstatus
single line
- - the status code of the error, mirroring statusCode for generalstatusCode
compatibility
- - the status code of the error, defaulting to 500
Create a new error object with the given message msg.createError.HttpError
The error object inherits from .
`js`
var err = createError(404, 'This video does not exist!')
- status: 500 - the status code as a numbermessage
- - the message of the error, defaulting to node's text for that status code.properties
- - custom properties to attach to the object
Extend the given error object with createError.HttpErrorerror
properties. This will not alter the inheritance of the given object, and the modified error object is the
return value.
`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 numbererror
- - the error object to extendproperties
- - custom properties to attach to the object
Determine if the provided val is an HttpError. This will return trueHttpError
if the error inherits from the constructor of this module orcreateError
matches the "duck type" for an error this module creates. All outputs from
the factory will return true for this function, includingHttpError
if an non- was passed into the factory.
Create a new error object with the given message msg.createError.HttpError
The error object inherits from .
`js`
var err = new createError.NotFound()
- code - the status code as a numbername
- - 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 |UnorderedCollection |
|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|
Xprezzo and related projects are maintained by Cloudgen Wong.