Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
6aae9a9e
L
libvirt
项目概览
openeuler
/
libvirt
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
L
libvirt
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
6aae9a9e
编写于
1月 14, 2008
作者:
D
Daniel P. Berrange
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Re-factor auth code to make clearer (Jim Meyering)
上级
b2083ea9
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
25 addition
and
24 deletion
+25
-24
ChangeLog
ChangeLog
+5
-0
src/remote_internal.c
src/remote_internal.c
+20
-24
未找到文件。
ChangeLog
浏览文件 @
6aae9a9e
Sun Jan 13 22:59:53 EST 2008 Daniel P. Berrange <berrange@redhat.com>
* src/remote_internal.c: Refactor code to make error patches
clearer (Jim Meyering).
Sun Jan 13 22:53:53 EST 2008 Daniel P. Berrange <berrange@redhat.com>
* src/remote_internal.c: Fix crash when server has auth type
...
...
src/remote_internal.c
浏览文件 @
6aae9a9e
...
...
@@ -3152,6 +3152,7 @@ remoteAuthSASL (virConnectPtr conn, struct private_data *priv, int in_open,
/* Need to gather some credentials from the client */
if
(
err
==
SASL_INTERACT
)
{
const
char
*
msg
;
if
(
cred
)
{
remoteAuthFreeCredentials
(
cred
,
ncred
);
cred
=
NULL
;
...
...
@@ -3166,20 +3167,18 @@ remoteAuthSASL (virConnectPtr conn, struct private_data *priv, int in_open,
}
/* Run the authentication callback */
if
(
auth
&&
auth
->
cb
)
{
if
((
*
(
auth
->
cb
))(
cred
,
ncred
,
auth
->
cbdata
)
<
0
)
{
__virRaiseError
(
in_open
?
NULL
:
conn
,
NULL
,
NULL
,
VIR_FROM_REMOTE
,
VIR_ERR_AUTH_FAILED
,
VIR_ERR_ERROR
,
NULL
,
NULL
,
NULL
,
0
,
0
,
"Failed to collect auth credentials"
);
goto
cleanup
;
if
((
*
(
auth
->
cb
))(
cred
,
ncred
,
auth
->
cbdata
)
>=
0
)
{
remoteAuthFillInteract
(
cred
,
interact
);
goto
restart
;
}
remoteAuthFillInteract
(
cred
,
interact
);
goto
restart
;
msg
=
"Failed to collect auth credentials"
;
}
else
{
__virRaiseError
(
in_open
?
NULL
:
conn
,
NULL
,
NULL
,
VIR_FROM_REMOTE
,
VIR_ERR_AUTH_FAILED
,
VIR_ERR_ERROR
,
NULL
,
NULL
,
NULL
,
0
,
0
,
"No authentication callback available"
);
goto
cleanup
;
msg
=
"No authentication callback available"
;
}
__virRaiseError
(
in_open
?
NULL
:
conn
,
NULL
,
NULL
,
VIR_FROM_REMOTE
,
VIR_ERR_AUTH_FAILED
,
VIR_ERR_ERROR
,
NULL
,
NULL
,
NULL
,
0
,
0
,
msg
);
goto
cleanup
;
}
free
(
iret
.
mechlist
);
...
...
@@ -3231,6 +3230,7 @@ remoteAuthSASL (virConnectPtr conn, struct private_data *priv, int in_open,
}
/* Need to gather some credentials from the client */
if
(
err
==
SASL_INTERACT
)
{
const
char
*
msg
;
if
(
cred
)
{
remoteAuthFreeCredentials
(
cred
,
ncred
);
cred
=
NULL
;
...
...
@@ -3240,25 +3240,21 @@ remoteAuthSASL (virConnectPtr conn, struct private_data *priv, int in_open,
VIR_ERR_AUTH_FAILED
,
VIR_ERR_ERROR
,
NULL
,
NULL
,
NULL
,
0
,
0
,
"Failed to make auth credentials"
);
goto
cleanup
;
return
-
1
;
}
/* Run the authentication callback */
if
(
auth
&&
auth
->
cb
)
{
if
((
*
(
auth
->
cb
))(
cred
,
ncred
,
auth
->
cbdata
)
<
0
)
{
__virRaiseError
(
in_open
?
NULL
:
conn
,
NULL
,
NULL
,
VIR_FROM_REMOTE
,
VIR_ERR_AUTH_FAILED
,
VIR_ERR_ERROR
,
NULL
,
NULL
,
NULL
,
0
,
0
,
"Failed to collect auth credentials"
);
goto
cleanup
;
return
-
1
;
if
((
*
(
auth
->
cb
))(
cred
,
ncred
,
auth
->
cbdata
)
>=
0
)
{
remoteAuthFillInteract
(
cred
,
interact
);
goto
restep
;
}
remoteAuthFillInteract
(
cred
,
interact
);
goto
restep
;
msg
=
"Failed to collect auth credentials"
;
}
else
{
__virRaiseError
(
in_open
?
NULL
:
conn
,
NULL
,
NULL
,
VIR_FROM_REMOTE
,
VIR_ERR_AUTH_FAILED
,
VIR_ERR_ERROR
,
NULL
,
NULL
,
NULL
,
0
,
0
,
"No authentication callback available"
);
goto
cleanup
;
msg
=
"No authentication callback available"
;
}
__virRaiseError
(
in_open
?
NULL
:
conn
,
NULL
,
NULL
,
VIR_FROM_REMOTE
,
VIR_ERR_AUTH_FAILED
,
VIR_ERR_ERROR
,
NULL
,
NULL
,
NULL
,
0
,
0
,
msg
);
goto
cleanup
;
}
if
(
serverin
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录