diff --git a/.changeset/giant-vans-refuse.md b/.changeset/giant-vans-refuse.md new file mode 100644 index 00000000..b653fb36 --- /dev/null +++ b/.changeset/giant-vans-refuse.md @@ -0,0 +1,5 @@ +--- +"pac-proxy-agent": patch +--- + +use WHATWG URL class to construct url parameter diff --git a/packages/pac-proxy-agent/src/index.ts b/packages/pac-proxy-agent/src/index.ts index 57aa06d5..8a0e3b32 100644 --- a/packages/pac-proxy-agent/src/index.ts +++ b/packages/pac-proxy-agent/src/index.ts @@ -5,7 +5,7 @@ import * as crypto from 'crypto'; import { once } from 'events'; import createDebug from 'debug'; import { Readable } from 'stream'; -import { format, URL } from 'url'; +import { URL } from 'url'; import { Agent, AgentConnectOpts, toBuffer } from 'agent-base'; import { HttpProxyAgent, HttpProxyAgentOptions } from 'http-proxy-agent'; import { HttpsProxyAgent, HttpsProxyAgentOptions } from 'https-proxy-agent'; @@ -186,32 +186,16 @@ export class PacProxyAgent extends Agent { const resolver = await this.getResolver(); // Calculate the `url` parameter + const protocol = secureEndpoint ? 'https:' : 'http:'; + const host = + opts.host && net.isIPv6(opts.host) ? `[${opts.host}]` : opts.host; const defaultPort = secureEndpoint ? 443 : 80; - let path = req.path; - let search: string | null = null; - const firstQuestion = path.indexOf('?'); - if (firstQuestion !== -1) { - search = path.substring(firstQuestion); - path = path.substring(0, firstQuestion); - } - - const urlOpts = { - ...opts, - protocol: secureEndpoint ? 'https:' : 'http:', - pathname: path, - search, - - // need to use `hostname` instead of `host` otherwise `port` is ignored - hostname: opts.host, - host: null, - href: null, - - // set `port` to null when it is the protocol default port (80 / 443) - port: defaultPort === opts.port ? null : opts.port, - }; - const url = format(urlOpts); + const url = Object.assign( + new URL(req.path, `${protocol}//${host}`), + defaultPort ? undefined : { port: opts.port } + ); - debug('url: %o', url); + debug('url: %s', url); let result = await resolver(url); // Default to "DIRECT" if a falsey value was returned (or nothing)