forked from joeholley/supergloo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrbac_config_client.sk.go
123 lines (103 loc) · 3.45 KB
/
rbac_config_client.sk.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
// Code generated by solo-kit. DO NOT EDIT.
package v1alpha1
import (
"github.com/solo-io/solo-kit/pkg/api/v1/clients"
"github.com/solo-io/solo-kit/pkg/api/v1/clients/factory"
"github.com/solo-io/solo-kit/pkg/api/v1/resources"
"github.com/solo-io/solo-kit/pkg/errors"
)
type RbacConfigWatcher interface {
// watch namespace-scoped Rbacconfigs
Watch(namespace string, opts clients.WatchOpts) (<-chan RbacConfigList, <-chan error, error)
}
type RbacConfigClient interface {
BaseClient() clients.ResourceClient
Register() error
Read(namespace, name string, opts clients.ReadOpts) (*RbacConfig, error)
Write(resource *RbacConfig, opts clients.WriteOpts) (*RbacConfig, error)
Delete(namespace, name string, opts clients.DeleteOpts) error
List(namespace string, opts clients.ListOpts) (RbacConfigList, error)
RbacConfigWatcher
}
type rbacConfigClient struct {
rc clients.ResourceClient
}
func NewRbacConfigClient(rcFactory factory.ResourceClientFactory) (RbacConfigClient, error) {
return NewRbacConfigClientWithToken(rcFactory, "")
}
func NewRbacConfigClientWithToken(rcFactory factory.ResourceClientFactory, token string) (RbacConfigClient, error) {
rc, err := rcFactory.NewResourceClient(factory.NewResourceClientParams{
ResourceType: &RbacConfig{},
Token: token,
})
if err != nil {
return nil, errors.Wrapf(err, "creating base RbacConfig resource client")
}
return NewRbacConfigClientWithBase(rc), nil
}
func NewRbacConfigClientWithBase(rc clients.ResourceClient) RbacConfigClient {
return &rbacConfigClient{
rc: rc,
}
}
func (client *rbacConfigClient) BaseClient() clients.ResourceClient {
return client.rc
}
func (client *rbacConfigClient) Register() error {
return client.rc.Register()
}
func (client *rbacConfigClient) Read(namespace, name string, opts clients.ReadOpts) (*RbacConfig, error) {
opts = opts.WithDefaults()
resource, err := client.rc.Read(namespace, name, opts)
if err != nil {
return nil, err
}
return resource.(*RbacConfig), nil
}
func (client *rbacConfigClient) Write(rbacConfig *RbacConfig, opts clients.WriteOpts) (*RbacConfig, error) {
opts = opts.WithDefaults()
resource, err := client.rc.Write(rbacConfig, opts)
if err != nil {
return nil, err
}
return resource.(*RbacConfig), nil
}
func (client *rbacConfigClient) Delete(namespace, name string, opts clients.DeleteOpts) error {
opts = opts.WithDefaults()
return client.rc.Delete(namespace, name, opts)
}
func (client *rbacConfigClient) List(namespace string, opts clients.ListOpts) (RbacConfigList, error) {
opts = opts.WithDefaults()
resourceList, err := client.rc.List(namespace, opts)
if err != nil {
return nil, err
}
return convertToRbacConfig(resourceList), nil
}
func (client *rbacConfigClient) Watch(namespace string, opts clients.WatchOpts) (<-chan RbacConfigList, <-chan error, error) {
opts = opts.WithDefaults()
resourcesChan, errs, initErr := client.rc.Watch(namespace, opts)
if initErr != nil {
return nil, nil, initErr
}
rbacconfigsChan := make(chan RbacConfigList)
go func() {
for {
select {
case resourceList := <-resourcesChan:
rbacconfigsChan <- convertToRbacConfig(resourceList)
case <-opts.Ctx.Done():
close(rbacconfigsChan)
return
}
}
}()
return rbacconfigsChan, errs, nil
}
func convertToRbacConfig(resources resources.ResourceList) RbacConfigList {
var rbacConfigList RbacConfigList
for _, resource := range resources {
rbacConfigList = append(rbacConfigList, resource.(*RbacConfig))
}
return rbacConfigList
}