...
1
16
17 package storage
18
19 import (
20 "context"
21
22 metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
23 "k8s.io/apimachinery/pkg/runtime"
24 "k8s.io/apiserver/pkg/registry/generic"
25 genericregistry "k8s.io/apiserver/pkg/registry/generic/registry"
26 "k8s.io/apiserver/pkg/registry/rest"
27 "k8s.io/kubernetes/pkg/apis/batch"
28 "k8s.io/kubernetes/pkg/printers"
29 printersinternal "k8s.io/kubernetes/pkg/printers/internalversion"
30 printerstorage "k8s.io/kubernetes/pkg/printers/storage"
31 "k8s.io/kubernetes/pkg/registry/batch/cronjob"
32 "sigs.k8s.io/structured-merge-diff/v4/fieldpath"
33 )
34
35
36 type REST struct {
37 *genericregistry.Store
38 }
39
40
41 func NewREST(optsGetter generic.RESTOptionsGetter) (*REST, *StatusREST, error) {
42 store := &genericregistry.Store{
43 NewFunc: func() runtime.Object { return &batch.CronJob{} },
44 NewListFunc: func() runtime.Object { return &batch.CronJobList{} },
45 DefaultQualifiedResource: batch.Resource("cronjobs"),
46 SingularQualifiedResource: batch.Resource("cronjob"),
47
48 CreateStrategy: cronjob.Strategy,
49 UpdateStrategy: cronjob.Strategy,
50 DeleteStrategy: cronjob.Strategy,
51 ResetFieldsStrategy: cronjob.Strategy,
52
53 TableConvertor: printerstorage.TableConvertor{TableGenerator: printers.NewTableGenerator().With(printersinternal.AddHandlers)},
54 }
55 options := &generic.StoreOptions{RESTOptions: optsGetter}
56 if err := store.CompleteWithOptions(options); err != nil {
57 return nil, nil, err
58 }
59
60 statusStore := *store
61 statusStore.UpdateStrategy = cronjob.StatusStrategy
62 statusStore.ResetFieldsStrategy = cronjob.StatusStrategy
63
64 return &REST{store}, &StatusREST{store: &statusStore}, nil
65 }
66
67 var _ rest.CategoriesProvider = &REST{}
68 var _ rest.ShortNamesProvider = &REST{}
69
70
71 func (r *REST) Categories() []string {
72 return []string{"all"}
73 }
74
75
76 func (r *REST) ShortNames() []string {
77 return []string{"cj"}
78 }
79
80
81 type StatusREST struct {
82 store *genericregistry.Store
83 }
84
85
86 func (r *StatusREST) New() runtime.Object {
87 return &batch.CronJob{}
88 }
89
90
91 func (r *StatusREST) Destroy() {
92
93
94 }
95
96
97 func (r *StatusREST) Get(ctx context.Context, name string, options *metav1.GetOptions) (runtime.Object, error) {
98 return r.store.Get(ctx, name, options)
99 }
100
101
102 func (r *StatusREST) Update(ctx context.Context, name string, objInfo rest.UpdatedObjectInfo, createValidation rest.ValidateObjectFunc, updateValidation rest.ValidateObjectUpdateFunc, forceAllowCreate bool, options *metav1.UpdateOptions) (runtime.Object, bool, error) {
103
104
105 return r.store.Update(ctx, name, objInfo, createValidation, updateValidation, false, options)
106 }
107
108
109 func (r *StatusREST) GetResetFields() map[fieldpath.APIVersion]*fieldpath.Set {
110 return r.store.GetResetFields()
111 }
112
113 func (r *StatusREST) ConvertToTable(ctx context.Context, object runtime.Object, tableOptions runtime.Object) (*metav1.Table, error) {
114 return r.store.ConvertToTable(ctx, object, tableOptions)
115 }
116
View as plain text