Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
92894781
V
vscode
项目概览
掘金者说
/
vscode
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vscode
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
92894781
编写于
3月 05, 2019
作者:
C
Christof Marti
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Interpret NO_PROXY (#68260)
上级
3b451a68
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
42 addition
and
3 deletion
+42
-3
src/vs/workbench/services/extensions/node/proxyResolver.ts
src/vs/workbench/services/extensions/node/proxyResolver.ts
+42
-3
未找到文件。
src/vs/workbench/services/extensions/node/proxyResolver.ts
浏览文件 @
92894781
...
...
@@ -8,6 +8,7 @@ import * as https from 'https';
import
*
as
nodeurl
from
'
url
'
;
import
{
assign
}
from
'
vs/base/common/objects
'
;
import
{
endsWith
}
from
'
vs/base/common/strings
'
;
import
{
IExtHostWorkspaceProvider
}
from
'
vs/workbench/api/node/extHostWorkspace
'
;
import
{
ExtHostConfigProvider
}
from
'
vs/workbench/api/node/extHostConfiguration
'
;
import
{
ProxyAgent
}
from
'
vscode-proxy-agent
'
;
...
...
@@ -44,15 +45,18 @@ function setupProxyResolution(
extHostLogService
:
ExtHostLogService
,
mainThreadTelemetry
:
MainThreadTelemetryShape
)
{
const
env
=
process
.
env
;
let
settingsProxy
=
proxyFromConfigURL
(
configProvider
.
getConfiguration
(
'
http
'
)
.
get
<
string
>
(
'
proxy
'
));
configProvider
.
onDidChangeConfiguration
(
e
=>
{
settingsProxy
=
proxyFromConfigURL
(
configProvider
.
getConfiguration
(
'
http
'
)
.
get
<
string
>
(
'
proxy
'
));
});
const
env
=
process
.
env
;
let
envProxy
=
proxyFromConfigURL
(
env
.
https_proxy
||
env
.
HTTPS_PROXY
||
env
.
http_proxy
||
env
.
HTTP_PROXY
);
// Not standardized.
let
envNoProxy
=
noProxyFromEnv
(
env
.
no_proxy
||
env
.
NO_PROXY
);
// Not standardized.
let
cacheRolls
=
0
;
let
oldCache
=
new
Map
<
string
,
string
>
();
let
cache
=
new
Map
<
string
,
string
>
();
...
...
@@ -90,6 +94,7 @@ function setupProxyResolution(
let
envCount
=
0
;
let
settingsCount
=
0
;
let
localhostCount
=
0
;
let
envNoProxyCount
=
0
;
let
results
:
ConnectionResult
[]
=
[];
function
logEvent
()
{
timeout
=
undefined
;
...
...
@@ -104,11 +109,12 @@ function setupProxyResolution(
"envCount": { "classification": "SystemMetaData", "purpose": "PerformanceAndHealth", "isMeasurement": true },
"settingsCount": { "classification": "SystemMetaData", "purpose": "PerformanceAndHealth", "isMeasurement": true },
"localhostCount": { "classification": "SystemMetaData", "purpose": "PerformanceAndHealth", "isMeasurement": true },
"envNoProxyCount": { "classification": "SystemMetaData", "purpose": "PerformanceAndHealth", "isMeasurement": true },
"results": { "classification": "SystemMetaData", "purpose": "PerformanceAndHealth" }
}
*/
mainThreadTelemetry
.
$publicLog
(
'
resolveProxy
'
,
{
count
,
duration
,
errorCount
,
cacheCount
,
cacheSize
:
cache
.
size
,
cacheRolls
,
envCount
,
settingsCount
,
localhostCount
,
results
});
count
=
duration
=
errorCount
=
cacheCount
=
envCount
=
settingsCount
=
localhostCount
=
0
;
mainThreadTelemetry
.
$publicLog
(
'
resolveProxy
'
,
{
count
,
duration
,
errorCount
,
cacheCount
,
cacheSize
:
cache
.
size
,
cacheRolls
,
envCount
,
settingsCount
,
localhostCount
,
envNoProxyCount
,
results
});
count
=
duration
=
errorCount
=
cacheCount
=
envCount
=
settingsCount
=
localhostCount
=
envNoProxyCount
=
0
;
results
=
[];
}
...
...
@@ -127,6 +133,13 @@ function setupProxyResolution(
return
;
}
if
(
envNoProxy
(
hostname
,
String
(
parsedUrl
.
port
||
(
<
any
>
opts
.
agent
).
defaultPort
)))
{
envNoProxyCount
++
;
callback
(
'
DIRECT
'
);
extHostLogService
.
trace
(
'
ProxyResolver#resolveProxy envNoProxy
'
,
url
,
'
DIRECT
'
);
return
;
}
if
(
settingsProxy
)
{
settingsCount
++
;
callback
(
settingsProxy
);
...
...
@@ -214,6 +227,32 @@ function proxyFromConfigURL(configURL: string | undefined) {
return
undefined
;
}
function
noProxyFromEnv
(
envValue
?:
string
)
{
const
value
=
(
envValue
||
''
)
.
trim
()
.
toLowerCase
();
if
(
value
===
'
*
'
)
{
return
()
=>
true
;
}
const
filters
=
value
.
split
(
'
,
'
)
.
map
(
s
=>
s
.
trim
().
split
(
'
:
'
,
2
))
.
map
(([
name
,
port
])
=>
({
name
,
port
}))
.
filter
(
filter
=>
!!
filter
.
name
)
.
map
(({
name
,
port
})
=>
{
const
domain
=
name
[
0
]
===
'
.
'
?
name
:
`.
${
name
}
`
;
return
{
domain
,
port
};
});
if
(
!
filters
.
length
)
{
return
()
=>
false
;
}
return
(
hostname
:
string
,
port
:
string
)
=>
filters
.
some
(({
domain
,
port
:
filterPort
})
=>
{
return
endsWith
(
`.
${
hostname
.
toLowerCase
()}
`
,
domain
)
&&
(
!
filterPort
||
port
===
filterPort
);
});
}
function
createPatchedModules
(
configProvider
:
ExtHostConfigProvider
,
resolveProxy
:
ReturnType
<
typeof
setupProxyResolution
>
)
{
const
setting
=
{
config
:
configProvider
.
getConfiguration
(
'
http
'
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录