1 /* 2 Copyright The Kubernetes Authors. 3 4 Licensed under the Apache License, Version 2.0 (the "License"); 5 you may not use this file except in compliance with the License. 6 You may obtain a copy of the License at 7 8 http://www.apache.org/licenses/LICENSE-2.0 9 10 Unless required by applicable law or agreed to in writing, software 11 distributed under the License is distributed on an "AS IS" BASIS, 12 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 See the License for the specific language governing permissions and 14 limitations under the License. 15 */ 16 17 // Code generated by applyconfiguration-gen. DO NOT EDIT. 18 19 package v1alpha1 20 21 import ( 22 certificatesv1alpha1 "k8s.io/api/certificates/v1alpha1" 23 metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" 24 types "k8s.io/apimachinery/pkg/types" 25 managedfields "k8s.io/apimachinery/pkg/util/managedfields" 26 internal "k8s.io/client-go/applyconfigurations/internal" 27 v1 "k8s.io/client-go/applyconfigurations/meta/v1" 28 ) 29 30 // ClusterTrustBundleApplyConfiguration represents an declarative configuration of the ClusterTrustBundle type for use 31 // with apply. 32 type ClusterTrustBundleApplyConfiguration struct { 33 v1.TypeMetaApplyConfiguration `json:",inline"` 34 *v1.ObjectMetaApplyConfiguration `json:"metadata,omitempty"` 35 Spec *ClusterTrustBundleSpecApplyConfiguration `json:"spec,omitempty"` 36 } 37 38 // ClusterTrustBundle constructs an declarative configuration of the ClusterTrustBundle type for use with 39 // apply. 40 func ClusterTrustBundle(name string) *ClusterTrustBundleApplyConfiguration { 41 b := &ClusterTrustBundleApplyConfiguration{} 42 b.WithName(name) 43 b.WithKind("ClusterTrustBundle") 44 b.WithAPIVersion("certificates.k8s.io/v1alpha1") 45 return b 46 } 47 48 // ExtractClusterTrustBundle extracts the applied configuration owned by fieldManager from 49 // clusterTrustBundle. If no managedFields are found in clusterTrustBundle for fieldManager, a 50 // ClusterTrustBundleApplyConfiguration is returned with only the Name, Namespace (if applicable), 51 // APIVersion and Kind populated. It is possible that no managed fields were found for because other 52 // field managers have taken ownership of all the fields previously owned by fieldManager, or because 53 // the fieldManager never owned fields any fields. 54 // clusterTrustBundle must be a unmodified ClusterTrustBundle API object that was retrieved from the Kubernetes API. 55 // ExtractClusterTrustBundle provides a way to perform a extract/modify-in-place/apply workflow. 56 // Note that an extracted apply configuration will contain fewer fields than what the fieldManager previously 57 // applied if another fieldManager has updated or force applied any of the previously applied fields. 58 // Experimental! 59 func ExtractClusterTrustBundle(clusterTrustBundle *certificatesv1alpha1.ClusterTrustBundle, fieldManager string) (*ClusterTrustBundleApplyConfiguration, error) { 60 return extractClusterTrustBundle(clusterTrustBundle, fieldManager, "") 61 } 62 63 // ExtractClusterTrustBundleStatus is the same as ExtractClusterTrustBundle except 64 // that it extracts the status subresource applied configuration. 65 // Experimental! 66 func ExtractClusterTrustBundleStatus(clusterTrustBundle *certificatesv1alpha1.ClusterTrustBundle, fieldManager string) (*ClusterTrustBundleApplyConfiguration, error) { 67 return extractClusterTrustBundle(clusterTrustBundle, fieldManager, "status") 68 } 69 70 func extractClusterTrustBundle(clusterTrustBundle *certificatesv1alpha1.ClusterTrustBundle, fieldManager string, subresource string) (*ClusterTrustBundleApplyConfiguration, error) { 71 b := &ClusterTrustBundleApplyConfiguration{} 72 err := managedfields.ExtractInto(clusterTrustBundle, internal.Parser().Type("io.k8s.api.certificates.v1alpha1.ClusterTrustBundle"), fieldManager, b, subresource) 73 if err != nil { 74 return nil, err 75 } 76 b.WithName(clusterTrustBundle.Name) 77 78 b.WithKind("ClusterTrustBundle") 79 b.WithAPIVersion("certificates.k8s.io/v1alpha1") 80 return b, nil 81 } 82 83 // WithKind sets the Kind field in the declarative configuration to the given value 84 // and returns the receiver, so that objects can be built by chaining "With" function invocations. 85 // If called multiple times, the Kind field is set to the value of the last call. 86 func (b *ClusterTrustBundleApplyConfiguration) WithKind(value string) *ClusterTrustBundleApplyConfiguration { 87 b.Kind = &value 88 return b 89 } 90 91 // WithAPIVersion sets the APIVersion field in the declarative configuration to the given value 92 // and returns the receiver, so that objects can be built by chaining "With" function invocations. 93 // If called multiple times, the APIVersion field is set to the value of the last call. 94 func (b *ClusterTrustBundleApplyConfiguration) WithAPIVersion(value string) *ClusterTrustBundleApplyConfiguration { 95 b.APIVersion = &value 96 return b 97 } 98 99 // WithName sets the Name field in the declarative configuration to the given value 100 // and returns the receiver, so that objects can be built by chaining "With" function invocations. 101 // If called multiple times, the Name field is set to the value of the last call. 102 func (b *ClusterTrustBundleApplyConfiguration) WithName(value string) *ClusterTrustBundleApplyConfiguration { 103 b.ensureObjectMetaApplyConfigurationExists() 104 b.Name = &value 105 return b 106 } 107 108 // WithGenerateName sets the GenerateName field in the declarative configuration to the given value 109 // and returns the receiver, so that objects can be built by chaining "With" function invocations. 110 // If called multiple times, the GenerateName field is set to the value of the last call. 111 func (b *ClusterTrustBundleApplyConfiguration) WithGenerateName(value string) *ClusterTrustBundleApplyConfiguration { 112 b.ensureObjectMetaApplyConfigurationExists() 113 b.GenerateName = &value 114 return b 115 } 116 117 // WithNamespace sets the Namespace field in the declarative configuration to the given value 118 // and returns the receiver, so that objects can be built by chaining "With" function invocations. 119 // If called multiple times, the Namespace field is set to the value of the last call. 120 func (b *ClusterTrustBundleApplyConfiguration) WithNamespace(value string) *ClusterTrustBundleApplyConfiguration { 121 b.ensureObjectMetaApplyConfigurationExists() 122 b.Namespace = &value 123 return b 124 } 125 126 // WithUID sets the UID field in the declarative configuration to the given value 127 // and returns the receiver, so that objects can be built by chaining "With" function invocations. 128 // If called multiple times, the UID field is set to the value of the last call. 129 func (b *ClusterTrustBundleApplyConfiguration) WithUID(value types.UID) *ClusterTrustBundleApplyConfiguration { 130 b.ensureObjectMetaApplyConfigurationExists() 131 b.UID = &value 132 return b 133 } 134 135 // WithResourceVersion sets the ResourceVersion field in the declarative configuration to the given value 136 // and returns the receiver, so that objects can be built by chaining "With" function invocations. 137 // If called multiple times, the ResourceVersion field is set to the value of the last call. 138 func (b *ClusterTrustBundleApplyConfiguration) WithResourceVersion(value string) *ClusterTrustBundleApplyConfiguration { 139 b.ensureObjectMetaApplyConfigurationExists() 140 b.ResourceVersion = &value 141 return b 142 } 143 144 // WithGeneration sets the Generation field in the declarative configuration to the given value 145 // and returns the receiver, so that objects can be built by chaining "With" function invocations. 146 // If called multiple times, the Generation field is set to the value of the last call. 147 func (b *ClusterTrustBundleApplyConfiguration) WithGeneration(value int64) *ClusterTrustBundleApplyConfiguration { 148 b.ensureObjectMetaApplyConfigurationExists() 149 b.Generation = &value 150 return b 151 } 152 153 // WithCreationTimestamp sets the CreationTimestamp field in the declarative configuration to the given value 154 // and returns the receiver, so that objects can be built by chaining "With" function invocations. 155 // If called multiple times, the CreationTimestamp field is set to the value of the last call. 156 func (b *ClusterTrustBundleApplyConfiguration) WithCreationTimestamp(value metav1.Time) *ClusterTrustBundleApplyConfiguration { 157 b.ensureObjectMetaApplyConfigurationExists() 158 b.CreationTimestamp = &value 159 return b 160 } 161 162 // WithDeletionTimestamp sets the DeletionTimestamp field in the declarative configuration to the given value 163 // and returns the receiver, so that objects can be built by chaining "With" function invocations. 164 // If called multiple times, the DeletionTimestamp field is set to the value of the last call. 165 func (b *ClusterTrustBundleApplyConfiguration) WithDeletionTimestamp(value metav1.Time) *ClusterTrustBundleApplyConfiguration { 166 b.ensureObjectMetaApplyConfigurationExists() 167 b.DeletionTimestamp = &value 168 return b 169 } 170 171 // WithDeletionGracePeriodSeconds sets the DeletionGracePeriodSeconds field in the declarative configuration to the given value 172 // and returns the receiver, so that objects can be built by chaining "With" function invocations. 173 // If called multiple times, the DeletionGracePeriodSeconds field is set to the value of the last call. 174 func (b *ClusterTrustBundleApplyConfiguration) WithDeletionGracePeriodSeconds(value int64) *ClusterTrustBundleApplyConfiguration { 175 b.ensureObjectMetaApplyConfigurationExists() 176 b.DeletionGracePeriodSeconds = &value 177 return b 178 } 179 180 // WithLabels puts the entries into the Labels field in the declarative configuration 181 // and returns the receiver, so that objects can be build by chaining "With" function invocations. 182 // If called multiple times, the entries provided by each call will be put on the Labels field, 183 // overwriting an existing map entries in Labels field with the same key. 184 func (b *ClusterTrustBundleApplyConfiguration) WithLabels(entries map[string]string) *ClusterTrustBundleApplyConfiguration { 185 b.ensureObjectMetaApplyConfigurationExists() 186 if b.Labels == nil && len(entries) > 0 { 187 b.Labels = make(map[string]string, len(entries)) 188 } 189 for k, v := range entries { 190 b.Labels[k] = v 191 } 192 return b 193 } 194 195 // WithAnnotations puts the entries into the Annotations field in the declarative configuration 196 // and returns the receiver, so that objects can be build by chaining "With" function invocations. 197 // If called multiple times, the entries provided by each call will be put on the Annotations field, 198 // overwriting an existing map entries in Annotations field with the same key. 199 func (b *ClusterTrustBundleApplyConfiguration) WithAnnotations(entries map[string]string) *ClusterTrustBundleApplyConfiguration { 200 b.ensureObjectMetaApplyConfigurationExists() 201 if b.Annotations == nil && len(entries) > 0 { 202 b.Annotations = make(map[string]string, len(entries)) 203 } 204 for k, v := range entries { 205 b.Annotations[k] = v 206 } 207 return b 208 } 209 210 // WithOwnerReferences adds the given value to the OwnerReferences field in the declarative configuration 211 // and returns the receiver, so that objects can be build by chaining "With" function invocations. 212 // If called multiple times, values provided by each call will be appended to the OwnerReferences field. 213 func (b *ClusterTrustBundleApplyConfiguration) WithOwnerReferences(values ...*v1.OwnerReferenceApplyConfiguration) *ClusterTrustBundleApplyConfiguration { 214 b.ensureObjectMetaApplyConfigurationExists() 215 for i := range values { 216 if values[i] == nil { 217 panic("nil value passed to WithOwnerReferences") 218 } 219 b.OwnerReferences = append(b.OwnerReferences, *values[i]) 220 } 221 return b 222 } 223 224 // WithFinalizers adds the given value to the Finalizers field in the declarative configuration 225 // and returns the receiver, so that objects can be build by chaining "With" function invocations. 226 // If called multiple times, values provided by each call will be appended to the Finalizers field. 227 func (b *ClusterTrustBundleApplyConfiguration) WithFinalizers(values ...string) *ClusterTrustBundleApplyConfiguration { 228 b.ensureObjectMetaApplyConfigurationExists() 229 for i := range values { 230 b.Finalizers = append(b.Finalizers, values[i]) 231 } 232 return b 233 } 234 235 func (b *ClusterTrustBundleApplyConfiguration) ensureObjectMetaApplyConfigurationExists() { 236 if b.ObjectMetaApplyConfiguration == nil { 237 b.ObjectMetaApplyConfiguration = &v1.ObjectMetaApplyConfiguration{} 238 } 239 } 240 241 // WithSpec sets the Spec field in the declarative configuration to the given value 242 // and returns the receiver, so that objects can be built by chaining "With" function invocations. 243 // If called multiple times, the Spec field is set to the value of the last call. 244 func (b *ClusterTrustBundleApplyConfiguration) WithSpec(value *ClusterTrustBundleSpecApplyConfiguration) *ClusterTrustBundleApplyConfiguration { 245 b.Spec = value 246 return b 247 } 248