/
authorization_client.go
130 lines (108 loc) · 3.71 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
// Code generated by client-gen. DO NOT EDIT.
package internalversion
import (
"github.com/openshift/origin/pkg/authorization/generated/internalclientset/scheme"
rest "k8s.io/client-go/rest"
)
type AuthorizationInterface interface {
RESTClient() rest.Interface
ClusterRolesGetter
ClusterRoleBindingsGetter
LocalResourceAccessReviewsGetter
LocalSubjectAccessReviewsGetter
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) 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) 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 {
config.APIPath = "/apis"
if config.UserAgent == "" {
config.UserAgent = rest.DefaultKubernetesUserAgent()
}
if config.GroupVersion == nil || config.GroupVersion.Group != scheme.Scheme.PrioritizedVersionsForGroup("authorization.openshift.io")[0].Group {
gv := scheme.Scheme.PrioritizedVersionsForGroup("authorization.openshift.io")[0]
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
}