/
kube_daemonset_to_koki_daemonset.go
125 lines (98 loc) · 4.33 KB
/
kube_daemonset_to_koki_daemonset.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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
package converters
import (
appsv1beta2 "k8s.io/api/apps/v1beta2"
"k8s.io/apimachinery/pkg/runtime"
intstr "k8s.io/apimachinery/pkg/util/intstr"
"github.com/koki/short/parser"
"github.com/koki/short/types"
"github.com/koki/short/yaml"
serrors "github.com/koki/structurederrors"
)
func Convert_Kube_DaemonSet_to_Koki_DaemonSet(kubeDaemonSet runtime.Object) (*types.DaemonSetWrapper, error) {
groupVersionKind := kubeDaemonSet.GetObjectKind().GroupVersionKind()
groupVersionString := groupVersionKind.GroupVersion().String()
groupVersionKind.Version = "v1beta2"
groupVersionKind.Group = "apps"
kubeDaemonSet.GetObjectKind().SetGroupVersionKind(groupVersionKind)
// Serialize as v1beta2
b, err := yaml.Marshal(kubeDaemonSet)
if err != nil {
return nil, serrors.InvalidInstanceContextErrorf(err, kubeDaemonSet, "couldn't serialize kube DaemonSet after setting apiVersion to apps/v1beta2")
}
// Deserialize the "generic" kube DaemonSet
genericDaemonSet, err := parser.ParseSingleKubeNativeFromBytes(b)
if err != nil {
return nil, serrors.InvalidInstanceContextErrorf(err, string(b), "couldn't deserialize 'generic' kube DaemonSet")
}
if genericDaemonSet, ok := genericDaemonSet.(*appsv1beta2.DaemonSet); ok {
kokiWrapper, err := Convert_Kube_v1beta2_DaemonSet_to_Koki_DaemonSet(genericDaemonSet)
if err != nil {
return nil, err
}
kokiDaemonSet := &kokiWrapper.DaemonSet
kokiDaemonSet.Version = groupVersionString
// Perform version-specific initialization here.
return kokiWrapper, nil
}
return nil, serrors.InvalidInstanceErrorf(genericDaemonSet, "didn't deserialize 'generic' kube DaemonSet as apps/v1beta2.DaemonSet")
}
func Convert_Kube_v1beta2_DaemonSet_to_Koki_DaemonSet(kubeDaemonSet *appsv1beta2.DaemonSet) (*types.DaemonSetWrapper, error) {
kokiDaemonSet := &types.DaemonSet{}
kokiDaemonSet.Name = kubeDaemonSet.Name
kokiDaemonSet.Namespace = kubeDaemonSet.Namespace
kokiDaemonSet.Version = kubeDaemonSet.APIVersion
kokiDaemonSet.Cluster = kubeDaemonSet.ClusterName
kokiDaemonSet.Labels = kubeDaemonSet.Labels
kokiDaemonSet.Annotations = kubeDaemonSet.Annotations
kubeSpec := &kubeDaemonSet.Spec
// Setting the Selector and Template is identical to ReplicaSet
// Fill out the Selector and Template.Labels.
// If kubeDaemonSet only has Template.Labels, we pull it up to Selector.
selector, templateLabelsOverride, err := convertRSLabelSelector(kubeSpec.Selector, kubeSpec.Template.Labels)
if err != nil {
return nil, err
}
if selector != nil && (selector.Labels != nil || selector.Shorthand != "") {
kokiDaemonSet.Selector = selector
}
// Build a Pod from the kube Template. Use it to set the koki Template.
meta, template, err := convertTemplate(kubeSpec.Template)
if err != nil {
return nil, serrors.ContextualizeErrorf(err, "pod template")
}
kokiDaemonSet.TemplateMetadata = applyTemplateLabelsOverride(templateLabelsOverride, meta)
kokiDaemonSet.PodTemplate = template
// End Selector/Template section.
kokiDaemonSet.OnDelete, kokiDaemonSet.MaxUnavailable = convertDaemonSetStrategy(kubeSpec.UpdateStrategy)
kokiDaemonSet.MinReadySeconds = kubeSpec.MinReadySeconds
kokiDaemonSet.RevisionHistoryLimit = kubeSpec.RevisionHistoryLimit
kokiDaemonSet.DaemonSetStatus, err = convertDaemonSetStatus(kubeDaemonSet.Status)
if err != nil {
return nil, err
}
return &types.DaemonSetWrapper{
DaemonSet: *kokiDaemonSet,
}, nil
}
func convertDaemonSetStatus(kubeStatus appsv1beta2.DaemonSetStatus) (types.DaemonSetStatus, error) {
return types.DaemonSetStatus{
ObservedGeneration: kubeStatus.ObservedGeneration,
NumNodesScheduled: kubeStatus.CurrentNumberScheduled,
NumNodesMisscheduled: kubeStatus.NumberMisscheduled,
NumNodesDesired: kubeStatus.DesiredNumberScheduled,
NumReady: kubeStatus.NumberReady,
NumUpdated: kubeStatus.UpdatedNumberScheduled,
NumAvailable: kubeStatus.NumberAvailable,
NumUnavailable: kubeStatus.NumberUnavailable,
CollisionCount: kubeStatus.CollisionCount,
}, nil
}
func convertDaemonSetStrategy(kubeStrategy appsv1beta2.DaemonSetUpdateStrategy) (onDelete bool, maxUnavailable *intstr.IntOrString) {
if kubeStrategy.Type == appsv1beta2.OnDeleteDaemonSetStrategyType {
return true, nil
}
if rollingUpdate := kubeStrategy.RollingUpdate; rollingUpdate != nil {
return false, rollingUpdate.MaxUnavailable
}
return false, nil
}