Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
掘金者说
vscode
提交
a2ae791b
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,发现更多精彩内容 >>
提交
a2ae791b
编写于
1月 22, 2020
作者:
R
Rachel Macfarlane
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add logging to account extension
上级
c16a8d0e
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
66 addition
and
0 deletion
+66
-0
extensions/vscode-account/src/AADHelper.ts
extensions/vscode-account/src/AADHelper.ts
+11
-0
extensions/vscode-account/src/logger.ts
extensions/vscode-account/src/logger.ts
+55
-0
未找到文件。
extensions/vscode-account/src/AADHelper.ts
浏览文件 @
a2ae791b
...
...
@@ -10,6 +10,7 @@ import * as querystring from 'querystring';
import
{
keychain
}
from
'
./keychain
'
;
import
{
toBase64UrlEncoding
}
from
'
./utils
'
;
import
{
createServer
,
startServer
}
from
'
./authServer
'
;
import
Logger
from
'
./logger
'
;
const
redirectUrl
=
'
https://vscode-redirect.azurewebsites.net/
'
;
const
loginEndpointUrl
=
'
https://login.microsoftonline.com/
'
;
...
...
@@ -82,6 +83,7 @@ export class AzureActiveDirectoryService {
}
public
async
login
():
Promise
<
void
>
{
Logger
.
info
(
'
Logging in...
'
);
const
nonce
=
crypto
.
randomBytes
(
16
).
toString
(
'
base64
'
);
const
{
server
,
redirectPromise
,
codePromise
}
=
createServer
(
nonce
);
...
...
@@ -120,9 +122,11 @@ export class AzureActiveDirectoryService {
}
token
=
await
this
.
exchangeCodeForToken
(
codeRes
.
code
,
codeVerifier
);
this
.
setToken
(
token
);
Logger
.
info
(
'
Login successful
'
);
res
.
writeHead
(
302
,
{
Location
:
'
/
'
});
res
.
end
();
}
catch
(
err
)
{
Logger
.
error
(
err
.
message
);
res
.
writeHead
(
302
,
{
Location
:
`/?error=
${
encodeURIComponent
(
err
&&
err
.
message
||
'
Unknown error
'
)}
`
});
res
.
end
();
}
...
...
@@ -155,6 +159,7 @@ export class AzureActiveDirectoryService {
private
async
exchangeCodeForToken
(
code
:
string
,
codeVerifier
:
string
):
Promise
<
IToken
>
{
return
new
Promise
((
resolve
:
(
value
:
IToken
)
=>
void
,
reject
)
=>
{
Logger
.
info
(
'
Exchanging login code for token
'
);
try
{
const
postData
=
querystring
.
stringify
({
grant_type
:
'
authorization_code
'
,
...
...
@@ -202,6 +207,7 @@ export class AzureActiveDirectoryService {
});
}
catch
(
e
)
{
Logger
.
error
(
e
.
message
);
reject
(
e
);
}
});
...
...
@@ -209,6 +215,7 @@ export class AzureActiveDirectoryService {
private
async
refreshToken
(
refreshToken
:
string
):
Promise
<
IToken
>
{
return
new
Promise
((
resolve
:
(
value
:
IToken
)
=>
void
,
reject
)
=>
{
Logger
.
info
(
'
Refreshing token...
'
);
const
postData
=
querystring
.
stringify
({
refresh_token
:
refreshToken
,
client_id
:
clientId
,
...
...
@@ -238,9 +245,11 @@ export class AzureActiveDirectoryService {
refreshToken
:
json
.
refresh_token
};
this
.
setToken
(
token
);
Logger
.
info
(
'
Token refresh success
'
);
resolve
(
token
);
}
else
{
await
this
.
logout
();
Logger
.
error
(
'
Refreshing token failed
'
);
reject
(
new
Error
(
'
Refreshing token failed.
'
));
}
});
...
...
@@ -250,12 +259,14 @@ export class AzureActiveDirectoryService {
post
.
end
();
post
.
on
(
'
error
'
,
err
=>
{
Logger
.
error
(
err
.
message
);
reject
(
err
);
});
});
}
public
async
logout
()
{
Logger
.
info
(
'
Logging out
'
);
delete
this
.
_token
;
await
keychain
.
deleteToken
();
if
(
this
.
_refreshTimeout
)
{
...
...
extensions/vscode-account/src/logger.ts
0 → 100644
浏览文件 @
a2ae791b
/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
import
*
as
vscode
from
'
vscode
'
;
type
LogLevel
=
'
Trace
'
|
'
Info
'
|
'
Error
'
;
class
Log
{
private
output
:
vscode
.
OutputChannel
;
constructor
()
{
this
.
output
=
vscode
.
window
.
createOutputChannel
(
'
Account
'
);
}
private
data2String
(
data
:
any
):
string
{
if
(
data
instanceof
Error
)
{
return
data
.
stack
||
data
.
message
;
}
if
(
data
.
success
===
false
&&
data
.
message
)
{
return
data
.
message
;
}
return
data
.
toString
();
}
public
info
(
message
:
string
,
data
?:
any
):
void
{
this
.
logLevel
(
'
Info
'
,
message
,
data
);
}
public
error
(
message
:
string
,
data
?:
any
):
void
{
this
.
logLevel
(
'
Error
'
,
message
,
data
);
}
public
logLevel
(
level
:
LogLevel
,
message
:
string
,
data
?:
any
):
void
{
this
.
output
.
appendLine
(
`[
${
level
}
-
${
this
.
now
()}
]
${
message
}
`
);
if
(
data
)
{
this
.
output
.
appendLine
(
this
.
data2String
(
data
));
}
}
private
now
():
string
{
const
now
=
new
Date
();
return
padLeft
(
now
.
getUTCHours
()
+
''
,
2
,
'
0
'
)
+
'
:
'
+
padLeft
(
now
.
getMinutes
()
+
''
,
2
,
'
0
'
)
+
'
:
'
+
padLeft
(
now
.
getUTCSeconds
()
+
''
,
2
,
'
0
'
)
+
'
.
'
+
now
.
getMilliseconds
();
}
}
function
padLeft
(
s
:
string
,
n
:
number
,
pad
=
'
'
)
{
return
pad
.
repeat
(
Math
.
max
(
0
,
n
-
s
.
length
))
+
s
;
}
const
Logger
=
new
Log
();
export
default
Logger
;
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录