/
base.go
145 lines (121 loc) · 4.7 KB
/
base.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
package getter
import (
"context"
apierrors "k8s.io/apimachinery/pkg/api/errors"
"k8s.io/apimachinery/pkg/apis/meta/v1/unstructured"
"k8s.io/apimachinery/pkg/fields"
"k8s.io/apimachinery/pkg/labels"
"k8s.io/apimachinery/pkg/runtime/schema"
"k8s.io/apimachinery/pkg/types"
"sigs.k8s.io/controller-runtime/pkg/client"
"sigs.k8s.io/yaml"
)
// GetResourceInCache gets a specific Kubernetes object in local cache, object can be any types
// which are registered by "scheme.AddToScheme()".
// Return true if object is found, false if not, or an error if something bad happened.
func GetResourceInCache(ns, name string, obj client.Object, cl client.Reader) (bool, error) {
err := cl.Get(context.TODO(), types.NamespacedName{Namespace: ns, Name: name}, obj)
if err != nil {
if apierrors.IsNotFound(err) {
return false, nil
}
return false, err
}
return true, nil
}
// ListResourceInCache gets a set of specific Kubernetes object in local cache, object can be any types
// which are registered by "scheme.AddToScheme()".
// Important: fieldSelector must be nil or contain just one kv pair, otherwise, controller-runtime will return error.
func ListResourceInCache(ns string, selector labels.Selector, fieldSelector fields.Selector, obj client.ObjectList, cl client.Reader) error {
opts := []client.ListOption{client.InNamespace(ns)}
if selector != nil && !selector.Empty() {
opts = append(opts, client.MatchingLabelsSelector{Selector: selector})
}
if fieldSelector != nil && !fieldSelector.Empty() {
opts = append(opts, client.MatchingFieldsSelector{Selector: fieldSelector})
}
return cl.List(context.TODO(), obj, opts...)
}
// ListUnstructuredResourceInCache gets a set of specific Kubernetes object in local cache, and return a representation in yaml format.
func ListUnstructuredResourceInCache(ns string, selector labels.Selector, fieldSelector fields.Selector, gvk schema.GroupVersionKind, cl client.Reader) ([]*unstructured.Unstructured, error) {
u := &unstructured.UnstructuredList{}
u.SetGroupVersionKind(gvk)
err := ListResourceInCache(ns, selector, fieldSelector, u, cl)
if err != nil {
return nil, err
}
var res []*unstructured.Unstructured
for i := range u.Items {
res = append(res, &u.Items[i])
}
return res, err
}
// GetResourceJSONInCache gets a specific Kubernetes object in local cache, and return a representation in json format.
// Return true if object is found, false if not, or an error if something bad happened.
func GetResourceJSONInCache(ns, name string, gvk schema.GroupVersionKind, cl client.Reader) ([]byte, bool, error) {
u := &unstructured.Unstructured{}
u.SetGroupVersionKind(gvk)
found, err := GetResourceInCache(ns, name, u, cl)
if err != nil || !found {
return nil, false, err
}
data, err := u.MarshalJSON()
if err != nil {
return nil, false, err
}
return data, true, nil
}
// GetResourceYamlInCache gets a specific Kubernetes object in local cache, and return a representation in yaml format.
// Return true if object is found, false if not, or an error if something bad happened.
func GetResourceYamlInCache(ns, name string, gvk schema.GroupVersionKind, cl client.Reader) ([]byte, bool, error) {
d, found, err := GetResourceJSONInCache(ns, name, gvk, cl)
if err != nil || !found || len(d) == 0 {
return nil, false, err
}
data, err := yaml.JSONToYAML(d)
if err != nil {
return nil, false, err
}
return data, true, nil
}
// ListResourceJSONInCache gets a set of specific Kubernetes object in local cache, and return a representation in json format.
func ListResourceJSONInCache(ns string, selector labels.Selector, fieldSelector fields.Selector, gvk schema.GroupVersionKind, cl client.Reader) ([][]byte, error) {
u := &unstructured.UnstructuredList{}
u.SetGroupVersionKind(gvk)
err := ListResourceInCache(ns, selector, fieldSelector, u, cl)
if err != nil {
return nil, err
}
var res [][]byte
for _, item := range u.Items {
data, err := item.MarshalJSON()
if err != nil {
return nil, err
}
res = append(res, data)
}
return res, nil
}
// ListResourceYamlInCache gets a set of specific Kubernetes object in local cache, and return a representation in yaml format.
func ListResourceYamlInCache(ns string, selector labels.Selector, fieldSelector fields.Selector, gvk schema.GroupVersionKind, cl client.Reader) ([][]byte, error) {
u := &unstructured.UnstructuredList{}
u.SetGroupVersionKind(gvk)
err := ListResourceInCache(ns, selector, fieldSelector, u, cl)
if err != nil {
return nil, err
}
var res [][]byte
for _, item := range u.Items {
item.SetManagedFields(nil)
data, err := item.MarshalJSON()
if err != nil {
return nil, err
}
data, err = yaml.JSONToYAML(data)
if err != nil {
return nil, err
}
res = append(res, data)
}
return res, nil
}