From 4989e215f21b2e4080d21f61f9b3e2fb1779e8ff Mon Sep 17 00:00:00 2001 From: deads2k Date: Mon, 27 Mar 2017 16:12:17 -0400 Subject: [PATCH] handle registered third parties Kubernetes-commit: b512073457d02f326ac39d5774582a92c763c47f --- pkg/endpoints/discovery/group.go | 18 +++++++++++------- pkg/endpoints/discovery/version.go | 24 +++++++++++++++++------- 2 files changed, 28 insertions(+), 14 deletions(-) diff --git a/pkg/endpoints/discovery/group.go b/pkg/endpoints/discovery/group.go index 30b653d33..fd9798276 100644 --- a/pkg/endpoints/discovery/group.go +++ b/pkg/endpoints/discovery/group.go @@ -28,15 +28,15 @@ import ( "k8s.io/apiserver/pkg/endpoints/handlers/responsewriters" ) -// apiGroupHandler creates a webservice serving the supported versions, preferred version, and name +// APIGroupHandler creates a webservice serving the supported versions, preferred version, and name // of a group. E.g., such a web service will be registered at /apis/extensions. -type apiGroupHandler struct { +type APIGroupHandler struct { serializer runtime.NegotiatedSerializer group metav1.APIGroup } -func NewAPIGroupHandler(serializer runtime.NegotiatedSerializer, group metav1.APIGroup) *apiGroupHandler { +func NewAPIGroupHandler(serializer runtime.NegotiatedSerializer, group metav1.APIGroup) *APIGroupHandler { if keepUnversioned(group.Name) { // Because in release 1.1, /apis/extensions returns response with empty // APIVersion, we use stripVersionNegotiatedSerializer to keep the @@ -44,13 +44,13 @@ func NewAPIGroupHandler(serializer runtime.NegotiatedSerializer, group metav1.AP serializer = stripVersionNegotiatedSerializer{serializer} } - return &apiGroupHandler{ + return &APIGroupHandler{ serializer: serializer, group: group, } } -func (s *apiGroupHandler) WebService() *restful.WebService { +func (s *APIGroupHandler) WebService() *restful.WebService { mediaTypes, _ := negotiation.MediaTypesForSerializer(s.serializer) ws := new(restful.WebService) ws.Path(APIGroupPrefix + "/" + s.group.Name) @@ -65,6 +65,10 @@ func (s *apiGroupHandler) WebService() *restful.WebService { } // handle returns a handler which will return the api.GroupAndVersion of the group. -func (s *apiGroupHandler) handle(req *restful.Request, resp *restful.Response) { - responsewriters.WriteObjectNegotiated(s.serializer, schema.GroupVersion{}, resp.ResponseWriter, req.Request, http.StatusOK, &s.group) +func (s *APIGroupHandler) handle(req *restful.Request, resp *restful.Response) { + s.ServeHTTP(resp.ResponseWriter, req.Request) +} + +func (s *APIGroupHandler) ServeHTTP(w http.ResponseWriter, req *http.Request) { + responsewriters.WriteObjectNegotiated(s.serializer, schema.GroupVersion{}, w, req, http.StatusOK, &s.group) } diff --git a/pkg/endpoints/discovery/version.go b/pkg/endpoints/discovery/version.go index 93f0b34c6..93f95034a 100644 --- a/pkg/endpoints/discovery/version.go +++ b/pkg/endpoints/discovery/version.go @@ -32,16 +32,22 @@ type APIResourceLister interface { ListAPIResources() []metav1.APIResource } -// apiVersionHandler creates a webservice serving the supported resources for the version +type APIResourceListerFunc func() []metav1.APIResource + +func (f APIResourceListerFunc) ListAPIResources() []metav1.APIResource { + return f() +} + +// APIVersionHandler creates a webservice serving the supported resources for the version // E.g., such a web service will be registered at /apis/extensions/v1beta1. -type apiVersionHandler struct { +type APIVersionHandler struct { serializer runtime.NegotiatedSerializer groupVersion schema.GroupVersion apiResourceLister APIResourceLister } -func NewAPIVersionHandler(serializer runtime.NegotiatedSerializer, groupVersion schema.GroupVersion, apiResourceLister APIResourceLister) *apiVersionHandler { +func NewAPIVersionHandler(serializer runtime.NegotiatedSerializer, groupVersion schema.GroupVersion, apiResourceLister APIResourceLister) *APIVersionHandler { if keepUnversioned(groupVersion.Group) { // Because in release 1.1, /apis/extensions returns response with empty // APIVersion, we use stripVersionNegotiatedSerializer to keep the @@ -49,14 +55,14 @@ func NewAPIVersionHandler(serializer runtime.NegotiatedSerializer, groupVersion serializer = stripVersionNegotiatedSerializer{serializer} } - return &apiVersionHandler{ + return &APIVersionHandler{ serializer: serializer, groupVersion: groupVersion, apiResourceLister: apiResourceLister, } } -func (s *apiVersionHandler) AddToWebService(ws *restful.WebService) { +func (s *APIVersionHandler) AddToWebService(ws *restful.WebService) { mediaTypes, _ := negotiation.MediaTypesForSerializer(s.serializer) ws.Route(ws.GET("/").To(s.handle). Doc("get available resources"). @@ -67,7 +73,11 @@ func (s *apiVersionHandler) AddToWebService(ws *restful.WebService) { } // handle returns a handler which will return the api.VersionAndVersion of the group. -func (s *apiVersionHandler) handle(req *restful.Request, resp *restful.Response) { - responsewriters.WriteObjectNegotiated(s.serializer, schema.GroupVersion{}, resp.ResponseWriter, req.Request, http.StatusOK, +func (s *APIVersionHandler) handle(req *restful.Request, resp *restful.Response) { + s.ServeHTTP(resp.ResponseWriter, req.Request) +} + +func (s *APIVersionHandler) ServeHTTP(w http.ResponseWriter, req *http.Request) { + responsewriters.WriteObjectNegotiated(s.serializer, schema.GroupVersion{}, w, req, http.StatusOK, &metav1.APIResourceList{GroupVersion: s.groupVersion.String(), APIResources: s.apiResourceLister.ListAPIResources()}) }