Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
水淹萌龙
kubesphere
提交
86a027e4
K
kubesphere
项目概览
水淹萌龙
/
kubesphere
与 Fork 源项目一致
Fork自
KubeSphere / kubesphere
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kubesphere
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
未验证
提交
86a027e4
编写于
7月 02, 2020
作者:
K
KubeSphere CI Bot
提交者:
GitHub
7月 02, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #2288 from wansir/clusters
fix: federated workspace cluster selector
上级
031d6b3b
8515e01f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
32 addition
and
11 deletion
+32
-11
pkg/models/tenant/tenant.go
pkg/models/tenant/tenant.go
+32
-11
未找到文件。
pkg/models/tenant/tenant.go
浏览文件 @
86a027e4
...
...
@@ -23,6 +23,7 @@ import (
corev1
"k8s.io/api/core/v1"
"k8s.io/apimachinery/pkg/api/errors"
metav1
"k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/labels"
"k8s.io/apimachinery/pkg/runtime"
"k8s.io/apimachinery/pkg/types"
"k8s.io/apiserver/pkg/authentication/user"
...
...
@@ -347,20 +348,40 @@ func (t *tenantOperator) ListWorkspaceClusters(workspaceName string) (*api.ListR
klog
.
Error
(
err
)
return
nil
,
err
}
clusters
:=
make
([]
interface
{},
0
)
for
_
,
cluster
:=
range
workspace
.
Spec
.
Placement
.
Clusters
{
obj
,
err
:=
t
.
resourceGetter
.
Get
(
clusterv1alpha1
.
ResourcesPluralCluster
,
""
,
cluster
.
Name
)
if
err
!=
nil
{
klog
.
Error
(
err
)
if
errors
.
IsNotFound
(
err
)
{
continue
// In this case, spec.placement.clusterSelector will be ignored, since spec.placement.clusters is provided.
if
workspace
.
Spec
.
Placement
.
Clusters
!=
nil
{
clusters
:=
make
([]
interface
{},
0
)
for
_
,
cluster
:=
range
workspace
.
Spec
.
Placement
.
Clusters
{
obj
,
err
:=
t
.
resourceGetter
.
Get
(
clusterv1alpha1
.
ResourcesPluralCluster
,
""
,
cluster
.
Name
)
if
err
!=
nil
{
klog
.
Error
(
err
)
if
errors
.
IsNotFound
(
err
)
{
continue
}
return
nil
,
err
}
return
nil
,
err
clusters
=
append
(
clusters
,
obj
)
}
return
&
api
.
ListResult
{
Items
:
clusters
,
TotalItems
:
len
(
clusters
)},
nil
}
if
workspace
.
Spec
.
Placement
.
ClusterSelector
!=
nil
{
// In this case, the resource will be propagated to all member clusters.
if
workspace
.
Spec
.
Placement
.
ClusterSelector
.
MatchLabels
==
nil
{
return
t
.
resourceGetter
.
List
(
clusterv1alpha1
.
ResourcesPluralCluster
,
""
,
query
.
New
())
}
else
{
// In this case, the resource will only be propagated to member clusters that are labeled with foo: bar.
return
t
.
resourceGetter
.
List
(
clusterv1alpha1
.
ResourcesPluralCluster
,
""
,
&
query
.
Query
{
Pagination
:
query
.
NoPagination
,
Ascending
:
false
,
LabelSelector
:
labels
.
SelectorFromSet
(
workspace
.
Spec
.
Placement
.
ClusterSelector
.
MatchLabels
)
.
String
(),
})
}
cluster
:=
obj
.
(
*
clusterv1alpha1
.
Cluster
)
clusters
=
append
(
clusters
,
cluster
)
}
return
&
api
.
ListResult
{
Items
:
clusters
,
TotalItems
:
len
(
clusters
)},
nil
// In this case, you can either set spec: {} as above or remove spec field from your placement policy. The resource will not be propagated to member clusters.
return
&
api
.
ListResult
{
Items
:
[]
interface
{}{},
TotalItems
:
0
},
nil
}
func
(
t
*
tenantOperator
)
ListClusters
(
user
user
.
Info
)
(
*
api
.
ListResult
,
error
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录