-
Notifications
You must be signed in to change notification settings - Fork 462
/
types_adminkubeconfigrequest.go
43 lines (37 loc) · 1.89 KB
/
types_adminkubeconfigrequest.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
// SPDX-FileCopyrightText: 2024 SAP SE or an SAP affiliate company and Gardener contributors
//
// SPDX-License-Identifier: Apache-2.0
package v1alpha1
import (
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
// +genclient
// +k8s:deepcopy-gen:interfaces=k8s.io/apimachinery/pkg/runtime.Object
// AdminKubeconfigRequest can be used to request a kubeconfig with admin credentials
// for a Shoot cluster.
type AdminKubeconfigRequest struct {
metav1.TypeMeta `json:",inline"`
// Standard object metadata.
metav1.ObjectMeta `json:"metadata,omitempty" protobuf:"bytes,1,opt,name=metadata"`
// Spec is the specification of the AdminKubeconfigRequest.
Spec AdminKubeconfigRequestSpec `json:"spec" protobuf:"bytes,2,opt,name=spec"`
// Status is the status of the AdminKubeconfigRequest.
Status AdminKubeconfigRequestStatus `json:"status" protobuf:"bytes,3,opt,name=status"`
}
// AdminKubeconfigRequestStatus is the status of the AdminKubeconfigRequest containing
// the kubeconfig and expiration of the credential.
type AdminKubeconfigRequestStatus struct {
// Kubeconfig contains the kubeconfig with cluster-admin privileges for the shoot cluster.
Kubeconfig []byte `json:"kubeconfig" protobuf:"bytes,1,opt,name=kubeconfig"`
// ExpirationTimestamp is the expiration timestamp of the returned credential.
ExpirationTimestamp metav1.Time `json:"expirationTimestamp" protobuf:"bytes,2,opt,name=expirationTimestamp"`
}
// AdminKubeconfigRequestSpec contains the expiration time of the kubeconfig.
type AdminKubeconfigRequestSpec struct {
// ExpirationSeconds is the requested validity duration of the credential. The
// credential issuer may return a credential with a different validity duration so a
// client needs to check the 'expirationTimestamp' field in a response.
// Defaults to 1 hour.
// +optional
ExpirationSeconds *int64 `json:"expirationSeconds,omitempty" protobuf:"varint,1,opt,name=expirationSeconds"`
}