forked from joeholley/supergloo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtls_secret_client.sk.go
118 lines (99 loc) · 3.3 KB
/
tls_secret_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
// Code generated by solo-kit. DO NOT EDIT.
package v1
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 TlsSecretClient interface {
BaseClient() clients.ResourceClient
Register() error
Read(namespace, name string, opts clients.ReadOpts) (*TlsSecret, error)
Write(resource *TlsSecret, opts clients.WriteOpts) (*TlsSecret, error)
Delete(namespace, name string, opts clients.DeleteOpts) error
List(namespace string, opts clients.ListOpts) (TlsSecretList, error)
Watch(namespace string, opts clients.WatchOpts) (<-chan TlsSecretList, <-chan error, error)
}
type tlsSecretClient struct {
rc clients.ResourceClient
}
func NewTlsSecretClient(rcFactory factory.ResourceClientFactory) (TlsSecretClient, error) {
return NewTlsSecretClientWithToken(rcFactory, "")
}
func NewTlsSecretClientWithToken(rcFactory factory.ResourceClientFactory, token string) (TlsSecretClient, error) {
rc, err := rcFactory.NewResourceClient(factory.NewResourceClientParams{
ResourceType: &TlsSecret{},
Token: token,
})
if err != nil {
return nil, errors.Wrapf(err, "creating base TlsSecret resource client")
}
return NewTlsSecretClientWithBase(rc), nil
}
func NewTlsSecretClientWithBase(rc clients.ResourceClient) TlsSecretClient {
return &tlsSecretClient{
rc: rc,
}
}
func (client *tlsSecretClient) BaseClient() clients.ResourceClient {
return client.rc
}
func (client *tlsSecretClient) Register() error {
return client.rc.Register()
}
func (client *tlsSecretClient) Read(namespace, name string, opts clients.ReadOpts) (*TlsSecret, error) {
opts = opts.WithDefaults()
resource, err := client.rc.Read(namespace, name, opts)
if err != nil {
return nil, err
}
return resource.(*TlsSecret), nil
}
func (client *tlsSecretClient) Write(tlsSecret *TlsSecret, opts clients.WriteOpts) (*TlsSecret, error) {
opts = opts.WithDefaults()
resource, err := client.rc.Write(tlsSecret, opts)
if err != nil {
return nil, err
}
return resource.(*TlsSecret), nil
}
func (client *tlsSecretClient) Delete(namespace, name string, opts clients.DeleteOpts) error {
opts = opts.WithDefaults()
return client.rc.Delete(namespace, name, opts)
}
func (client *tlsSecretClient) List(namespace string, opts clients.ListOpts) (TlsSecretList, error) {
opts = opts.WithDefaults()
resourceList, err := client.rc.List(namespace, opts)
if err != nil {
return nil, err
}
return convertToTlsSecret(resourceList), nil
}
func (client *tlsSecretClient) Watch(namespace string, opts clients.WatchOpts) (<-chan TlsSecretList, <-chan error, error) {
opts = opts.WithDefaults()
resourcesChan, errs, initErr := client.rc.Watch(namespace, opts)
if initErr != nil {
return nil, nil, initErr
}
tlssecretsChan := make(chan TlsSecretList)
go func() {
for {
select {
case resourceList := <-resourcesChan:
tlssecretsChan <- convertToTlsSecret(resourceList)
case <-opts.Ctx.Done():
close(tlssecretsChan)
return
}
}
}()
return tlssecretsChan, errs, nil
}
func convertToTlsSecret(resources resources.ResourceList) TlsSecretList {
var tlsSecretList TlsSecretList
for _, resource := range resources {
tlsSecretList = append(tlsSecretList, resource.(*TlsSecret))
}
return tlsSecretList
}