12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- /*
- Copyright 2016 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 master
- import (
- "k8s.io/kubernetes/pkg/api/rest"
- "k8s.io/kubernetes/pkg/apis/authorization"
- authorizationv1beta1 "k8s.io/kubernetes/pkg/apis/authorization/v1beta1"
- "k8s.io/kubernetes/pkg/auth/authorizer"
- "k8s.io/kubernetes/pkg/genericapiserver"
- "k8s.io/kubernetes/pkg/registry/authorization/subjectaccessreview"
- )
- type AuthorizationRESTStorageProvider struct {
- Authorizer authorizer.Authorizer
- }
- var _ RESTStorageProvider = &AuthorizationRESTStorageProvider{}
- func (p AuthorizationRESTStorageProvider) NewRESTStorage(apiResourceConfigSource genericapiserver.APIResourceConfigSource, restOptionsGetter RESTOptionsGetter) (genericapiserver.APIGroupInfo, bool) {
- if p.Authorizer == nil {
- return genericapiserver.APIGroupInfo{}, false
- }
- apiGroupInfo := genericapiserver.NewDefaultAPIGroupInfo(authorization.GroupName)
- if apiResourceConfigSource.AnyResourcesForVersionEnabled(authorizationv1beta1.SchemeGroupVersion) {
- apiGroupInfo.VersionedResourcesStorageMap[authorizationv1beta1.SchemeGroupVersion.Version] = p.v1beta1Storage(apiResourceConfigSource, restOptionsGetter)
- apiGroupInfo.GroupMeta.GroupVersion = authorizationv1beta1.SchemeGroupVersion
- }
- return apiGroupInfo, true
- }
- func (p AuthorizationRESTStorageProvider) v1beta1Storage(apiResourceConfigSource genericapiserver.APIResourceConfigSource, restOptionsGetter RESTOptionsGetter) map[string]rest.Storage {
- version := authorizationv1beta1.SchemeGroupVersion
- storage := map[string]rest.Storage{}
- if apiResourceConfigSource.ResourceEnabled(version.WithResource("subjectaccessreviews")) {
- storage["subjectaccessreviews"] = subjectaccessreview.NewREST(p.Authorizer)
- }
- return storage
- }
|