forked from openshift/origin
-
Notifications
You must be signed in to change notification settings - Fork 0
/
admission.go
103 lines (92 loc) · 3.37 KB
/
admission.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
package overrides
import (
"io"
"github.com/golang/glog"
"k8s.io/kubernetes/pkg/admission"
kapi "k8s.io/kubernetes/pkg/api"
clientset "k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset"
buildadmission "github.com/openshift/origin/pkg/build/admission"
overridesapi "github.com/openshift/origin/pkg/build/admission/overrides/api"
)
func init() {
admission.RegisterPlugin("BuildOverrides", func(c clientset.Interface, config io.Reader) (admission.Interface, error) {
overridesConfig, err := getConfig(config)
if err != nil {
return nil, err
}
glog.V(5).Infof("Initializing BuildOverrides plugin with config: %#v", overridesConfig)
return NewBuildOverrides(overridesConfig), nil
})
}
func getConfig(in io.Reader) (*overridesapi.BuildOverridesConfig, error) {
overridesConfig := &overridesapi.BuildOverridesConfig{}
err := buildadmission.ReadPluginConfig(in, overridesConfig)
if err != nil {
return nil, err
}
return overridesConfig, nil
}
type buildOverrides struct {
*admission.Handler
overridesConfig *overridesapi.BuildOverridesConfig
}
// NewBuildOverrides returns an admission control for builds that overrides
// settings on builds
func NewBuildOverrides(overridesConfig *overridesapi.BuildOverridesConfig) admission.Interface {
return &buildOverrides{
Handler: admission.NewHandler(admission.Create, admission.Update),
overridesConfig: overridesConfig,
}
}
// Admit appplies configured overrides to a build in a build pod
func (a *buildOverrides) Admit(attributes admission.Attributes) error {
if a.overridesConfig == nil {
return nil
}
if !buildadmission.IsBuildPod(attributes) {
return nil
}
return a.applyOverrides(attributes)
}
func (a *buildOverrides) applyOverrides(attributes admission.Attributes) error {
if !a.overridesConfig.ForcePull {
return nil
}
build, version, err := buildadmission.GetBuild(attributes)
if err != nil {
return err
}
glog.V(4).Infof("Handling build %s/%s", build.Namespace, build.Name)
if build.Spec.Strategy.DockerStrategy != nil {
glog.V(5).Infof("Setting docker strategy ForcePull to true in build %s/%s", build.Namespace, build.Name)
build.Spec.Strategy.DockerStrategy.ForcePull = true
}
if build.Spec.Strategy.SourceStrategy != nil {
glog.V(5).Infof("Setting source strategy ForcePull to true in build %s/%s", build.Namespace, build.Name)
build.Spec.Strategy.SourceStrategy.ForcePull = true
}
if build.Spec.Strategy.CustomStrategy != nil {
err := applyForcePullToPod(attributes)
if err != nil {
return err
}
glog.V(5).Infof("Setting custom strategy ForcePull to true in build %s/%s", build.Namespace, build.Name)
build.Spec.Strategy.CustomStrategy.ForcePull = true
}
return buildadmission.SetBuild(attributes, build, version)
}
func applyForcePullToPod(attributes admission.Attributes) error {
pod, err := buildadmission.GetPod(attributes)
if err != nil {
return err
}
for i := range pod.Spec.InitContainers {
glog.V(5).Infof("Setting ImagePullPolicy to PullAlways on init container %s of pod %s/%s", pod.Spec.InitContainers[i].Name, pod.Namespace, pod.Name)
pod.Spec.InitContainers[i].ImagePullPolicy = kapi.PullAlways
}
for i := range pod.Spec.Containers {
glog.V(5).Infof("Setting ImagePullPolicy to PullAlways on container %s of pod %s/%s", pod.Spec.Containers[i].Name, pod.Namespace, pod.Name)
pod.Spec.Containers[i].ImagePullPolicy = kapi.PullAlways
}
return nil
}