...
1
16
17 package deny
18
19 import (
20 "context"
21 "errors"
22 "io"
23
24 "k8s.io/klog/v2"
25
26 "k8s.io/apiserver/pkg/admission"
27 )
28
29
30 const PluginName = "AlwaysDeny"
31
32
33 func Register(plugins *admission.Plugins) {
34 plugins.Register(PluginName, func(config io.Reader) (admission.Interface, error) {
35 return NewAlwaysDeny(), nil
36 })
37 }
38
39
40 type alwaysDeny struct{}
41
42 var _ admission.MutationInterface = alwaysDeny{}
43 var _ admission.ValidationInterface = alwaysDeny{}
44
45
46 func (alwaysDeny) Admit(ctx context.Context, a admission.Attributes, o admission.ObjectInterfaces) (err error) {
47 return admission.NewForbidden(a, errors.New("admission control is denying all modifications"))
48 }
49
50
51 func (alwaysDeny) Validate(ctx context.Context, a admission.Attributes, o admission.ObjectInterfaces) (err error) {
52 return admission.NewForbidden(a, errors.New("admission control is denying all modifications"))
53 }
54
55
56
57 func (alwaysDeny) Handles(operation admission.Operation) bool {
58 return true
59 }
60
61
62 func NewAlwaysDeny() admission.Interface {
63
64 klog.Warningf("%s admission controller is deprecated. "+
65 "Please remove this controller from your configuration files and scripts.", PluginName)
66 return new(alwaysDeny)
67 }
68
View as plain text