forked from joeholley/supergloo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmesh_ingress_client.sk.go
123 lines (103 loc) · 3.5 KB
/
mesh_ingress_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 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 MeshIngressWatcher interface {
// watch namespace-scoped Meshingresses
Watch(namespace string, opts clients.WatchOpts) (<-chan MeshIngressList, <-chan error, error)
}
type MeshIngressClient interface {
BaseClient() clients.ResourceClient
Register() error
Read(namespace, name string, opts clients.ReadOpts) (*MeshIngress, error)
Write(resource *MeshIngress, opts clients.WriteOpts) (*MeshIngress, error)
Delete(namespace, name string, opts clients.DeleteOpts) error
List(namespace string, opts clients.ListOpts) (MeshIngressList, error)
MeshIngressWatcher
}
type meshIngressClient struct {
rc clients.ResourceClient
}
func NewMeshIngressClient(rcFactory factory.ResourceClientFactory) (MeshIngressClient, error) {
return NewMeshIngressClientWithToken(rcFactory, "")
}
func NewMeshIngressClientWithToken(rcFactory factory.ResourceClientFactory, token string) (MeshIngressClient, error) {
rc, err := rcFactory.NewResourceClient(factory.NewResourceClientParams{
ResourceType: &MeshIngress{},
Token: token,
})
if err != nil {
return nil, errors.Wrapf(err, "creating base MeshIngress resource client")
}
return NewMeshIngressClientWithBase(rc), nil
}
func NewMeshIngressClientWithBase(rc clients.ResourceClient) MeshIngressClient {
return &meshIngressClient{
rc: rc,
}
}
func (client *meshIngressClient) BaseClient() clients.ResourceClient {
return client.rc
}
func (client *meshIngressClient) Register() error {
return client.rc.Register()
}
func (client *meshIngressClient) Read(namespace, name string, opts clients.ReadOpts) (*MeshIngress, error) {
opts = opts.WithDefaults()
resource, err := client.rc.Read(namespace, name, opts)
if err != nil {
return nil, err
}
return resource.(*MeshIngress), nil
}
func (client *meshIngressClient) Write(meshIngress *MeshIngress, opts clients.WriteOpts) (*MeshIngress, error) {
opts = opts.WithDefaults()
resource, err := client.rc.Write(meshIngress, opts)
if err != nil {
return nil, err
}
return resource.(*MeshIngress), nil
}
func (client *meshIngressClient) Delete(namespace, name string, opts clients.DeleteOpts) error {
opts = opts.WithDefaults()
return client.rc.Delete(namespace, name, opts)
}
func (client *meshIngressClient) List(namespace string, opts clients.ListOpts) (MeshIngressList, error) {
opts = opts.WithDefaults()
resourceList, err := client.rc.List(namespace, opts)
if err != nil {
return nil, err
}
return convertToMeshIngress(resourceList), nil
}
func (client *meshIngressClient) Watch(namespace string, opts clients.WatchOpts) (<-chan MeshIngressList, <-chan error, error) {
opts = opts.WithDefaults()
resourcesChan, errs, initErr := client.rc.Watch(namespace, opts)
if initErr != nil {
return nil, nil, initErr
}
meshingressesChan := make(chan MeshIngressList)
go func() {
for {
select {
case resourceList := <-resourcesChan:
meshingressesChan <- convertToMeshIngress(resourceList)
case <-opts.Ctx.Done():
close(meshingressesChan)
return
}
}
}()
return meshingressesChan, errs, nil
}
func convertToMeshIngress(resources resources.ResourceList) MeshIngressList {
var meshIngressList MeshIngressList
for _, resource := range resources {
meshIngressList = append(meshIngressList, resource.(*MeshIngress))
}
return meshIngressList
}