forked from kubernetes-sigs/controller-runtime
-
Notifications
You must be signed in to change notification settings - Fork 0
/
handler.go
72 lines (57 loc) · 2.16 KB
/
handler.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
/*
Copyright 2017 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 admission
import (
"net/http"
"k8s.io/api/admission/v1beta1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
)
// Func implements an AdmissionReview operation for a GroupVersionResource
type Func func(review v1beta1.AdmissionReview) *v1beta1.AdmissionResponse
// HandleEntry
type admissionHandler struct {
GVR metav1.GroupVersionResource
Fn Func
}
// handle handles an admission request and returns a result
func (ah admissionHandler) handle(review v1beta1.AdmissionReview) *v1beta1.AdmissionResponse {
return ah.handle(review)
}
// Manager manages admission controllers
type Manager struct {
Entries map[string]admissionHandler
SMux *http.ServeMux
}
// DefaultAdmissionFns is the default admission control functions registry
var DefaultAdmissionFns = &Manager{
SMux: http.DefaultServeMux,
}
// HandleFunc registers fn as an admission control webhook callback for the group,version,resources specified
func (e *Manager) HandleFunc(path string, gvr metav1.GroupVersionResource, fn Func) {
// Register the entry so a Webhook config is created
e.Entries[path] = admissionHandler{gvr, fn}
// Register the handler path
e.SMux.Handle(path, httpHandler{fn})
}
// HandleFunc registers fn as an admission control webhook callback for the group,version,resources specified
func HandleFunc(path string, gvr metav1.GroupVersionResource, fn Func) {
DefaultAdmissionFns.HandleFunc(path, gvr, fn)
}
// ListenAndServeTLS starts the admission HttpServer.
func ListenAndServeTLS(addr string) error {
server := &http.Server{
Addr: addr,
TLSConfig: nil, // TODO: Set this
}
return server.ListenAndServeTLS("", "")
}