-
Notifications
You must be signed in to change notification settings - Fork 11
/
deployment.go
85 lines (66 loc) · 3.2 KB
/
deployment.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 v1beta2
import (
"context"
kcpclient "github.com/kcp-dev/apimachinery/v2/pkg/client"
"github.com/kcp-dev/logicalcluster/v3"
appsv1beta2 "k8s.io/api/apps/v1beta2"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/watch"
appsv1beta2client "k8s.io/client-go/kubernetes/typed/apps/v1beta2"
)
// DeploymentsClusterGetter has a method to return a DeploymentClusterInterface.
// A group's cluster client should implement this interface.
type DeploymentsClusterGetter interface {
Deployments() DeploymentClusterInterface
}
// DeploymentClusterInterface can operate on Deployments across all clusters,
// or scope down to one cluster and return a DeploymentsNamespacer.
type DeploymentClusterInterface interface {
Cluster(logicalcluster.Path) DeploymentsNamespacer
List(ctx context.Context, opts metav1.ListOptions) (*appsv1beta2.DeploymentList, error)
Watch(ctx context.Context, opts metav1.ListOptions) (watch.Interface, error)
}
type deploymentsClusterInterface struct {
clientCache kcpclient.Cache[*appsv1beta2client.AppsV1beta2Client]
}
// Cluster scopes the client down to a particular cluster.
func (c *deploymentsClusterInterface) Cluster(clusterPath logicalcluster.Path) DeploymentsNamespacer {
if clusterPath == logicalcluster.Wildcard {
panic("A specific cluster must be provided when scoping, not the wildcard.")
}
return &deploymentsNamespacer{clientCache: c.clientCache, clusterPath: clusterPath}
}
// List returns the entire collection of all Deployments across all clusters.
func (c *deploymentsClusterInterface) List(ctx context.Context, opts metav1.ListOptions) (*appsv1beta2.DeploymentList, error) {
return c.clientCache.ClusterOrDie(logicalcluster.Wildcard).Deployments(metav1.NamespaceAll).List(ctx, opts)
}
// Watch begins to watch all Deployments across all clusters.
func (c *deploymentsClusterInterface) Watch(ctx context.Context, opts metav1.ListOptions) (watch.Interface, error) {
return c.clientCache.ClusterOrDie(logicalcluster.Wildcard).Deployments(metav1.NamespaceAll).Watch(ctx, opts)
}
// DeploymentsNamespacer can scope to objects within a namespace, returning a appsv1beta2client.DeploymentInterface.
type DeploymentsNamespacer interface {
Namespace(string) appsv1beta2client.DeploymentInterface
}
type deploymentsNamespacer struct {
clientCache kcpclient.Cache[*appsv1beta2client.AppsV1beta2Client]
clusterPath logicalcluster.Path
}
func (n *deploymentsNamespacer) Namespace(namespace string) appsv1beta2client.DeploymentInterface {
return n.clientCache.ClusterOrDie(n.clusterPath).Deployments(namespace)
}