mirror of
https://github.com/actions/http-client.git
synced 2025-02-25 00:52:46 +00:00
Remove deprecated URL API usage
This commit is contained in:
parent
ab10999b09
commit
6543260f0a
@ -2,7 +2,6 @@ import * as http from 'http'
|
|||||||
import * as httpm from '../_out'
|
import * as httpm from '../_out'
|
||||||
import * as pm from '../_out/proxy'
|
import * as pm from '../_out/proxy'
|
||||||
import * as proxy from 'proxy'
|
import * as proxy from 'proxy'
|
||||||
import * as url from 'url'
|
|
||||||
|
|
||||||
let _proxyConnects: string[]
|
let _proxyConnects: string[]
|
||||||
let _proxyServer: http.Server
|
let _proxyServer: http.Server
|
||||||
@ -39,107 +38,107 @@ describe('proxy', () => {
|
|||||||
})
|
})
|
||||||
|
|
||||||
it('getProxyUrl does not return proxyUrl if variables not set', () => {
|
it('getProxyUrl does not return proxyUrl if variables not set', () => {
|
||||||
let proxyUrl = pm.getProxyUrl(url.parse('https://github.com'))
|
let proxyUrl = pm.getProxyUrl(new URL('https://github.com'))
|
||||||
expect(proxyUrl).toBeUndefined()
|
expect(proxyUrl).toBeUndefined()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('getProxyUrl returns proxyUrl if https_proxy set for https url', () => {
|
it('getProxyUrl returns proxyUrl if https_proxy set for https url', () => {
|
||||||
process.env['https_proxy'] = 'https://myproxysvr'
|
process.env['https_proxy'] = 'https://myproxysvr'
|
||||||
let proxyUrl = pm.getProxyUrl(url.parse('https://github.com'))
|
let proxyUrl = pm.getProxyUrl(new URL('https://github.com'))
|
||||||
expect(proxyUrl).toBeDefined()
|
expect(proxyUrl).toBeDefined()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('getProxyUrl does not return proxyUrl if http_proxy set for https url', () => {
|
it('getProxyUrl does not return proxyUrl if http_proxy set for https url', () => {
|
||||||
process.env['http_proxy'] = 'https://myproxysvr'
|
process.env['http_proxy'] = 'https://myproxysvr'
|
||||||
let proxyUrl = pm.getProxyUrl(url.parse('https://github.com'))
|
let proxyUrl = pm.getProxyUrl(new URL('https://github.com'))
|
||||||
expect(proxyUrl).toBeUndefined()
|
expect(proxyUrl).toBeUndefined()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('getProxyUrl returns proxyUrl if http_proxy set for http url', () => {
|
it('getProxyUrl returns proxyUrl if http_proxy set for http url', () => {
|
||||||
process.env['http_proxy'] = 'http://myproxysvr'
|
process.env['http_proxy'] = 'http://myproxysvr'
|
||||||
let proxyUrl = pm.getProxyUrl(url.parse('http://github.com'))
|
let proxyUrl = pm.getProxyUrl(new URL('http://github.com'))
|
||||||
expect(proxyUrl).toBeDefined()
|
expect(proxyUrl).toBeDefined()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('getProxyUrl does not return proxyUrl if https_proxy set and in no_proxy list', () => {
|
it('getProxyUrl does not return proxyUrl if https_proxy set and in no_proxy list', () => {
|
||||||
process.env['https_proxy'] = 'https://myproxysvr'
|
process.env['https_proxy'] = 'https://myproxysvr'
|
||||||
process.env['no_proxy'] = 'otherserver,myserver,anotherserver:8080'
|
process.env['no_proxy'] = 'otherserver,myserver,anotherserver:8080'
|
||||||
let proxyUrl = pm.getProxyUrl(url.parse('https://myserver'))
|
let proxyUrl = pm.getProxyUrl(new URL('https://myserver'))
|
||||||
expect(proxyUrl).toBeUndefined()
|
expect(proxyUrl).toBeUndefined()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('getProxyUrl returns proxyUrl if https_proxy set and not in no_proxy list', () => {
|
it('getProxyUrl returns proxyUrl if https_proxy set and not in no_proxy list', () => {
|
||||||
process.env['https_proxy'] = 'https://myproxysvr'
|
process.env['https_proxy'] = 'https://myproxysvr'
|
||||||
process.env['no_proxy'] = 'otherserver,myserver,anotherserver:8080'
|
process.env['no_proxy'] = 'otherserver,myserver,anotherserver:8080'
|
||||||
let proxyUrl = pm.getProxyUrl(url.parse('https://github.com'))
|
let proxyUrl = pm.getProxyUrl(new URL('https://github.com'))
|
||||||
expect(proxyUrl).toBeDefined()
|
expect(proxyUrl).toBeDefined()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('getProxyUrl does not return proxyUrl if http_proxy set and in no_proxy list', () => {
|
it('getProxyUrl does not return proxyUrl if http_proxy set and in no_proxy list', () => {
|
||||||
process.env['http_proxy'] = 'http://myproxysvr'
|
process.env['http_proxy'] = 'http://myproxysvr'
|
||||||
process.env['no_proxy'] = 'otherserver,myserver,anotherserver:8080'
|
process.env['no_proxy'] = 'otherserver,myserver,anotherserver:8080'
|
||||||
let proxyUrl = pm.getProxyUrl(url.parse('http://myserver'))
|
let proxyUrl = pm.getProxyUrl(new URL('http://myserver'))
|
||||||
expect(proxyUrl).toBeUndefined()
|
expect(proxyUrl).toBeUndefined()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('getProxyUrl returns proxyUrl if http_proxy set and not in no_proxy list', () => {
|
it('getProxyUrl returns proxyUrl if http_proxy set and not in no_proxy list', () => {
|
||||||
process.env['http_proxy'] = 'http://myproxysvr'
|
process.env['http_proxy'] = 'http://myproxysvr'
|
||||||
process.env['no_proxy'] = 'otherserver,myserver,anotherserver:8080'
|
process.env['no_proxy'] = 'otherserver,myserver,anotherserver:8080'
|
||||||
let proxyUrl = pm.getProxyUrl(url.parse('http://github.com'))
|
let proxyUrl = pm.getProxyUrl(new URL('http://github.com'))
|
||||||
expect(proxyUrl).toBeDefined()
|
expect(proxyUrl).toBeDefined()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('checkBypass returns true if host as no_proxy list', () => {
|
it('checkBypass returns true if host as no_proxy list', () => {
|
||||||
process.env['no_proxy'] = 'myserver'
|
process.env['no_proxy'] = 'myserver'
|
||||||
let bypass = pm.checkBypass(url.parse('https://myserver'))
|
let bypass = pm.checkBypass(new URL('https://myserver'))
|
||||||
expect(bypass).toBeTruthy()
|
expect(bypass).toBeTruthy()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('checkBypass returns true if host in no_proxy list', () => {
|
it('checkBypass returns true if host in no_proxy list', () => {
|
||||||
process.env['no_proxy'] = 'otherserver,myserver,anotherserver:8080'
|
process.env['no_proxy'] = 'otherserver,myserver,anotherserver:8080'
|
||||||
let bypass = pm.checkBypass(url.parse('https://myserver'))
|
let bypass = pm.checkBypass(new URL('https://myserver'))
|
||||||
expect(bypass).toBeTruthy()
|
expect(bypass).toBeTruthy()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('checkBypass returns true if host in no_proxy list with spaces', () => {
|
it('checkBypass returns true if host in no_proxy list with spaces', () => {
|
||||||
process.env['no_proxy'] = 'otherserver, myserver ,anotherserver:8080'
|
process.env['no_proxy'] = 'otherserver, myserver ,anotherserver:8080'
|
||||||
let bypass = pm.checkBypass(url.parse('https://myserver'))
|
let bypass = pm.checkBypass(new URL('https://myserver'))
|
||||||
expect(bypass).toBeTruthy()
|
expect(bypass).toBeTruthy()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('checkBypass returns true if host in no_proxy list with port', () => {
|
it('checkBypass returns true if host in no_proxy list with port', () => {
|
||||||
process.env['no_proxy'] = 'otherserver, myserver:8080 ,anotherserver'
|
process.env['no_proxy'] = 'otherserver, myserver:8080 ,anotherserver'
|
||||||
let bypass = pm.checkBypass(url.parse('https://myserver:8080'))
|
let bypass = pm.checkBypass(new URL('https://myserver:8080'))
|
||||||
expect(bypass).toBeTruthy()
|
expect(bypass).toBeTruthy()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('checkBypass returns true if host with port in no_proxy list without port', () => {
|
it('checkBypass returns true if host with port in no_proxy list without port', () => {
|
||||||
process.env['no_proxy'] = 'otherserver, myserver ,anotherserver'
|
process.env['no_proxy'] = 'otherserver, myserver ,anotherserver'
|
||||||
let bypass = pm.checkBypass(url.parse('https://myserver:8080'))
|
let bypass = pm.checkBypass(new URL('https://myserver:8080'))
|
||||||
expect(bypass).toBeTruthy()
|
expect(bypass).toBeTruthy()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('checkBypass returns true if host in no_proxy list with default https port', () => {
|
it('checkBypass returns true if host in no_proxy list with default https port', () => {
|
||||||
process.env['no_proxy'] = 'otherserver, myserver:443 ,anotherserver'
|
process.env['no_proxy'] = 'otherserver, myserver:443 ,anotherserver'
|
||||||
let bypass = pm.checkBypass(url.parse('https://myserver'))
|
let bypass = pm.checkBypass(new URL('https://myserver'))
|
||||||
expect(bypass).toBeTruthy()
|
expect(bypass).toBeTruthy()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('checkBypass returns true if host in no_proxy list with default http port', () => {
|
it('checkBypass returns true if host in no_proxy list with default http port', () => {
|
||||||
process.env['no_proxy'] = 'otherserver, myserver:80 ,anotherserver'
|
process.env['no_proxy'] = 'otherserver, myserver:80 ,anotherserver'
|
||||||
let bypass = pm.checkBypass(url.parse('http://myserver'))
|
let bypass = pm.checkBypass(new URL('http://myserver'))
|
||||||
expect(bypass).toBeTruthy()
|
expect(bypass).toBeTruthy()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('checkBypass returns false if host not in no_proxy list', () => {
|
it('checkBypass returns false if host not in no_proxy list', () => {
|
||||||
process.env['no_proxy'] = 'otherserver, myserver ,anotherserver:8080'
|
process.env['no_proxy'] = 'otherserver, myserver ,anotherserver:8080'
|
||||||
let bypass = pm.checkBypass(url.parse('https://github.com'))
|
let bypass = pm.checkBypass(new URL('https://github.com'))
|
||||||
expect(bypass).toBeFalsy()
|
expect(bypass).toBeFalsy()
|
||||||
})
|
})
|
||||||
|
|
||||||
it('checkBypass returns false if empty no_proxy', () => {
|
it('checkBypass returns false if empty no_proxy', () => {
|
||||||
process.env['no_proxy'] = ''
|
process.env['no_proxy'] = ''
|
||||||
let bypass = pm.checkBypass(url.parse('https://github.com'))
|
let bypass = pm.checkBypass(new URL('https://github.com'))
|
||||||
expect(bypass).toBeFalsy()
|
expect(bypass).toBeFalsy()
|
||||||
})
|
})
|
||||||
|
|
||||||
|
19
index.ts
19
index.ts
@ -1,4 +1,3 @@
|
|||||||
import url = require('url')
|
|
||||||
import http = require('http')
|
import http = require('http')
|
||||||
import https = require('https')
|
import https = require('https')
|
||||||
import ifm = require('./interfaces')
|
import ifm = require('./interfaces')
|
||||||
@ -50,7 +49,7 @@ export enum MediaTypes {
|
|||||||
* @param serverUrl The server URL where the request will be sent. For example, https://api.github.com
|
* @param serverUrl The server URL where the request will be sent. For example, https://api.github.com
|
||||||
*/
|
*/
|
||||||
export function getProxyUrl(serverUrl: string): string {
|
export function getProxyUrl(serverUrl: string): string {
|
||||||
let proxyUrl = pm.getProxyUrl(url.parse(serverUrl))
|
let proxyUrl = pm.getProxyUrl(new URL(serverUrl))
|
||||||
return proxyUrl ? proxyUrl.href : ''
|
return proxyUrl ? proxyUrl.href : ''
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -92,7 +91,7 @@ export class HttpClientResponse implements ifm.IHttpClientResponse {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function isHttps(requestUrl: string) {
|
export function isHttps(requestUrl: string) {
|
||||||
let parsedUrl: url.Url = url.parse(requestUrl)
|
let parsedUrl: URL = new URL(requestUrl)
|
||||||
return parsedUrl.protocol === 'https:'
|
return parsedUrl.protocol === 'https:'
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -322,7 +321,7 @@ export class HttpClient {
|
|||||||
throw new Error('Client has already been disposed.')
|
throw new Error('Client has already been disposed.')
|
||||||
}
|
}
|
||||||
|
|
||||||
let parsedUrl = url.parse(requestUrl)
|
let parsedUrl = new URL(requestUrl)
|
||||||
let info: ifm.IRequestInfo = this._prepareRequest(verb, parsedUrl, headers)
|
let info: ifm.IRequestInfo = this._prepareRequest(verb, parsedUrl, headers)
|
||||||
|
|
||||||
// Only perform retries on reads since writes may not be idempotent.
|
// Only perform retries on reads since writes may not be idempotent.
|
||||||
@ -371,7 +370,7 @@ export class HttpClient {
|
|||||||
// if there's no location to redirect to, we won't
|
// if there's no location to redirect to, we won't
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
let parsedRedirectUrl = url.parse(redirectUrl)
|
let parsedRedirectUrl = new URL(redirectUrl)
|
||||||
if (
|
if (
|
||||||
parsedUrl.protocol == 'https:' &&
|
parsedUrl.protocol == 'https:' &&
|
||||||
parsedUrl.protocol != parsedRedirectUrl.protocol &&
|
parsedUrl.protocol != parsedRedirectUrl.protocol &&
|
||||||
@ -516,13 +515,13 @@ export class HttpClient {
|
|||||||
* @param serverUrl The server URL where the request will be sent. For example, https://api.github.com
|
* @param serverUrl The server URL where the request will be sent. For example, https://api.github.com
|
||||||
*/
|
*/
|
||||||
public getAgent(serverUrl: string): http.Agent {
|
public getAgent(serverUrl: string): http.Agent {
|
||||||
let parsedUrl = url.parse(serverUrl)
|
let parsedUrl = new URL(serverUrl)
|
||||||
return this._getAgent(parsedUrl)
|
return this._getAgent(parsedUrl)
|
||||||
}
|
}
|
||||||
|
|
||||||
private _prepareRequest(
|
private _prepareRequest(
|
||||||
method: string,
|
method: string,
|
||||||
requestUrl: url.Url,
|
requestUrl: URL,
|
||||||
headers: ifm.IHeaders
|
headers: ifm.IHeaders
|
||||||
): ifm.IRequestInfo {
|
): ifm.IRequestInfo {
|
||||||
const info: ifm.IRequestInfo = <ifm.IRequestInfo>{}
|
const info: ifm.IRequestInfo = <ifm.IRequestInfo>{}
|
||||||
@ -587,9 +586,9 @@ export class HttpClient {
|
|||||||
return additionalHeaders[header] || clientHeader || _default
|
return additionalHeaders[header] || clientHeader || _default
|
||||||
}
|
}
|
||||||
|
|
||||||
private _getAgent(parsedUrl: url.Url): http.Agent {
|
private _getAgent(parsedUrl: URL): http.Agent {
|
||||||
let agent
|
let agent
|
||||||
let proxyUrl: url.Url = pm.getProxyUrl(parsedUrl)
|
let proxyUrl: URL = pm.getProxyUrl(parsedUrl)
|
||||||
let useProxy = proxyUrl && proxyUrl.hostname
|
let useProxy = proxyUrl && proxyUrl.hostname
|
||||||
|
|
||||||
if (this._keepAlive && useProxy) {
|
if (this._keepAlive && useProxy) {
|
||||||
@ -621,7 +620,7 @@ export class HttpClient {
|
|||||||
maxSockets: maxSockets,
|
maxSockets: maxSockets,
|
||||||
keepAlive: this._keepAlive,
|
keepAlive: this._keepAlive,
|
||||||
proxy: {
|
proxy: {
|
||||||
proxyAuth: proxyUrl.auth,
|
proxyAuth: `${proxyUrl.username}:${proxyUrl.password}`,
|
||||||
host: proxyUrl.hostname,
|
host: proxyUrl.hostname,
|
||||||
port: proxyUrl.port
|
port: proxyUrl.port
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import http = require('http')
|
import http = require('http')
|
||||||
import url = require('url')
|
|
||||||
|
|
||||||
export interface IHeaders {
|
export interface IHeaders {
|
||||||
[key: string]: any
|
[key: string]: any
|
||||||
@ -73,7 +72,7 @@ export interface IHttpClientResponse {
|
|||||||
|
|
||||||
export interface IRequestInfo {
|
export interface IRequestInfo {
|
||||||
options: http.RequestOptions
|
options: http.RequestOptions
|
||||||
parsedUrl: url.Url
|
parsedUrl: URL
|
||||||
httpModule: any
|
httpModule: any
|
||||||
}
|
}
|
||||||
|
|
||||||
|
10
proxy.ts
10
proxy.ts
@ -1,9 +1,7 @@
|
|||||||
import * as url from 'url'
|
export function getProxyUrl(reqUrl: URL): URL | undefined {
|
||||||
|
|
||||||
export function getProxyUrl(reqUrl: url.Url): url.Url | undefined {
|
|
||||||
let usingSsl = reqUrl.protocol === 'https:'
|
let usingSsl = reqUrl.protocol === 'https:'
|
||||||
|
|
||||||
let proxyUrl: url.Url
|
let proxyUrl: URL
|
||||||
if (checkBypass(reqUrl)) {
|
if (checkBypass(reqUrl)) {
|
||||||
return proxyUrl
|
return proxyUrl
|
||||||
}
|
}
|
||||||
@ -16,13 +14,13 @@ export function getProxyUrl(reqUrl: url.Url): url.Url | undefined {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (proxyVar) {
|
if (proxyVar) {
|
||||||
proxyUrl = url.parse(proxyVar)
|
proxyUrl = new URL(proxyVar)
|
||||||
}
|
}
|
||||||
|
|
||||||
return proxyUrl
|
return proxyUrl
|
||||||
}
|
}
|
||||||
|
|
||||||
export function checkBypass(reqUrl: url.Url): boolean {
|
export function checkBypass(reqUrl: URL): boolean {
|
||||||
if (!reqUrl.hostname) {
|
if (!reqUrl.hostname) {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user