2016-07-27 14:29:31 +00:00
|
|
|
/*
|
|
|
|
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.
|
|
|
|
*/
|
|
|
|
|
2016-09-23 19:10:47 +00:00
|
|
|
package rest
|
2016-07-27 14:29:31 +00:00
|
|
|
|
|
|
|
import (
|
2016-10-17 20:24:02 +00:00
|
|
|
"fmt"
|
2016-07-27 14:29:31 +00:00
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/golang/glog"
|
|
|
|
|
|
|
|
"k8s.io/kubernetes/pkg/api/rest"
|
|
|
|
"k8s.io/kubernetes/pkg/apis/extensions"
|
|
|
|
extensionsapiv1beta1 "k8s.io/kubernetes/pkg/apis/extensions/v1beta1"
|
2016-10-21 22:24:05 +00:00
|
|
|
extensionsclient "k8s.io/kubernetes/pkg/client/clientset_generated/internalclientset/typed/extensions/internalversion"
|
2016-07-27 14:29:31 +00:00
|
|
|
"k8s.io/kubernetes/pkg/genericapiserver"
|
2016-09-21 13:01:02 +00:00
|
|
|
horizontalpodautoscaleretcd "k8s.io/kubernetes/pkg/registry/autoscaling/horizontalpodautoscaler/etcd"
|
|
|
|
jobetcd "k8s.io/kubernetes/pkg/registry/batch/job/etcd"
|
2016-09-21 13:06:56 +00:00
|
|
|
expcontrolleretcd "k8s.io/kubernetes/pkg/registry/extensions/controller/etcd"
|
|
|
|
daemonetcd "k8s.io/kubernetes/pkg/registry/extensions/daemonset/etcd"
|
|
|
|
deploymentetcd "k8s.io/kubernetes/pkg/registry/extensions/deployment/etcd"
|
|
|
|
ingressetcd "k8s.io/kubernetes/pkg/registry/extensions/ingress/etcd"
|
|
|
|
networkpolicyetcd "k8s.io/kubernetes/pkg/registry/extensions/networkpolicy/etcd"
|
|
|
|
pspetcd "k8s.io/kubernetes/pkg/registry/extensions/podsecuritypolicy/etcd"
|
|
|
|
replicasetetcd "k8s.io/kubernetes/pkg/registry/extensions/replicaset/etcd"
|
|
|
|
thirdpartyresourceetcd "k8s.io/kubernetes/pkg/registry/extensions/thirdpartyresource/etcd"
|
2016-12-01 02:09:56 +00:00
|
|
|
"k8s.io/kubernetes/pkg/registry/generic"
|
2016-10-17 20:24:02 +00:00
|
|
|
utilruntime "k8s.io/kubernetes/pkg/util/runtime"
|
2016-07-27 14:29:31 +00:00
|
|
|
"k8s.io/kubernetes/pkg/util/wait"
|
|
|
|
)
|
|
|
|
|
2016-09-23 19:10:47 +00:00
|
|
|
type RESTStorageProvider struct {
|
2016-10-17 20:24:02 +00:00
|
|
|
ResourceInterface ResourceInterface
|
2016-07-27 14:29:31 +00:00
|
|
|
}
|
|
|
|
|
2016-12-01 02:09:56 +00:00
|
|
|
func (p RESTStorageProvider) NewRESTStorage(apiResourceConfigSource genericapiserver.APIResourceConfigSource, restOptionsGetter generic.RESTOptionsGetter) (genericapiserver.APIGroupInfo, bool) {
|
2016-07-27 14:29:31 +00:00
|
|
|
apiGroupInfo := genericapiserver.NewDefaultAPIGroupInfo(extensions.GroupName)
|
|
|
|
|
|
|
|
if apiResourceConfigSource.AnyResourcesForVersionEnabled(extensionsapiv1beta1.SchemeGroupVersion) {
|
|
|
|
apiGroupInfo.VersionedResourcesStorageMap[extensionsapiv1beta1.SchemeGroupVersion.Version] = p.v1beta1Storage(apiResourceConfigSource, restOptionsGetter)
|
|
|
|
apiGroupInfo.GroupMeta.GroupVersion = extensionsapiv1beta1.SchemeGroupVersion
|
|
|
|
}
|
|
|
|
|
|
|
|
return apiGroupInfo, true
|
|
|
|
}
|
|
|
|
|
2016-12-01 02:09:56 +00:00
|
|
|
func (p RESTStorageProvider) v1beta1Storage(apiResourceConfigSource genericapiserver.APIResourceConfigSource, restOptionsGetter generic.RESTOptionsGetter) map[string]rest.Storage {
|
2016-07-27 14:29:31 +00:00
|
|
|
version := extensionsapiv1beta1.SchemeGroupVersion
|
|
|
|
|
|
|
|
storage := map[string]rest.Storage{}
|
|
|
|
|
|
|
|
if apiResourceConfigSource.ResourceEnabled(version.WithResource("horizontalpodautoscalers")) {
|
2016-12-01 02:09:56 +00:00
|
|
|
hpaStorage, hpaStatusStorage := horizontalpodautoscaleretcd.NewREST(restOptionsGetter)
|
2016-07-27 14:29:31 +00:00
|
|
|
storage["horizontalpodautoscalers"] = hpaStorage
|
|
|
|
storage["horizontalpodautoscalers/status"] = hpaStatusStorage
|
|
|
|
|
2016-12-01 02:09:56 +00:00
|
|
|
controllerStorage := expcontrolleretcd.NewStorage(restOptionsGetter)
|
2016-07-27 14:29:31 +00:00
|
|
|
storage["replicationcontrollers"] = controllerStorage.ReplicationController
|
|
|
|
storage["replicationcontrollers/scale"] = controllerStorage.Scale
|
|
|
|
}
|
|
|
|
if apiResourceConfigSource.ResourceEnabled(version.WithResource("thirdpartyresources")) {
|
2016-12-01 02:09:56 +00:00
|
|
|
thirdPartyResourceStorage := thirdpartyresourceetcd.NewREST(restOptionsGetter)
|
2016-07-27 14:29:31 +00:00
|
|
|
storage["thirdpartyresources"] = thirdPartyResourceStorage
|
|
|
|
}
|
|
|
|
|
|
|
|
if apiResourceConfigSource.ResourceEnabled(version.WithResource("daemonsets")) {
|
2016-12-01 02:09:56 +00:00
|
|
|
daemonSetStorage, daemonSetStatusStorage := daemonetcd.NewREST(restOptionsGetter)
|
2016-07-27 14:29:31 +00:00
|
|
|
storage["daemonsets"] = daemonSetStorage
|
|
|
|
storage["daemonsets/status"] = daemonSetStatusStorage
|
|
|
|
}
|
|
|
|
if apiResourceConfigSource.ResourceEnabled(version.WithResource("deployments")) {
|
2016-12-01 02:09:56 +00:00
|
|
|
deploymentStorage := deploymentetcd.NewStorage(restOptionsGetter)
|
2016-07-27 14:29:31 +00:00
|
|
|
storage["deployments"] = deploymentStorage.Deployment
|
|
|
|
storage["deployments/status"] = deploymentStorage.Status
|
|
|
|
storage["deployments/rollback"] = deploymentStorage.Rollback
|
|
|
|
storage["deployments/scale"] = deploymentStorage.Scale
|
|
|
|
}
|
|
|
|
if apiResourceConfigSource.ResourceEnabled(version.WithResource("jobs")) {
|
2016-12-01 02:09:56 +00:00
|
|
|
jobsStorage, jobsStatusStorage := jobetcd.NewREST(restOptionsGetter)
|
2016-07-27 14:29:31 +00:00
|
|
|
storage["jobs"] = jobsStorage
|
|
|
|
storage["jobs/status"] = jobsStatusStorage
|
|
|
|
}
|
|
|
|
if apiResourceConfigSource.ResourceEnabled(version.WithResource("ingresses")) {
|
2016-12-01 02:09:56 +00:00
|
|
|
ingressStorage, ingressStatusStorage := ingressetcd.NewREST(restOptionsGetter)
|
2016-07-27 14:29:31 +00:00
|
|
|
storage["ingresses"] = ingressStorage
|
|
|
|
storage["ingresses/status"] = ingressStatusStorage
|
|
|
|
}
|
2016-12-01 02:09:56 +00:00
|
|
|
if apiResourceConfigSource.ResourceEnabled(version.WithResource("podsecuritypolicy")) || apiResourceConfigSource.ResourceEnabled(version.WithResource("podsecuritypolicies")) {
|
|
|
|
podSecurityExtensionsStorage := pspetcd.NewREST(restOptionsGetter)
|
2016-07-27 14:29:31 +00:00
|
|
|
storage["podSecurityPolicies"] = podSecurityExtensionsStorage
|
|
|
|
}
|
|
|
|
if apiResourceConfigSource.ResourceEnabled(version.WithResource("replicasets")) {
|
2016-12-01 02:09:56 +00:00
|
|
|
replicaSetStorage := replicasetetcd.NewStorage(restOptionsGetter)
|
2016-07-27 14:29:31 +00:00
|
|
|
storage["replicasets"] = replicaSetStorage.ReplicaSet
|
|
|
|
storage["replicasets/status"] = replicaSetStorage.Status
|
|
|
|
storage["replicasets/scale"] = replicaSetStorage.Scale
|
|
|
|
}
|
|
|
|
if apiResourceConfigSource.ResourceEnabled(version.WithResource("networkpolicies")) {
|
2016-12-01 02:09:56 +00:00
|
|
|
networkExtensionsStorage := networkpolicyetcd.NewREST(restOptionsGetter)
|
2016-07-27 14:29:31 +00:00
|
|
|
storage["networkpolicies"] = networkExtensionsStorage
|
|
|
|
}
|
|
|
|
|
|
|
|
return storage
|
|
|
|
}
|
2016-10-17 20:24:02 +00:00
|
|
|
|
|
|
|
func (p RESTStorageProvider) PostStartHook() (string, genericapiserver.PostStartHookFunc, error) {
|
|
|
|
return "extensions/third-party-resources", p.postStartHookFunc, nil
|
|
|
|
}
|
|
|
|
func (p RESTStorageProvider) postStartHookFunc(hookContext genericapiserver.PostStartHookContext) error {
|
|
|
|
clientset, err := extensionsclient.NewForConfig(hookContext.LoopbackClientConfig)
|
|
|
|
if err != nil {
|
|
|
|
utilruntime.HandleError(fmt.Errorf("unable to initialize clusterroles: %v", err))
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
thirdPartyControl := ThirdPartyController{
|
|
|
|
master: p.ResourceInterface,
|
|
|
|
client: clientset,
|
|
|
|
}
|
|
|
|
go wait.Forever(func() {
|
|
|
|
if err := thirdPartyControl.SyncResources(); err != nil {
|
|
|
|
glog.Warningf("third party resource sync failed: %v", err)
|
|
|
|
}
|
|
|
|
}, 10*time.Second)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
2016-10-27 18:24:11 +00:00
|
|
|
|
|
|
|
func (p RESTStorageProvider) GroupName() string {
|
|
|
|
return extensions.GroupName
|
|
|
|
}
|