-
Notifications
You must be signed in to change notification settings - Fork 10
/
resourcequota.go
85 lines (66 loc) · 3.22 KB
/
resourcequota.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"
)
// ResourceQuotasClusterGetter has a method to return a ResourceQuotaClusterInterface.
// A group's cluster client should implement this interface.
type ResourceQuotasClusterGetter interface {
ResourceQuotas() ResourceQuotaClusterInterface
}
// ResourceQuotaClusterInterface can operate on ResourceQuotas across all clusters,
// or scope down to one cluster and return a ResourceQuotasNamespacer.
type ResourceQuotaClusterInterface interface {
Cluster(logicalcluster.Path) ResourceQuotasNamespacer
List(ctx context.Context, opts metav1.ListOptions) (*corev1.ResourceQuotaList, error)
Watch(ctx context.Context, opts metav1.ListOptions) (watch.Interface, error)
}
type resourceQuotasClusterInterface struct {
clientCache kcpclient.Cache[*corev1client.CoreV1Client]
}
// Cluster scopes the client down to a particular cluster.
func (c *resourceQuotasClusterInterface) Cluster(clusterPath logicalcluster.Path) ResourceQuotasNamespacer {
if clusterPath == logicalcluster.Wildcard {
panic("A specific cluster must be provided when scoping, not the wildcard.")
}
return &resourceQuotasNamespacer{clientCache: c.clientCache, clusterPath: clusterPath}
}
// List returns the entire collection of all ResourceQuotas across all clusters.
func (c *resourceQuotasClusterInterface) List(ctx context.Context, opts metav1.ListOptions) (*corev1.ResourceQuotaList, error) {
return c.clientCache.ClusterOrDie(logicalcluster.Wildcard).ResourceQuotas(metav1.NamespaceAll).List(ctx, opts)
}
// Watch begins to watch all ResourceQuotas across all clusters.
func (c *resourceQuotasClusterInterface) Watch(ctx context.Context, opts metav1.ListOptions) (watch.Interface, error) {
return c.clientCache.ClusterOrDie(logicalcluster.Wildcard).ResourceQuotas(metav1.NamespaceAll).Watch(ctx, opts)
}
// ResourceQuotasNamespacer can scope to objects within a namespace, returning a corev1client.ResourceQuotaInterface.
type ResourceQuotasNamespacer interface {
Namespace(string) corev1client.ResourceQuotaInterface
}
type resourceQuotasNamespacer struct {
clientCache kcpclient.Cache[*corev1client.CoreV1Client]
clusterPath logicalcluster.Path
}
func (n *resourceQuotasNamespacer) Namespace(namespace string) corev1client.ResourceQuotaInterface {
return n.clientCache.ClusterOrDie(n.clusterPath).ResourceQuotas(namespace)
}