Documentation ¶
Overview ¶
Package util provides various utility functions for Kubernetes resources.
Index ¶
- Constants
- func BuildRestMapper(restConfig *rest.Config) (meta.RESTMapper, error)
- func ConditionsFromUnstructured(from *unstructured.Unstructured, fields ...string) []metav1.Condition
- func ConditionsToUnstructured(conditions []metav1.Condition, to *unstructured.Unstructured, fields ...string)
- func CopyImmutableMetadata(from, to *unstructured.Unstructured) *unstructured.Unstructured
- func CreateAnew(ctx context.Context, client resource.Interface, obj runtime.Object, ...) (runtime.Object, error)
- func FindGroupVersionResource(from *unstructured.Unstructured, restMapper meta.RESTMapper) (*schema.GroupVersionResource, error)
- func GetMetadata(from *unstructured.Unstructured) map[string]interface{}
- func GetNestedField(obj *unstructured.Unstructured, fields ...string) interface{}
- func GetSpec(obj *unstructured.Unstructured) interface{}
- func MustUpdate(ctx context.Context, client resource.Interface, obj runtime.Object, ...) error
- func SetBackoff(b wait.Backoff) wait.Backoff
- func SetNestedField(to map[string]interface{}, value interface{}, fields ...string)
- func ToUnstructuredResource(from runtime.Object, restMapper meta.RESTMapper) (*unstructured.Unstructured, *schema.GroupVersionResource, error)
- func Update(ctx context.Context, client resource.Interface, obj runtime.Object, ...) error
- type MutateFn
- type OperationResult
Constants ¶
const ( MetadataField = "metadata" LabelsField = "labels" AnnotationsField = "annotations" StatusField = "status" )
Variables ¶
This section is empty.
Functions ¶
func BuildRestMapper ¶
func BuildRestMapper(restConfig *rest.Config) (meta.RESTMapper, error)
func ConditionsFromUnstructured ¶ added in v0.10.1
func ConditionsFromUnstructured(from *unstructured.Unstructured, fields ...string) []metav1.Condition
func ConditionsToUnstructured ¶ added in v0.10.1
func ConditionsToUnstructured(conditions []metav1.Condition, to *unstructured.Unstructured, fields ...string)
func CopyImmutableMetadata ¶ added in v0.12.0
func CopyImmutableMetadata(from, to *unstructured.Unstructured) *unstructured.Unstructured
CopyImmutableMetadata copies the static metadata fields (except Labels and Annotations) from one resource to another.
func CreateAnew ¶ added in v0.9.0
func CreateAnew(ctx context.Context, client resource.Interface, obj runtime.Object, createOptions metav1.CreateOptions, deleteOptions metav1.DeleteOptions, ) (runtime.Object, error)
CreateAnew creates a resource, first deleting an existing instance if one exists. If the delete options specify that deletion should be propagated in the foreground, this will wait for the deletion to be complete before creating the new object: with foreground propagation, Get will continue to return the object being deleted and Create will fail with “already exists” until deletion is complete.
func FindGroupVersionResource ¶
func FindGroupVersionResource(from *unstructured.Unstructured, restMapper meta.RESTMapper) (*schema.GroupVersionResource, error)
func GetMetadata ¶
func GetMetadata(from *unstructured.Unstructured) map[string]interface{}
func GetNestedField ¶ added in v0.6.0
func GetNestedField(obj *unstructured.Unstructured, fields ...string) interface{}
func GetSpec ¶ added in v0.6.0
func GetSpec(obj *unstructured.Unstructured) interface{}
func MustUpdate ¶ added in v0.14.0
func MustUpdate(ctx context.Context, client resource.Interface, obj runtime.Object, mutate MutateFn) error
Update tries to obtain an existing resource and, if found, updates it. If not found, a NotFound error is returned.
func SetNestedField ¶ added in v0.12.0
func ToUnstructuredResource ¶
func ToUnstructuredResource(from runtime.Object, restMapper meta.RESTMapper, ) (*unstructured.Unstructured, *schema.GroupVersionResource, error)
Types ¶
type OperationResult ¶
type OperationResult string
const ( OperationResultNone OperationResult = "unchanged" OperationResultCreated OperationResult = "created" OperationResultUpdated OperationResult = "updated" )
func CreateOrUpdate ¶
func CreateOrUpdate(ctx context.Context, client resource.Interface, obj runtime.Object, mutate MutateFn) (OperationResult, error)
CreateOrUpdate tries to obtain an existing resource and, if not found, creates 'obj' otherwise updates it. The existing resource is normally retrieved via 'obj's Name field but if it's empty and the GenerateName field is non-empty, it will try to retrieve it via the List method using 'obj's Labels. This assumes that the labels uniquely identify the resource. If more than one resource is found, an error is returned.