-
Notifications
You must be signed in to change notification settings - Fork 10
/
configmap.go
85 lines (66 loc) · 3.1 KB
/
configmap.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
//go:build !ignore_autogenerated
// +build !ignore_autogenerated
/*
Copyright The KCP Authors.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
// Code generated by kcp code-generator. DO NOT EDIT.
package v1
import (
"context"
kcpclient "github.com/kcp-dev/apimachinery/v2/pkg/client"
"github.com/kcp-dev/logicalcluster/v3"
corev1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/watch"
corev1client "k8s.io/client-go/kubernetes/typed/core/v1"
)
// ConfigMapsClusterGetter has a method to return a ConfigMapClusterInterface.
// A group's cluster client should implement this interface.
type ConfigMapsClusterGetter interface {
ConfigMaps() ConfigMapClusterInterface
}
// ConfigMapClusterInterface can operate on ConfigMaps across all clusters,
// or scope down to one cluster and return a ConfigMapsNamespacer.
type ConfigMapClusterInterface interface {
Cluster(logicalcluster.Path) ConfigMapsNamespacer
List(ctx context.Context, opts metav1.ListOptions) (*corev1.ConfigMapList, error)
Watch(ctx context.Context, opts metav1.ListOptions) (watch.Interface, error)
}
type configMapsClusterInterface struct {
clientCache kcpclient.Cache[*corev1client.CoreV1Client]
}
// Cluster scopes the client down to a particular cluster.
func (c *configMapsClusterInterface) Cluster(clusterPath logicalcluster.Path) ConfigMapsNamespacer {
if clusterPath == logicalcluster.Wildcard {
panic("A specific cluster must be provided when scoping, not the wildcard.")
}
return &configMapsNamespacer{clientCache: c.clientCache, clusterPath: clusterPath}
}
// List returns the entire collection of all ConfigMaps across all clusters.
func (c *configMapsClusterInterface) List(ctx context.Context, opts metav1.ListOptions) (*corev1.ConfigMapList, error) {
return c.clientCache.ClusterOrDie(logicalcluster.Wildcard).ConfigMaps(metav1.NamespaceAll).List(ctx, opts)
}
// Watch begins to watch all ConfigMaps across all clusters.
func (c *configMapsClusterInterface) Watch(ctx context.Context, opts metav1.ListOptions) (watch.Interface, error) {
return c.clientCache.ClusterOrDie(logicalcluster.Wildcard).ConfigMaps(metav1.NamespaceAll).Watch(ctx, opts)
}
// ConfigMapsNamespacer can scope to objects within a namespace, returning a corev1client.ConfigMapInterface.
type ConfigMapsNamespacer interface {
Namespace(string) corev1client.ConfigMapInterface
}
type configMapsNamespacer struct {
clientCache kcpclient.Cache[*corev1client.CoreV1Client]
clusterPath logicalcluster.Path
}
func (n *configMapsNamespacer) Namespace(namespace string) corev1client.ConfigMapInterface {
return n.clientCache.ClusterOrDie(n.clusterPath).ConfigMaps(namespace)
}