-
Notifications
You must be signed in to change notification settings - Fork 1
/
map-http-status-to-name.mjs
85 lines (81 loc) · 3.04 KB
/
map-http-status-to-name.mjs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
// We considered using something like 'http-status' (https://www.npmjs.com/package/http-status), but it would add a
// bunch of unnecessary codes. I.e., errors don't need 1xx, 2xx, or 3xx codes since those represent non-error statuses.
const defaultMappings = {
400 : 'Bad Request',
401 : 'Unauthorized',
402 : 'Payment Required',
403 : 'Forbidden',
404 : 'Not Found',
405 : 'Method Not Allowed',
406 : 'Not Acceptable',
407 : 'Proxy Authentication Required',
408 : 'Request Timeout',
409 : 'Conflict',
410 : 'Gone',
411 : 'Length Required',
412 : 'Precondition Failed',
413 : 'Content Too Large',
414 : 'URI Too Long',
415 : 'Unsupported Media Type',
416 : 'Range Not Satisfiable',
417 : 'Expectation Failed',
418 : '(Unused)',
421 : 'Misdirected Request',
422 : 'Unprocessable Content',
423 : 'Locked',
424 : 'Failed Dependency',
425 : 'Too Early',
426 : 'Upgrade Required',
428 : 'Precondition Required',
429 : 'Too Many Requests',
431 : 'Request Header Fields Too Large',
440 : 'Login Time Out', // extended code from IIS
444 : 'No Response', // extended code from Nginx
451 : 'Unavailable For Legal Reasons',
500 : 'Internal Server Error',
501 : 'Not Implemented',
502 : 'Bad Gateway',
503 : 'Service Unavailable',
504 : 'Gateway Timeout',
505 : 'HTTP Version Not Supported',
506 : 'Variant Also Negotiates',
507 : 'Insufficient Storage',
508 : 'Loop Detected',
510 : 'Not Extended', // OBSOLETE
511 : 'Network Authentication Required',
540 : 'Unknown Error', // extended code from Cloudflair
}
const customMappings = {}
/* eslint-disable jsdoc/check-types */
/**
* Used to translate and manage mappings from HTTP status codes to names. Supports all current status defined by the [
* IANA](https://www.iana.org/assignments/http-status-codes/http-status-codes.xhtml), as well as common extensions
* returned by IIS, NginX, and Cloudflare.
* - To retrieve a status name, call `mapHttpStatusToName(status)` (where `status` is a `string`).
* - To add/override a single custom mapping, call `mapHttpStatusToName(status, name)`.
* - To bulk add/override custom mappings, call `mapHttpStatusToName(/mappings)` (where `mappings is an `Object`).
* - To reset the custom mappings to default, call `mapHttpStatusToName()`.
* @param {number|Object<number,string>} status - Either the status to retrieve or set mapping for, or an
* `Object<number,string>` to bulk update mappings.
* @param {string} name - The name to map a status onto.
* @returns {string|undefined} The status name, if known.
* @category Settings management
*/
const mapHttpStatusToName = (status, name) => {
/* eslint-enable jsdoc/check-types */
if (status === undefined) {
for (const prop in customMappings) {
delete customMappings[prop]
}
}
else if (typeof status === 'object') {
Object.assign(customMappings, status)
}
else if (name === undefined) {
return customMappings[status] || defaultMappings[status] || 'Unassigned'
}
else {
customMappings[status] = name
}
}
export { mapHttpStatusToName }