summaryrefslogtreecommitdiff
path: root/deps/npm/node_modules/request/node_modules/hawk/node_modules/boom/lib/index.js
diff options
context:
space:
mode:
Diffstat (limited to 'deps/npm/node_modules/request/node_modules/hawk/node_modules/boom/lib/index.js')
-rwxr-xr-xdeps/npm/node_modules/request/node_modules/hawk/node_modules/boom/lib/index.js189
1 files changed, 152 insertions, 37 deletions
diff --git a/deps/npm/node_modules/request/node_modules/hawk/node_modules/boom/lib/index.js b/deps/npm/node_modules/request/node_modules/hawk/node_modules/boom/lib/index.js
index 6bdea69368..17ed0279ea 100755
--- a/deps/npm/node_modules/request/node_modules/hawk/node_modules/boom/lib/index.js
+++ b/deps/npm/node_modules/request/node_modules/hawk/node_modules/boom/lib/index.js
@@ -1,16 +1,80 @@
+'use strict';
+
// Load modules
-var Http = require('http');
-var Hoek = require('hoek');
+const Hoek = require('hoek');
// Declare internals
-var internals = {};
+const internals = {
+ STATUS_CODES: Object.setPrototypeOf({
+ '100': 'Continue',
+ '101': 'Switching Protocols',
+ '102': 'Processing',
+ '200': 'OK',
+ '201': 'Created',
+ '202': 'Accepted',
+ '203': 'Non-Authoritative Information',
+ '204': 'No Content',
+ '205': 'Reset Content',
+ '206': 'Partial Content',
+ '207': 'Multi-Status',
+ '300': 'Multiple Choices',
+ '301': 'Moved Permanently',
+ '302': 'Moved Temporarily',
+ '303': 'See Other',
+ '304': 'Not Modified',
+ '305': 'Use Proxy',
+ '307': 'Temporary Redirect',
+ '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 Time-out',
+ '409': 'Conflict',
+ '410': 'Gone',
+ '411': 'Length Required',
+ '412': 'Precondition Failed',
+ '413': 'Request Entity Too Large',
+ '414': 'Request-URI Too Large',
+ '415': 'Unsupported Media Type',
+ '416': 'Requested Range Not Satisfiable',
+ '417': 'Expectation Failed',
+ '418': 'I\'m a teapot',
+ '422': 'Unprocessable Entity',
+ '423': 'Locked',
+ '424': 'Failed Dependency',
+ '425': 'Unordered Collection',
+ '426': 'Upgrade Required',
+ '428': 'Precondition Required',
+ '429': 'Too Many Requests',
+ '431': 'Request Header Fields Too Large',
+ '451': 'Unavailable For Legal Reasons',
+ '500': 'Internal Server Error',
+ '501': 'Not Implemented',
+ '502': 'Bad Gateway',
+ '503': 'Service Unavailable',
+ '504': 'Gateway Time-out',
+ '505': 'HTTP Version Not Supported',
+ '506': 'Variant Also Negotiates',
+ '507': 'Insufficient Storage',
+ '509': 'Bandwidth Limit Exceeded',
+ '510': 'Not Extended',
+ '511': 'Network Authentication Required'
+ }, null)
+};
+
exports.wrap = function (error, statusCode, message) {
Hoek.assert(error instanceof Error, 'Cannot wrap non-Error object');
+ Hoek.assert(!error.isBoom || (!statusCode && !message), 'Cannot provide statusCode or message with boom error');
+
return (error.isBoom ? error : internals.initialize(error, statusCode || 500, message));
};
@@ -20,18 +84,27 @@ exports.create = function (statusCode, message, data) {
return internals.create(statusCode, message, data, exports.create);
};
+
internals.create = function (statusCode, message, data, ctor) {
- var error = new Error(message ? message : undefined); // Avoids settings null message
+ if (message instanceof Error) {
+ if (data) {
+ message.data = data;
+ }
+ return exports.wrap(message, statusCode);
+ }
+
+ const error = new Error(message ? message : undefined); // Avoids settings null message
Error.captureStackTrace(error, ctor); // Filter the stack to our external API
error.data = data || null;
internals.initialize(error, statusCode);
return error;
};
+
internals.initialize = function (error, statusCode, message) {
- var numberCode = parseInt(statusCode, 10);
+ const numberCode = parseInt(statusCode, 10);
Hoek.assert(!isNaN(numberCode) && numberCode >= 400, 'First argument must be a number (400+):', statusCode);
error.isBoom = true;
@@ -67,7 +140,7 @@ internals.initialize = function (error, statusCode, message) {
internals.reformat = function () {
this.output.payload.statusCode = this.output.statusCode;
- this.output.payload.error = Http.STATUS_CODES[this.output.statusCode] || 'Unknown';
+ this.output.payload.error = internals.STATUS_CODES[this.output.statusCode] || 'Unknown';
if (this.output.statusCode === 500) {
this.output.payload.message = 'An internal server error occurred'; // Hide actual error from user
@@ -88,15 +161,13 @@ exports.badRequest = function (message, data) {
exports.unauthorized = function (message, scheme, attributes) { // Or function (message, wwwAuthenticate[])
- var err = internals.create(401, message, undefined, exports.unauthorized);
+ const err = internals.create(401, message, undefined, exports.unauthorized);
if (!scheme) {
return err;
}
- var wwwAuthenticate = '';
- var i = 0;
- var il = 0;
+ let wwwAuthenticate = '';
if (typeof scheme === 'string') {
@@ -109,29 +180,36 @@ exports.unauthorized = function (message, scheme, attributes) { // Or f
}
if (attributes) {
- var names = Object.keys(attributes);
- for (i = 0, il = names.length; i < il; ++i) {
- var name = names[i];
- if (i) {
- wwwAuthenticate += ',';
- }
-
- var value = attributes[name];
- if (value === null ||
- value === undefined) { // Value can be zero
-
- value = '';
+ if (typeof attributes === 'string') {
+ wwwAuthenticate = wwwAuthenticate + ' ' + Hoek.escapeHeaderAttribute(attributes);
+ err.output.payload.attributes = attributes;
+ }
+ else {
+ const names = Object.keys(attributes);
+ for (let i = 0; i < names.length; ++i) {
+ const name = names[i];
+ if (i) {
+ wwwAuthenticate = wwwAuthenticate + ',';
+ }
+
+ let value = attributes[name];
+ if (value === null ||
+ value === undefined) { // Value can be zero
+
+ value = '';
+ }
+ wwwAuthenticate = wwwAuthenticate + ' ' + name + '="' + Hoek.escapeHeaderAttribute(value.toString()) + '"';
+ err.output.payload.attributes[name] = value;
}
- wwwAuthenticate += ' ' + name + '="' + Hoek.escapeHeaderAttribute(value.toString()) + '"';
- err.output.payload.attributes[name] = value;
}
}
+
if (message) {
if (attributes) {
- wwwAuthenticate += ',';
+ wwwAuthenticate = wwwAuthenticate + ',';
}
- wwwAuthenticate += ' error="' + Hoek.escapeHeaderAttribute(message) + '"';
+ wwwAuthenticate = wwwAuthenticate + ' error="' + Hoek.escapeHeaderAttribute(message) + '"';
err.output.payload.attributes.error = message;
}
else {
@@ -142,13 +220,13 @@ exports.unauthorized = function (message, scheme, attributes) { // Or f
// function (message, wwwAuthenticate[])
- var wwwArray = scheme;
- for (i = 0, il = wwwArray.length; i < il; ++i) {
+ const wwwArray = scheme;
+ for (let i = 0; i < wwwArray.length; ++i) {
if (i) {
- wwwAuthenticate += ', ';
+ wwwAuthenticate = wwwAuthenticate + ', ';
}
- wwwAuthenticate += wwwArray[i];
+ wwwAuthenticate = wwwAuthenticate + wwwArray[i];
}
}
@@ -158,6 +236,12 @@ exports.unauthorized = function (message, scheme, attributes) { // Or f
};
+exports.paymentRequired = function (message, data) {
+
+ return internals.create(402, message, data, exports.paymentRequired);
+};
+
+
exports.forbidden = function (message, data) {
return internals.create(403, message, data, exports.forbidden);
@@ -170,9 +254,19 @@ exports.notFound = function (message, data) {
};
-exports.methodNotAllowed = function (message, data) {
+exports.methodNotAllowed = function (message, data, allow) {
+
+ const err = internals.create(405, message, data, exports.methodNotAllowed);
+
+ if (typeof allow === 'string') {
+ allow = [allow];
+ }
+
+ if (Array.isArray(allow)) {
+ err.output.headers.Allow = allow.join(', ');
+ }
- return internals.create(405, message, data, exports.methodNotAllowed);
+ return err;
};
@@ -247,12 +341,25 @@ exports.expectationFailed = function (message, data) {
return internals.create(417, message, data, exports.expectationFailed);
};
+
+exports.teapot = function (message, data) {
+
+ return internals.create(418, message, data, exports.teapot);
+};
+
+
exports.badData = function (message, data) {
return internals.create(422, message, data, exports.badData);
};
+exports.locked = function (message, data) {
+
+ return internals.create(423, message, data, exports.locked);
+};
+
+
exports.preconditionRequired = function (message, data) {
return internals.create(428, message, data, exports.preconditionRequired);
@@ -265,6 +372,12 @@ exports.tooManyRequests = function (message, data) {
};
+exports.illegal = function (message, data) {
+
+ return internals.create(451, message, data, exports.illegal);
+};
+
+
// 5xx Server Errors
exports.internal = function (message, data, statusCode) {
@@ -272,12 +385,14 @@ exports.internal = function (message, data, statusCode) {
return internals.serverError(message, data, statusCode, exports.internal);
};
+
internals.serverError = function (message, data, statusCode, ctor) {
- var error;
+ let error;
if (data instanceof Error) {
error = exports.wrap(data, statusCode, message);
- } else {
+ }
+ else {
error = internals.create(statusCode || 500, message, undefined, ctor);
error.data = data;
}
@@ -298,9 +413,9 @@ exports.badGateway = function (message, data) {
};
-exports.serverTimeout = function (message, data) {
+exports.serverUnavailable = function (message, data) {
- return internals.serverError(message, data, 503, exports.serverTimeout);
+ return internals.serverError(message, data, 503, exports.serverUnavailable);
};
@@ -312,7 +427,7 @@ exports.gatewayTimeout = function (message, data) {
exports.badImplementation = function (message, data) {
- var err = internals.serverError(message, data, 500, exports.badImplementation);
+ const err = internals.serverError(message, data, 500, exports.badImplementation);
err.isDeveloperError = true;
return err;
};