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