summaryrefslogtreecommitdiff
path: root/deps/npm/node_modules/agent-base/patch-core.js
diff options
context:
space:
mode:
Diffstat (limited to 'deps/npm/node_modules/agent-base/patch-core.js')
-rw-r--r--deps/npm/node_modules/agent-base/patch-core.js46
1 files changed, 30 insertions, 16 deletions
diff --git a/deps/npm/node_modules/agent-base/patch-core.js b/deps/npm/node_modules/agent-base/patch-core.js
index 47d26a72b0..21cbbb6753 100644
--- a/deps/npm/node_modules/agent-base/patch-core.js
+++ b/deps/npm/node_modules/agent-base/patch-core.js
@@ -8,21 +8,25 @@ const https = require('https');
*
* There is currently no PR attempting to move this property upstream.
*/
-https.request = (function(request) {
- return function(_options, cb) {
- let options;
- if (typeof _options === 'string') {
- options = url.parse(_options);
- } else {
- options = Object.assign({}, _options);
- }
- if (null == options.port) {
- options.port = 443;
- }
- options.secureEndpoint = true;
- return request.call(https, options, cb);
- };
-})(https.request);
+const patchMarker = "__agent_base_https_request_patched__";
+if (!https.request[patchMarker]) {
+ https.request = (function(request) {
+ return function(_options, cb) {
+ let options;
+ if (typeof _options === 'string') {
+ options = url.parse(_options);
+ } else {
+ options = Object.assign({}, _options);
+ }
+ if (null == options.port) {
+ options.port = 443;
+ }
+ options.secureEndpoint = true;
+ return request.call(https, options, cb);
+ };
+ })(https.request);
+ https.request[patchMarker] = true;
+}
/**
* This is needed for Node.js >= 9.0.0 to make sure `https.get()` uses the
@@ -30,7 +34,17 @@ https.request = (function(request) {
*
* Ref: https://github.com/nodejs/node/commit/5118f31
*/
-https.get = function(options, cb) {
+https.get = function (_url, _options, cb) {
+ let options;
+ if (typeof _url === 'string' && _options && typeof _options !== 'function') {
+ options = Object.assign({}, url.parse(_url), _options);
+ } else if (!_options && !cb) {
+ options = _url;
+ } else if (!cb) {
+ options = _url;
+ cb = _options;
+ }
+
const req = https.request(options, cb);
req.end();
return req;