You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
/*! * statuses * Copyright(c) 2014 Jonathan Ong * Copyright(c) 2016 Douglas Christopher Wilson * MIT Licensed */
'use strict'
/** * Module dependencies. * @private */
var codes = require('./codes.json')
/** * Module exports. * @public */
module.exports = status
// status code to message map
status.message = codes
// status message (lower-case) to code map
status.code = createMessageToStatusCodeMap(codes)
// array of status codes
status.codes = createStatusCodeList(codes)
// status codes for redirects
status.redirect = { 300: true, 301: true, 302: true, 303: true, 305: true, 307: true, 308: true }
// status codes for empty bodies
status.empty = { 204: true, 205: true, 304: true }
// status codes for when you should retry the request
status.retry = { 502: true, 503: true, 504: true }
/** * Create a map of message to status code. * @private */
function createMessageToStatusCodeMap (codes) { var map = {}
Object.keys(codes).forEach(function forEachCode (code) { var message = codes[code] var status = Number(code)
// populate map
map[message.toLowerCase()] = status })
return map }
/** * Create a list of all status codes. * @private */
function createStatusCodeList (codes) { return Object.keys(codes).map(function mapCode (code) { return Number(code) }) }
/** * Get the status code for given message. * @private */
function getStatusCode (message) { var msg = message.toLowerCase()
if (!Object.prototype.hasOwnProperty.call(status.code, msg)) { throw new Error('invalid status message: "' + message + '"') }
return status.code[msg] }
/** * Get the status message for given code. * @private */
function getStatusMessage (code) { if (!Object.prototype.hasOwnProperty.call(status.message, code)) { throw new Error('invalid status code: ' + code) }
return status.message[code] }
/** * Get the status code. * * Given a number, this will throw if it is not a known status * code, otherwise the code will be returned. Given a string, * the string will be parsed for a number and return the code * if valid, otherwise will lookup the code assuming this is * the status message. * * @param {string|number} code * @returns {number} * @public */
function status (code) { if (typeof code === 'number') { return getStatusMessage(code) }
if (typeof code !== 'string') { throw new TypeError('code must be a number or string') }
// '403'
var n = parseInt(code, 10) if (!isNaN(n)) { return getStatusMessage(n) }
return getStatusCode(code) }
|