apiserverk8s.io/apiserver/pkg/endpoints/handlers/fieldmanager Index | Files | Directories

package fieldmanager

import "k8s.io/apiserver/pkg/endpoints/handlers/fieldmanager"

Index

Types

type FieldManager

type FieldManager struct {
	// contains filtered or unexported fields
}

FieldManager updates the managed fields and merge applied configurations.

func NewCRDFieldManager

func NewCRDFieldManager(models openapiproto.Models, objectConverter runtime.ObjectConvertor, objectDefaulter runtime.ObjectDefaulter, gv schema.GroupVersion, hub schema.GroupVersion, preserveUnknownFields bool) (_ *FieldManager, err error)

NewCRDFieldManager creates a new FieldManager specifically for CRDs. This allows for the possibility of fields which are not defined in models, as well as having no models defined at all.

func NewFieldManager

func NewFieldManager(models openapiproto.Models, objectConverter runtime.ObjectConvertor, objectDefaulter runtime.ObjectDefaulter, gv schema.GroupVersion, hub schema.GroupVersion) (*FieldManager, error)

NewFieldManager creates a new FieldManager that merges apply requests and update managed fields for other types of requests.

func (*FieldManager) Apply

func (f *FieldManager) Apply(liveObj runtime.Object, patch []byte, fieldManager string, force bool) (runtime.Object, error)

Apply is used when server-side apply is called, as it merges the object and update the managed fields.

func (*FieldManager) Update

func (f *FieldManager) Update(liveObj, newObj runtime.Object, manager string) (runtime.Object, error)

Update is used when the object has already been merged (non-apply use-case), and simply updates the managed fields in the output object.

Source Files

fieldmanager.go

Directories

PathSynopsis
pkg/endpoints/handlers/fieldmanager/internal
Version
v0.16.9
Published
Apr 17, 2020
Platform
js/wasm
Imports
14 packages
Last checked
6 minutes ago

Tools for package owners.