mirror of
https://github.com/usebruno/bruno.git
synced 2024-12-23 15:19:01 +01:00
Merge pull request #725 from cwilper/fix/https-proxy-agent-opts
fix: respect rejectUnauthorized and ca opts when proxying https
This commit is contained in:
commit
f22e975d90
@ -12,11 +12,10 @@ const { ScriptRuntime, TestRuntime, VarsRuntime, AssertRuntime } = require('@use
|
|||||||
const { stripExtension } = require('../utils/filesystem');
|
const { stripExtension } = require('../utils/filesystem');
|
||||||
const { getOptions } = require('../utils/bru');
|
const { getOptions } = require('../utils/bru');
|
||||||
const https = require('https');
|
const https = require('https');
|
||||||
const { HttpsProxyAgent } = require('https-proxy-agent');
|
|
||||||
const { HttpProxyAgent } = require('http-proxy-agent');
|
const { HttpProxyAgent } = require('http-proxy-agent');
|
||||||
const { SocksProxyAgent } = require('socks-proxy-agent');
|
const { SocksProxyAgent } = require('socks-proxy-agent');
|
||||||
const { makeAxiosInstance } = require('../utils/axios-instance');
|
const { makeAxiosInstance } = require('../utils/axios-instance');
|
||||||
const { shouldUseProxy } = require('../utils/proxy-util');
|
const { shouldUseProxy, PatchedHttpsProxyAgent } = require('../utils/proxy-util');
|
||||||
|
|
||||||
const runSingleRequest = async function (
|
const runSingleRequest = async function (
|
||||||
filename,
|
filename,
|
||||||
@ -152,7 +151,7 @@ const runSingleRequest = async function (
|
|||||||
request.httpsAgent = socksProxyAgent;
|
request.httpsAgent = socksProxyAgent;
|
||||||
request.httpAgent = socksProxyAgent;
|
request.httpAgent = socksProxyAgent;
|
||||||
} else {
|
} else {
|
||||||
request.httpsAgent = new HttpsProxyAgent(
|
request.httpsAgent = new PatchedHttpsProxyAgent(
|
||||||
proxyUri,
|
proxyUri,
|
||||||
Object.keys(httpsAgentRequestFields).length > 0 ? { ...httpsAgentRequestFields } : undefined
|
Object.keys(httpsAgentRequestFields).length > 0 ? { ...httpsAgentRequestFields } : undefined
|
||||||
);
|
);
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
const parseUrl = require('url').parse;
|
const parseUrl = require('url').parse;
|
||||||
|
const { isEmpty } = require('lodash');
|
||||||
|
const { HttpsProxyAgent } = require('https-proxy-agent');
|
||||||
|
|
||||||
const DEFAULT_PORTS = {
|
const DEFAULT_PORTS = {
|
||||||
ftp: 21,
|
ftp: 21,
|
||||||
@ -9,7 +11,7 @@ const DEFAULT_PORTS = {
|
|||||||
wss: 443
|
wss: 443
|
||||||
};
|
};
|
||||||
/**
|
/**
|
||||||
* check for proxy bypass, Copied form 'proxy-from-env'
|
* check for proxy bypass, copied form 'proxy-from-env'
|
||||||
*/
|
*/
|
||||||
const shouldUseProxy = (url, proxyBypass) => {
|
const shouldUseProxy = (url, proxyBypass) => {
|
||||||
if (proxyBypass === '*') {
|
if (proxyBypass === '*') {
|
||||||
@ -39,7 +41,6 @@ const shouldUseProxy = (url, proxyBypass) => {
|
|||||||
if (!dontProxyFor) {
|
if (!dontProxyFor) {
|
||||||
return true; // Skip zero-length hosts.
|
return true; // Skip zero-length hosts.
|
||||||
}
|
}
|
||||||
|
|
||||||
const parsedProxy = dontProxyFor.match(/^(.+):(\d+)$/);
|
const parsedProxy = dontProxyFor.match(/^(.+):(\d+)$/);
|
||||||
let parsedProxyHostname = parsedProxy ? parsedProxy[1] : dontProxyFor;
|
let parsedProxyHostname = parsedProxy ? parsedProxy[1] : dontProxyFor;
|
||||||
const parsedProxyPort = parsedProxy ? parseInt(parsedProxy[2]) : 0;
|
const parsedProxyPort = parsedProxy ? parseInt(parsedProxy[2]) : 0;
|
||||||
@ -61,6 +62,24 @@ const shouldUseProxy = (url, proxyBypass) => {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Patched version of HttpsProxyAgent to get around a bug that ignores
|
||||||
|
* options like ca and rejectUnauthorized when upgrading the socket to TLS:
|
||||||
|
* https://github.com/TooTallNate/proxy-agents/issues/194
|
||||||
|
*/
|
||||||
|
class PatchedHttpsProxyAgent extends HttpsProxyAgent {
|
||||||
|
constructor(proxy, opts) {
|
||||||
|
super(proxy, opts);
|
||||||
|
this.constructorOpts = opts;
|
||||||
|
}
|
||||||
|
|
||||||
|
async connect(req, opts) {
|
||||||
|
const combinedOpts = { ...this.constructorOpts, ...opts };
|
||||||
|
return super.connect(req, combinedOpts);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
shouldUseProxy
|
shouldUseProxy,
|
||||||
|
PatchedHttpsProxyAgent
|
||||||
};
|
};
|
||||||
|
@ -19,12 +19,11 @@ const { sortFolder, getAllRequestsInFolderRecursively } = require('./helper');
|
|||||||
const { preferencesUtil } = require('../../store/preferences');
|
const { preferencesUtil } = require('../../store/preferences');
|
||||||
const { getProcessEnvVars } = require('../../store/process-env');
|
const { getProcessEnvVars } = require('../../store/process-env');
|
||||||
const { getBrunoConfig } = require('../../store/bruno-config');
|
const { getBrunoConfig } = require('../../store/bruno-config');
|
||||||
const { HttpsProxyAgent } = require('https-proxy-agent');
|
|
||||||
const { HttpProxyAgent } = require('http-proxy-agent');
|
const { HttpProxyAgent } = require('http-proxy-agent');
|
||||||
const { SocksProxyAgent } = require('socks-proxy-agent');
|
const { SocksProxyAgent } = require('socks-proxy-agent');
|
||||||
const { makeAxiosInstance } = require('./axios-instance');
|
const { makeAxiosInstance } = require('./axios-instance');
|
||||||
const { addAwsV4Interceptor, resolveAwsV4Credentials } = require('./awsv4auth-helper');
|
const { addAwsV4Interceptor, resolveAwsV4Credentials } = require('./awsv4auth-helper');
|
||||||
const { shouldUseProxy } = require('../../utils/proxy-util');
|
const { shouldUseProxy, PatchedHttpsProxyAgent } = require('../../utils/proxy-util');
|
||||||
|
|
||||||
// override the default escape function to prevent escaping
|
// override the default escape function to prevent escaping
|
||||||
Mustache.escape = function (value) {
|
Mustache.escape = function (value) {
|
||||||
@ -149,7 +148,7 @@ const configureRequest = async (collectionUid, request, envVars, collectionVaria
|
|||||||
request.httpsAgent = socksProxyAgent;
|
request.httpsAgent = socksProxyAgent;
|
||||||
request.httpAgent = socksProxyAgent;
|
request.httpAgent = socksProxyAgent;
|
||||||
} else {
|
} else {
|
||||||
request.httpsAgent = new HttpsProxyAgent(
|
request.httpsAgent = new PatchedHttpsProxyAgent(
|
||||||
proxyUri,
|
proxyUri,
|
||||||
Object.keys(httpsAgentRequestFields).length > 0 ? { ...httpsAgentRequestFields } : undefined
|
Object.keys(httpsAgentRequestFields).length > 0 ? { ...httpsAgentRequestFields } : undefined
|
||||||
);
|
);
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
const parseUrl = require('url').parse;
|
const parseUrl = require('url').parse;
|
||||||
const { isEmpty } = require('lodash');
|
const { isEmpty } = require('lodash');
|
||||||
|
const { HttpsProxyAgent } = require('https-proxy-agent');
|
||||||
|
|
||||||
const DEFAULT_PORTS = {
|
const DEFAULT_PORTS = {
|
||||||
ftp: 21,
|
ftp: 21,
|
||||||
@ -61,6 +62,24 @@ const shouldUseProxy = (url, proxyBypass) => {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Patched version of HttpsProxyAgent to get around a bug that ignores options
|
||||||
|
* such as ca and rejectUnauthorized when upgrading the proxied socket to TLS:
|
||||||
|
* https://github.com/TooTallNate/proxy-agents/issues/194
|
||||||
|
*/
|
||||||
|
class PatchedHttpsProxyAgent extends HttpsProxyAgent {
|
||||||
|
constructor(proxy, opts) {
|
||||||
|
super(proxy, opts);
|
||||||
|
this.constructorOpts = opts;
|
||||||
|
}
|
||||||
|
|
||||||
|
async connect(req, opts) {
|
||||||
|
const combinedOpts = { ...this.constructorOpts, ...opts };
|
||||||
|
return super.connect(req, combinedOpts);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
shouldUseProxy
|
shouldUseProxy,
|
||||||
|
PatchedHttpsProxyAgent
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user