/
authorization_client.go
153 lines (127 loc) · 4.19 KB
/
authorization_client.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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
package internalversion
import (
"github.com/openshift/origin/pkg/authorization/generated/internalclientset/scheme"
rest "k8s.io/client-go/rest"
)
type AuthorizationInterface interface {
RESTClient() rest.Interface
ClusterPoliciesGetter
ClusterPolicyBindingsGetter
ClusterRolesGetter
ClusterRoleBindingsGetter
LocalResourceAccessReviewsGetter
LocalSubjectAccessReviewsGetter
PoliciesGetter
PolicyBindingsGetter
ResourceAccessReviewsGetter
RolesGetter
RoleBindingsGetter
RoleBindingRestrictionsGetter
SelfSubjectRulesReviewsGetter
SubjectAccessReviewsGetter
SubjectRulesReviewsGetter
}
// AuthorizationClient is used to interact with features provided by the authorization.openshift.io group.
type AuthorizationClient struct {
restClient rest.Interface
}
func (c *AuthorizationClient) ClusterPolicies() ClusterPolicyInterface {
return newClusterPolicies(c)
}
func (c *AuthorizationClient) ClusterPolicyBindings() ClusterPolicyBindingInterface {
return newClusterPolicyBindings(c)
}
func (c *AuthorizationClient) ClusterRoles() ClusterRoleInterface {
return newClusterRoles(c)
}
func (c *AuthorizationClient) ClusterRoleBindings() ClusterRoleBindingInterface {
return newClusterRoleBindings(c)
}
func (c *AuthorizationClient) LocalResourceAccessReviews(namespace string) LocalResourceAccessReviewInterface {
return newLocalResourceAccessReviews(c, namespace)
}
func (c *AuthorizationClient) LocalSubjectAccessReviews(namespace string) LocalSubjectAccessReviewInterface {
return newLocalSubjectAccessReviews(c, namespace)
}
func (c *AuthorizationClient) Policies(namespace string) PolicyInterface {
return newPolicies(c, namespace)
}
func (c *AuthorizationClient) PolicyBindings(namespace string) PolicyBindingInterface {
return newPolicyBindings(c, namespace)
}
func (c *AuthorizationClient) ResourceAccessReviews() ResourceAccessReviewInterface {
return newResourceAccessReviews(c)
}
func (c *AuthorizationClient) Roles(namespace string) RoleInterface {
return newRoles(c, namespace)
}
func (c *AuthorizationClient) RoleBindings(namespace string) RoleBindingInterface {
return newRoleBindings(c, namespace)
}
func (c *AuthorizationClient) RoleBindingRestrictions(namespace string) RoleBindingRestrictionInterface {
return newRoleBindingRestrictions(c, namespace)
}
func (c *AuthorizationClient) SelfSubjectRulesReviews(namespace string) SelfSubjectRulesReviewInterface {
return newSelfSubjectRulesReviews(c, namespace)
}
func (c *AuthorizationClient) SubjectAccessReviews() SubjectAccessReviewInterface {
return newSubjectAccessReviews(c)
}
func (c *AuthorizationClient) SubjectRulesReviews(namespace string) SubjectRulesReviewInterface {
return newSubjectRulesReviews(c, namespace)
}
// NewForConfig creates a new AuthorizationClient for the given config.
func NewForConfig(c *rest.Config) (*AuthorizationClient, error) {
config := *c
if err := setConfigDefaults(&config); err != nil {
return nil, err
}
client, err := rest.RESTClientFor(&config)
if err != nil {
return nil, err
}
return &AuthorizationClient{client}, nil
}
// NewForConfigOrDie creates a new AuthorizationClient for the given config and
// panics if there is an error in the config.
func NewForConfigOrDie(c *rest.Config) *AuthorizationClient {
client, err := NewForConfig(c)
if err != nil {
panic(err)
}
return client
}
// New creates a new AuthorizationClient for the given RESTClient.
func New(c rest.Interface) *AuthorizationClient {
return &AuthorizationClient{c}
}
func setConfigDefaults(config *rest.Config) error {
g, err := scheme.Registry.Group("authorization.openshift.io")
if err != nil {
return err
}
config.APIPath = "/apis"
if config.UserAgent == "" {
config.UserAgent = rest.DefaultKubernetesUserAgent()
}
if config.GroupVersion == nil || config.GroupVersion.Group != g.GroupVersion.Group {
gv := g.GroupVersion
config.GroupVersion = &gv
}
config.NegotiatedSerializer = scheme.Codecs
if config.QPS == 0 {
config.QPS = 5
}
if config.Burst == 0 {
config.Burst = 10
}
return nil
}
// RESTClient returns a RESTClient that is used to communicate
// with API server by this client implementation.
func (c *AuthorizationClient) RESTClient() rest.Interface {
if c == nil {
return nil
}
return c.restClient
}