storage_batch.go 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. /*
  2. Copyright 2016 The Kubernetes Authors.
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. http://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. */
  13. package rest
  14. import (
  15. batchapiv1 "k8s.io/api/batch/v1"
  16. batchapiv1beta1 "k8s.io/api/batch/v1beta1"
  17. batchapiv2alpha1 "k8s.io/api/batch/v2alpha1"
  18. "k8s.io/apiserver/pkg/registry/generic"
  19. "k8s.io/apiserver/pkg/registry/rest"
  20. genericapiserver "k8s.io/apiserver/pkg/server"
  21. serverstorage "k8s.io/apiserver/pkg/server/storage"
  22. "k8s.io/kubernetes/pkg/api/legacyscheme"
  23. "k8s.io/kubernetes/pkg/apis/batch"
  24. cronjobstore "k8s.io/kubernetes/pkg/registry/batch/cronjob/storage"
  25. jobstore "k8s.io/kubernetes/pkg/registry/batch/job/storage"
  26. )
  27. type RESTStorageProvider struct{}
  28. func (p RESTStorageProvider) NewRESTStorage(apiResourceConfigSource serverstorage.APIResourceConfigSource, restOptionsGetter generic.RESTOptionsGetter) (genericapiserver.APIGroupInfo, bool, error) {
  29. apiGroupInfo := genericapiserver.NewDefaultAPIGroupInfo(batch.GroupName, legacyscheme.Scheme, legacyscheme.ParameterCodec, legacyscheme.Codecs)
  30. // If you add a version here, be sure to add an entry in `k8s.io/kubernetes/cmd/kube-apiserver/app/aggregator.go with specific priorities.
  31. // TODO refactor the plumbing to provide the information in the APIGroupInfo
  32. if apiResourceConfigSource.VersionEnabled(batchapiv1.SchemeGroupVersion) {
  33. if storageMap, err := p.v1Storage(apiResourceConfigSource, restOptionsGetter); err != nil {
  34. return genericapiserver.APIGroupInfo{}, false, err
  35. } else {
  36. apiGroupInfo.VersionedResourcesStorageMap[batchapiv1.SchemeGroupVersion.Version] = storageMap
  37. }
  38. }
  39. if apiResourceConfigSource.VersionEnabled(batchapiv1beta1.SchemeGroupVersion) {
  40. if storageMap, err := p.v1beta1Storage(apiResourceConfigSource, restOptionsGetter); err != nil {
  41. return genericapiserver.APIGroupInfo{}, false, err
  42. } else {
  43. apiGroupInfo.VersionedResourcesStorageMap[batchapiv1beta1.SchemeGroupVersion.Version] = storageMap
  44. }
  45. }
  46. if apiResourceConfigSource.VersionEnabled(batchapiv2alpha1.SchemeGroupVersion) {
  47. if storageMap, err := p.v2alpha1Storage(apiResourceConfigSource, restOptionsGetter); err != nil {
  48. return genericapiserver.APIGroupInfo{}, false, err
  49. } else {
  50. apiGroupInfo.VersionedResourcesStorageMap[batchapiv2alpha1.SchemeGroupVersion.Version] = storageMap
  51. }
  52. }
  53. return apiGroupInfo, true, nil
  54. }
  55. func (p RESTStorageProvider) v1Storage(apiResourceConfigSource serverstorage.APIResourceConfigSource, restOptionsGetter generic.RESTOptionsGetter) (map[string]rest.Storage, error) {
  56. storage := map[string]rest.Storage{}
  57. // jobs
  58. jobsStorage, jobsStatusStorage, err := jobstore.NewREST(restOptionsGetter)
  59. if err != nil {
  60. return storage, err
  61. }
  62. storage["jobs"] = jobsStorage
  63. storage["jobs/status"] = jobsStatusStorage
  64. return storage, err
  65. }
  66. func (p RESTStorageProvider) v1beta1Storage(apiResourceConfigSource serverstorage.APIResourceConfigSource, restOptionsGetter generic.RESTOptionsGetter) (map[string]rest.Storage, error) {
  67. storage := map[string]rest.Storage{}
  68. // cronjobs
  69. cronJobsStorage, cronJobsStatusStorage, err := cronjobstore.NewREST(restOptionsGetter)
  70. if err != nil {
  71. return storage, err
  72. }
  73. storage["cronjobs"] = cronJobsStorage
  74. storage["cronjobs/status"] = cronJobsStatusStorage
  75. return storage, err
  76. }
  77. func (p RESTStorageProvider) v2alpha1Storage(apiResourceConfigSource serverstorage.APIResourceConfigSource, restOptionsGetter generic.RESTOptionsGetter) (map[string]rest.Storage, error) {
  78. storage := map[string]rest.Storage{}
  79. // cronjobs
  80. cronJobsStorage, cronJobsStatusStorage, err := cronjobstore.NewREST(restOptionsGetter)
  81. if err != nil {
  82. return storage, err
  83. }
  84. storage["cronjobs"] = cronJobsStorage
  85. storage["cronjobs/status"] = cronJobsStatusStorage
  86. return storage, err
  87. }
  88. func (p RESTStorageProvider) GroupName() string {
  89. return batch.GroupName
  90. }