mirror of
				https://github.com/k3s-io/kubernetes.git
				synced 2025-11-03 23:40:03 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			92 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			92 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
/*
 | 
						|
Copyright 2019 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 storage
 | 
						|
 | 
						|
import (
 | 
						|
	"context"
 | 
						|
 | 
						|
	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
 | 
						|
	"k8s.io/apimachinery/pkg/runtime"
 | 
						|
	"k8s.io/apiserver/pkg/registry/generic"
 | 
						|
	genericregistry "k8s.io/apiserver/pkg/registry/generic/registry"
 | 
						|
	"k8s.io/apiserver/pkg/registry/rest"
 | 
						|
	"k8s.io/kubernetes/pkg/apis/flowcontrol"
 | 
						|
	"k8s.io/kubernetes/pkg/printers"
 | 
						|
	printersinternal "k8s.io/kubernetes/pkg/printers/internalversion"
 | 
						|
	printerstorage "k8s.io/kubernetes/pkg/printers/storage"
 | 
						|
	"k8s.io/kubernetes/pkg/registry/flowcontrol/flowschema"
 | 
						|
)
 | 
						|
 | 
						|
// FlowSchemaStorage implements storage for flow schema.
 | 
						|
type FlowSchemaStorage struct {
 | 
						|
	FlowSchema *REST
 | 
						|
	Status     *StatusREST
 | 
						|
}
 | 
						|
 | 
						|
// REST implements a RESTStorage for flow schema against etcd
 | 
						|
type REST struct {
 | 
						|
	*genericregistry.Store
 | 
						|
}
 | 
						|
 | 
						|
// NewREST returns a RESTStorage object that will work against flow schemas.
 | 
						|
func NewREST(optsGetter generic.RESTOptionsGetter) (*REST, *StatusREST, error) {
 | 
						|
	store := &genericregistry.Store{
 | 
						|
		NewFunc:                  func() runtime.Object { return &flowcontrol.FlowSchema{} },
 | 
						|
		NewListFunc:              func() runtime.Object { return &flowcontrol.FlowSchemaList{} },
 | 
						|
		DefaultQualifiedResource: flowcontrol.Resource("flowschemas"),
 | 
						|
 | 
						|
		CreateStrategy: flowschema.Strategy,
 | 
						|
		UpdateStrategy: flowschema.Strategy,
 | 
						|
		DeleteStrategy: flowschema.Strategy,
 | 
						|
 | 
						|
		TableConvertor: printerstorage.TableConvertor{TableGenerator: printers.NewTableGenerator().With(printersinternal.AddHandlers)},
 | 
						|
	}
 | 
						|
	options := &generic.StoreOptions{RESTOptions: optsGetter}
 | 
						|
	if err := store.CompleteWithOptions(options); err != nil {
 | 
						|
		return nil, nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	statusStore := *store
 | 
						|
	statusStore.CreateStrategy = nil
 | 
						|
	statusStore.UpdateStrategy = flowschema.StatusStrategy
 | 
						|
	statusStore.DeleteStrategy = nil
 | 
						|
 | 
						|
	return &REST{store}, &StatusREST{store: &statusStore}, nil
 | 
						|
}
 | 
						|
 | 
						|
// StatusREST implements the REST endpoint for changing the status of a flow schema.
 | 
						|
type StatusREST struct {
 | 
						|
	store *genericregistry.Store
 | 
						|
}
 | 
						|
 | 
						|
// New creates a new flow schema object.
 | 
						|
func (r *StatusREST) New() runtime.Object {
 | 
						|
	return &flowcontrol.FlowSchema{}
 | 
						|
}
 | 
						|
 | 
						|
// Get retrieves the object from the storage. It is required to support Patch.
 | 
						|
func (r *StatusREST) Get(ctx context.Context, name string, options *metav1.GetOptions) (runtime.Object, error) {
 | 
						|
	return r.store.Get(ctx, name, options)
 | 
						|
}
 | 
						|
 | 
						|
// Update alters the status subset of an object.
 | 
						|
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) {
 | 
						|
	// We are explicitly setting forceAllowCreate to false in the call to the underlying storage because
 | 
						|
	// subresources should never allow create on update.
 | 
						|
	return r.store.Update(ctx, name, objInfo, createValidation, updateValidation, false, options)
 | 
						|
}
 |