2023-02-01 17:06:36 +00:00
/ *
Copyright The Kubernetes 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 client-gen. DO NOT EDIT.
2023-06-01 16:58:10 +00:00
package v1alpha2
2023-02-01 17:06:36 +00:00
import (
"context"
json "encoding/json"
"fmt"
"time"
2023-06-01 16:58:10 +00:00
v1alpha2 "k8s.io/api/resource/v1alpha2"
2023-02-01 17:06:36 +00:00
v1 "k8s.io/apimachinery/pkg/apis/meta/v1"
types "k8s.io/apimachinery/pkg/types"
watch "k8s.io/apimachinery/pkg/watch"
2023-06-01 16:58:10 +00:00
resourcev1alpha2 "k8s.io/client-go/applyconfigurations/resource/v1alpha2"
2023-02-01 17:06:36 +00:00
scheme "k8s.io/client-go/kubernetes/scheme"
rest "k8s.io/client-go/rest"
)
// ResourceClaimTemplatesGetter has a method to return a ResourceClaimTemplateInterface.
// A group's client should implement this interface.
type ResourceClaimTemplatesGetter interface {
ResourceClaimTemplates ( namespace string ) ResourceClaimTemplateInterface
}
// ResourceClaimTemplateInterface has methods to work with ResourceClaimTemplate resources.
type ResourceClaimTemplateInterface interface {
2023-06-01 16:58:10 +00:00
Create ( ctx context . Context , resourceClaimTemplate * v1alpha2 . ResourceClaimTemplate , opts v1 . CreateOptions ) ( * v1alpha2 . ResourceClaimTemplate , error )
Update ( ctx context . Context , resourceClaimTemplate * v1alpha2 . ResourceClaimTemplate , opts v1 . UpdateOptions ) ( * v1alpha2 . ResourceClaimTemplate , error )
2023-02-01 17:06:36 +00:00
Delete ( ctx context . Context , name string , opts v1 . DeleteOptions ) error
DeleteCollection ( ctx context . Context , opts v1 . DeleteOptions , listOpts v1 . ListOptions ) error
2023-06-01 16:58:10 +00:00
Get ( ctx context . Context , name string , opts v1 . GetOptions ) ( * v1alpha2 . ResourceClaimTemplate , error )
List ( ctx context . Context , opts v1 . ListOptions ) ( * v1alpha2 . ResourceClaimTemplateList , error )
2023-02-01 17:06:36 +00:00
Watch ( ctx context . Context , opts v1 . ListOptions ) ( watch . Interface , error )
2023-06-01 16:58:10 +00:00
Patch ( ctx context . Context , name string , pt types . PatchType , data [ ] byte , opts v1 . PatchOptions , subresources ... string ) ( result * v1alpha2 . ResourceClaimTemplate , err error )
Apply ( ctx context . Context , resourceClaimTemplate * resourcev1alpha2 . ResourceClaimTemplateApplyConfiguration , opts v1 . ApplyOptions ) ( result * v1alpha2 . ResourceClaimTemplate , err error )
2023-02-01 17:06:36 +00:00
ResourceClaimTemplateExpansion
}
// resourceClaimTemplates implements ResourceClaimTemplateInterface
type resourceClaimTemplates struct {
client rest . Interface
ns string
}
// newResourceClaimTemplates returns a ResourceClaimTemplates
2023-06-01 16:58:10 +00:00
func newResourceClaimTemplates ( c * ResourceV1alpha2Client , namespace string ) * resourceClaimTemplates {
2023-02-01 17:06:36 +00:00
return & resourceClaimTemplates {
client : c . RESTClient ( ) ,
ns : namespace ,
}
}
// Get takes name of the resourceClaimTemplate, and returns the corresponding resourceClaimTemplate object, and an error if there is any.
2023-06-01 16:58:10 +00:00
func ( c * resourceClaimTemplates ) Get ( ctx context . Context , name string , options v1 . GetOptions ) ( result * v1alpha2 . ResourceClaimTemplate , err error ) {
result = & v1alpha2 . ResourceClaimTemplate { }
2023-02-01 17:06:36 +00:00
err = c . client . Get ( ) .
Namespace ( c . ns ) .
Resource ( "resourceclaimtemplates" ) .
Name ( name ) .
VersionedParams ( & options , scheme . ParameterCodec ) .
Do ( ctx ) .
Into ( result )
return
}
// List takes label and field selectors, and returns the list of ResourceClaimTemplates that match those selectors.
2023-06-01 16:58:10 +00:00
func ( c * resourceClaimTemplates ) List ( ctx context . Context , opts v1 . ListOptions ) ( result * v1alpha2 . ResourceClaimTemplateList , err error ) {
2023-02-01 17:06:36 +00:00
var timeout time . Duration
if opts . TimeoutSeconds != nil {
timeout = time . Duration ( * opts . TimeoutSeconds ) * time . Second
}
2023-06-01 16:58:10 +00:00
result = & v1alpha2 . ResourceClaimTemplateList { }
2023-02-01 17:06:36 +00:00
err = c . client . Get ( ) .
Namespace ( c . ns ) .
Resource ( "resourceclaimtemplates" ) .
VersionedParams ( & opts , scheme . ParameterCodec ) .
Timeout ( timeout ) .
Do ( ctx ) .
Into ( result )
return
}
// Watch returns a watch.Interface that watches the requested resourceClaimTemplates.
func ( c * resourceClaimTemplates ) Watch ( ctx context . Context , opts v1 . ListOptions ) ( watch . Interface , error ) {
var timeout time . Duration
if opts . TimeoutSeconds != nil {
timeout = time . Duration ( * opts . TimeoutSeconds ) * time . Second
}
opts . Watch = true
return c . client . Get ( ) .
Namespace ( c . ns ) .
Resource ( "resourceclaimtemplates" ) .
VersionedParams ( & opts , scheme . ParameterCodec ) .
Timeout ( timeout ) .
Watch ( ctx )
}
// Create takes the representation of a resourceClaimTemplate and creates it. Returns the server's representation of the resourceClaimTemplate, and an error, if there is any.
2023-06-01 16:58:10 +00:00
func ( c * resourceClaimTemplates ) Create ( ctx context . Context , resourceClaimTemplate * v1alpha2 . ResourceClaimTemplate , opts v1 . CreateOptions ) ( result * v1alpha2 . ResourceClaimTemplate , err error ) {
result = & v1alpha2 . ResourceClaimTemplate { }
2023-02-01 17:06:36 +00:00
err = c . client . Post ( ) .
Namespace ( c . ns ) .
Resource ( "resourceclaimtemplates" ) .
VersionedParams ( & opts , scheme . ParameterCodec ) .
Body ( resourceClaimTemplate ) .
Do ( ctx ) .
Into ( result )
return
}
// Update takes the representation of a resourceClaimTemplate and updates it. Returns the server's representation of the resourceClaimTemplate, and an error, if there is any.
2023-06-01 16:58:10 +00:00
func ( c * resourceClaimTemplates ) Update ( ctx context . Context , resourceClaimTemplate * v1alpha2 . ResourceClaimTemplate , opts v1 . UpdateOptions ) ( result * v1alpha2 . ResourceClaimTemplate , err error ) {
result = & v1alpha2 . ResourceClaimTemplate { }
2023-02-01 17:06:36 +00:00
err = c . client . Put ( ) .
Namespace ( c . ns ) .
Resource ( "resourceclaimtemplates" ) .
Name ( resourceClaimTemplate . Name ) .
VersionedParams ( & opts , scheme . ParameterCodec ) .
Body ( resourceClaimTemplate ) .
Do ( ctx ) .
Into ( result )
return
}
// Delete takes name of the resourceClaimTemplate and deletes it. Returns an error if one occurs.
func ( c * resourceClaimTemplates ) Delete ( ctx context . Context , name string , opts v1 . DeleteOptions ) error {
return c . client . Delete ( ) .
Namespace ( c . ns ) .
Resource ( "resourceclaimtemplates" ) .
Name ( name ) .
Body ( & opts ) .
Do ( ctx ) .
Error ( )
}
// DeleteCollection deletes a collection of objects.
func ( c * resourceClaimTemplates ) DeleteCollection ( ctx context . Context , opts v1 . DeleteOptions , listOpts v1 . ListOptions ) error {
var timeout time . Duration
if listOpts . TimeoutSeconds != nil {
timeout = time . Duration ( * listOpts . TimeoutSeconds ) * time . Second
}
return c . client . Delete ( ) .
Namespace ( c . ns ) .
Resource ( "resourceclaimtemplates" ) .
VersionedParams ( & listOpts , scheme . ParameterCodec ) .
Timeout ( timeout ) .
Body ( & opts ) .
Do ( ctx ) .
Error ( )
}
// Patch applies the patch and returns the patched resourceClaimTemplate.
2023-06-01 16:58:10 +00:00
func ( c * resourceClaimTemplates ) Patch ( ctx context . Context , name string , pt types . PatchType , data [ ] byte , opts v1 . PatchOptions , subresources ... string ) ( result * v1alpha2 . ResourceClaimTemplate , err error ) {
result = & v1alpha2 . ResourceClaimTemplate { }
2023-02-01 17:06:36 +00:00
err = c . client . Patch ( pt ) .
Namespace ( c . ns ) .
Resource ( "resourceclaimtemplates" ) .
Name ( name ) .
SubResource ( subresources ... ) .
VersionedParams ( & opts , scheme . ParameterCodec ) .
Body ( data ) .
Do ( ctx ) .
Into ( result )
return
}
// Apply takes the given apply declarative configuration, applies it and returns the applied resourceClaimTemplate.
2023-06-01 16:58:10 +00:00
func ( c * resourceClaimTemplates ) Apply ( ctx context . Context , resourceClaimTemplate * resourcev1alpha2 . ResourceClaimTemplateApplyConfiguration , opts v1 . ApplyOptions ) ( result * v1alpha2 . ResourceClaimTemplate , err error ) {
2023-02-01 17:06:36 +00:00
if resourceClaimTemplate == nil {
return nil , fmt . Errorf ( "resourceClaimTemplate provided to Apply must not be nil" )
}
patchOpts := opts . ToPatchOptions ( )
data , err := json . Marshal ( resourceClaimTemplate )
if err != nil {
return nil , err
}
name := resourceClaimTemplate . Name
if name == nil {
return nil , fmt . Errorf ( "resourceClaimTemplate.Name must be provided to Apply" )
}
2023-06-01 16:58:10 +00:00
result = & v1alpha2 . ResourceClaimTemplate { }
2023-02-01 17:06:36 +00:00
err = c . client . Patch ( types . ApplyPatchType ) .
Namespace ( c . ns ) .
Resource ( "resourceclaimtemplates" ) .
Name ( * name ) .
VersionedParams ( & patchOpts , scheme . ParameterCodec ) .
Body ( data ) .
Do ( ctx ) .
Into ( result )
return
}