forked from openshift/origin
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathdead.go
79 lines (66 loc) · 2.63 KB
/
dead.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
package bootstrappolicy
import (
"github.com/golang/glog"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/kubernetes/pkg/apis/rbac"
)
var (
deadClusterRoles = []rbac.ClusterRole{}
deadClusterRoleBindings = []rbac.ClusterRoleBinding{}
)
func addDeadClusterRole(name string) {
for _, existingRole := range deadClusterRoles {
if name == existingRole.Name {
glog.Fatalf("role %q was already registered", name)
}
}
deadClusterRole := rbac.ClusterRole{
ObjectMeta: metav1.ObjectMeta{Name: name},
}
addDefaultMetadata(&deadClusterRole)
deadClusterRoles = append(deadClusterRoles, deadClusterRole)
}
func addDeadClusterRoleBinding(name, roleName string) {
for _, existing := range deadClusterRoleBindings {
if name == existing.Name {
glog.Fatalf("%q was already registered", name)
}
}
deadClusterRoleBinding := rbac.ClusterRoleBinding{
ObjectMeta: metav1.ObjectMeta{Name: name},
RoleRef: rbac.RoleRef{APIGroup: rbac.GroupName, Kind: "ClusterRole", Name: roleName},
}
addDefaultMetadata(&deadClusterRoleBinding)
deadClusterRoleBindings = append(deadClusterRoleBindings, deadClusterRoleBinding)
}
// GetDeadClusterRoles returns cluster roles which should no longer have any permissions.
// These are enumerated so that a reconcile that tightens permissions will properly.
func GetDeadClusterRoles() []rbac.ClusterRole {
return deadClusterRoles
}
// GetDeadClusterRoleBindings returns cluster role bindings which should no longer have any subjects.
// These are enumerated so that a reconcile that tightens permissions will properly remove them.
func GetDeadClusterRoleBindings() []rbac.ClusterRoleBinding {
return deadClusterRoleBindings
}
func init() {
// these were replaced by kube controller roles
addDeadClusterRole("system:replication-controller")
addDeadClusterRole("system:endpoint-controller")
addDeadClusterRole("system:replicaset-controller")
addDeadClusterRole("system:garbage-collector-controller")
addDeadClusterRole("system:job-controller")
addDeadClusterRole("system:hpa-controller")
addDeadClusterRole("system:daemonset-controller")
addDeadClusterRole("system:disruption-controller")
addDeadClusterRole("system:namespace-controller")
addDeadClusterRole("system:gc-controller")
addDeadClusterRole("system:certificate-signing-controller")
addDeadClusterRole("system:statefulset-controller")
// these were moved under system:openshift:controller:*
addDeadClusterRole("system:build-controller")
addDeadClusterRole("system:deploymentconfig-controller")
addDeadClusterRole("system:deployment-controller")
// this was replaced by the node authorizer
addDeadClusterRoleBinding("system:nodes", "system:node")
}