123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226 |
- /*
- Copyright 2016 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.
- */
- package v1beta2
- import (
- "fmt"
- "strconv"
- appsv1beta2 "k8s.io/api/apps/v1beta2"
- corev1 "k8s.io/api/core/v1"
- metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
- "k8s.io/apimachinery/pkg/conversion"
- "k8s.io/apimachinery/pkg/labels"
- "k8s.io/apimachinery/pkg/runtime"
- "k8s.io/kubernetes/pkg/apis/apps"
- autoscaling "k8s.io/kubernetes/pkg/apis/autoscaling"
- "k8s.io/kubernetes/pkg/apis/core"
- )
- func addConversionFuncs(scheme *runtime.Scheme) error {
- // Add field label conversions for kinds having selectable nothing but ObjectMeta fields.
- if err := scheme.AddFieldLabelConversionFunc(SchemeGroupVersion.WithKind("StatefulSet"),
- func(label, value string) (string, string, error) {
- switch label {
- case "metadata.name", "metadata.namespace", "status.successful":
- return label, value, nil
- default:
- return "", "", fmt.Errorf("field label not supported for appsv1beta2.StatefulSet: %s", label)
- }
- }); err != nil {
- return err
- }
- return nil
- }
- func Convert_autoscaling_ScaleStatus_To_v1beta2_ScaleStatus(in *autoscaling.ScaleStatus, out *appsv1beta2.ScaleStatus, s conversion.Scope) error {
- out.Replicas = int32(in.Replicas)
- out.TargetSelector = in.Selector
- out.Selector = nil
- selector, err := metav1.ParseToLabelSelector(in.Selector)
- if err != nil {
- return fmt.Errorf("failed to parse selector: %v", err)
- }
- if len(selector.MatchExpressions) == 0 {
- out.Selector = selector.MatchLabels
- }
- return nil
- }
- func Convert_v1beta2_ScaleStatus_To_autoscaling_ScaleStatus(in *appsv1beta2.ScaleStatus, out *autoscaling.ScaleStatus, s conversion.Scope) error {
- out.Replicas = in.Replicas
- // Normally when 2 fields map to the same internal value we favor the old field, since
- // old clients can't be expected to know about new fields but clients that know about the
- // new field can be expected to know about the old field (though that's not quite true, due
- // to kubectl apply). However, these fields are readonly, so any non-nil value should work.
- if in.TargetSelector != "" {
- out.Selector = in.TargetSelector
- } else if in.Selector != nil {
- set := labels.Set{}
- for key, val := range in.Selector {
- set[key] = val
- }
- out.Selector = labels.SelectorFromSet(set).String()
- } else {
- out.Selector = ""
- }
- return nil
- }
- // Convert_apps_DeploymentSpec_To_v1beta2_DeploymentSpec is defined here, because public
- // conversion is not auto-generated due to existing warnings.
- func Convert_apps_DeploymentSpec_To_v1beta2_DeploymentSpec(in *apps.DeploymentSpec, out *appsv1beta2.DeploymentSpec, s conversion.Scope) error {
- if err := autoConvert_apps_DeploymentSpec_To_v1beta2_DeploymentSpec(in, out, s); err != nil {
- return err
- }
- return nil
- }
- func Convert_v1beta2_Deployment_To_apps_Deployment(in *appsv1beta2.Deployment, out *apps.Deployment, s conversion.Scope) error {
- if err := autoConvert_v1beta2_Deployment_To_apps_Deployment(in, out, s); err != nil {
- return err
- }
- // Copy annotation to deprecated rollbackTo field for roundtrip
- // TODO: remove this conversion after we delete extensions/v1beta1 and apps/v1beta1 Deployment
- if revision := in.Annotations[appsv1beta2.DeprecatedRollbackTo]; revision != "" {
- if revision64, err := strconv.ParseInt(revision, 10, 64); err != nil {
- return fmt.Errorf("failed to parse annotation[%s]=%s as int64: %v", appsv1beta2.DeprecatedRollbackTo, revision, err)
- } else {
- out.Spec.RollbackTo = new(apps.RollbackConfig)
- out.Spec.RollbackTo.Revision = revision64
- }
- out.Annotations = deepCopyStringMap(out.Annotations)
- delete(out.Annotations, appsv1beta2.DeprecatedRollbackTo)
- } else {
- out.Spec.RollbackTo = nil
- }
- return nil
- }
- func Convert_apps_Deployment_To_v1beta2_Deployment(in *apps.Deployment, out *appsv1beta2.Deployment, s conversion.Scope) error {
- if err := autoConvert_apps_Deployment_To_v1beta2_Deployment(in, out, s); err != nil {
- return err
- }
- out.Annotations = deepCopyStringMap(out.Annotations) // deep copy because we modify annotations below
- // Copy deprecated rollbackTo field to annotation for roundtrip
- // TODO: remove this conversion after we delete extensions/v1beta1 and apps/v1beta1 Deployment
- if in.Spec.RollbackTo != nil {
- if out.Annotations == nil {
- out.Annotations = make(map[string]string)
- }
- out.Annotations[appsv1beta2.DeprecatedRollbackTo] = strconv.FormatInt(in.Spec.RollbackTo.Revision, 10)
- } else {
- delete(out.Annotations, appsv1beta2.DeprecatedRollbackTo)
- }
- return nil
- }
- func Convert_apps_DaemonSet_To_v1beta2_DaemonSet(in *apps.DaemonSet, out *appsv1beta2.DaemonSet, s conversion.Scope) error {
- if err := autoConvert_apps_DaemonSet_To_v1beta2_DaemonSet(in, out, s); err != nil {
- return err
- }
- out.Annotations = deepCopyStringMap(out.Annotations)
- out.Annotations[appsv1beta2.DeprecatedTemplateGeneration] = strconv.FormatInt(in.Spec.TemplateGeneration, 10)
- return nil
- }
- // Convert_apps_DaemonSetSpec_To_v1beta2_DaemonSetSpec is defined here, because public
- // conversion is not auto-generated due to existing warnings.
- func Convert_apps_DaemonSetSpec_To_v1beta2_DaemonSetSpec(in *apps.DaemonSetSpec, out *appsv1beta2.DaemonSetSpec, s conversion.Scope) error {
- if err := autoConvert_apps_DaemonSetSpec_To_v1beta2_DaemonSetSpec(in, out, s); err != nil {
- return err
- }
- return nil
- }
- func Convert_v1beta2_DaemonSet_To_apps_DaemonSet(in *appsv1beta2.DaemonSet, out *apps.DaemonSet, s conversion.Scope) error {
- if err := autoConvert_v1beta2_DaemonSet_To_apps_DaemonSet(in, out, s); err != nil {
- return err
- }
- if value, ok := in.Annotations[appsv1beta2.DeprecatedTemplateGeneration]; ok {
- if value64, err := strconv.ParseInt(value, 10, 64); err != nil {
- return err
- } else {
- out.Spec.TemplateGeneration = value64
- out.Annotations = deepCopyStringMap(out.Annotations)
- delete(out.Annotations, appsv1beta2.DeprecatedTemplateGeneration)
- }
- }
- return nil
- }
- func deepCopyStringMap(m map[string]string) map[string]string {
- ret := make(map[string]string, len(m))
- for k, v := range m {
- ret[k] = v
- }
- return ret
- }
- // Convert_v1beta2_StatefulSetSpec_To_apps_StatefulSetSpec augments auto-conversion to preserve < 1.17 behavior
- // setting apiVersion/kind in nested persistent volume claim objects.
- func Convert_v1beta2_StatefulSetSpec_To_apps_StatefulSetSpec(in *appsv1beta2.StatefulSetSpec, out *apps.StatefulSetSpec, s conversion.Scope) error {
- if err := autoConvert_v1beta2_StatefulSetSpec_To_apps_StatefulSetSpec(in, out, s); err != nil {
- return err
- }
- // set APIVersion/Kind to behave the same as reflective conversion < 1.17.
- // see http://issue.k8s.io/87583
- if out.VolumeClaimTemplates != nil {
- // copy so we don't modify the input
- templatesCopy := make([]core.PersistentVolumeClaim, len(out.VolumeClaimTemplates))
- copy(templatesCopy, out.VolumeClaimTemplates)
- out.VolumeClaimTemplates = templatesCopy
- for i := range out.VolumeClaimTemplates {
- out.VolumeClaimTemplates[i].APIVersion = ""
- out.VolumeClaimTemplates[i].Kind = ""
- }
- }
- return nil
- }
- // Convert_apps_StatefulSetSpec_To_v1beta2_StatefulSetSpec augments auto-conversion to preserve < 1.17 behavior
- // setting apiVersion/kind in nested persistent volume claim objects.
- func Convert_apps_StatefulSetSpec_To_v1beta2_StatefulSetSpec(in *apps.StatefulSetSpec, out *appsv1beta2.StatefulSetSpec, s conversion.Scope) error {
- if err := autoConvert_apps_StatefulSetSpec_To_v1beta2_StatefulSetSpec(in, out, s); err != nil {
- return err
- }
- // set APIVersion/Kind to behave the same as reflective conversion < 1.17.
- // see http://issue.k8s.io/87583
- if out.VolumeClaimTemplates != nil {
- // copy so we don't modify the input
- templatesCopy := make([]corev1.PersistentVolumeClaim, len(out.VolumeClaimTemplates))
- copy(templatesCopy, out.VolumeClaimTemplates)
- out.VolumeClaimTemplates = templatesCopy
- for i := range out.VolumeClaimTemplates {
- out.VolumeClaimTemplates[i].APIVersion = "v1"
- out.VolumeClaimTemplates[i].Kind = "PersistentVolumeClaim"
- }
- }
- return nil
- }
|