Documentation ¶
Overview ¶
Package resource implements representations of k8s API resources.
Index ¶
- Variables
- type Factory
- func (rf *Factory) DropLocalNodes(nodes []*yaml.RNode) ([]*Resource, error)
- func (rf *Factory) FromBytes(in []byte) (*Resource, error)
- func (rf *Factory) FromMap(m map[string]interface{}) *Resource
- func (rf *Factory) FromMapAndOption(m map[string]interface{}, args *types.GeneratorArgs) *Resource
- func (rf *Factory) FromMapWithName(n string, m map[string]interface{}) *Resource
- func (rf *Factory) FromMapWithNamespaceAndName(ns string, n string, m map[string]interface{}) *Resource
- func (rf *Factory) Hasher() ifc.KustHasher
- func (rf *Factory) MakeConfigMap(kvLdr ifc.KvLoader, args *types.ConfigMapArgs) (*Resource, error)
- func (rf *Factory) MakeSecret(kvLdr ifc.KvLoader, args *types.SecretArgs) (*Resource, error)
- func (rf *Factory) RNodesFromBytes(b []byte) ([]*yaml.RNode, error)
- func (rf *Factory) ResourcesFromRNodes(nodes []*yaml.RNode) (result []*Resource, err error)
- func (rf *Factory) SliceFromBytes(in []byte) ([]*Resource, error)
- func (rf *Factory) SliceFromBytesWithNames(names []string, in []byte) ([]*Resource, error)
- func (rf *Factory) SliceFromPatches(ldr ifc.Loader, paths []types.PatchStrategicMerge) ([]*Resource, error)
- type IdSet
- type Origin
- type ResCtx
- type ResCtxMatcher
- type Resource
- func (r *Resource) AddNamePrefix(p string)
- func (r *Resource) AddNameSuffix(s string)
- func (r *Resource) AllowKindChange()
- func (r *Resource) AllowNameChange()
- func (r *Resource) AppendRefBy(id fmt.Stringer)
- func (r *Resource) AppendRefVarName(variable types.Var)
- func (r *Resource) ApplyFilter(f kio.Filter) error
- func (r *Resource) ApplySmPatch(patch *Resource) error
- func (r *Resource) AsYAML() ([]byte, error)
- func (r *Resource) Behavior() types.GenerationBehavior
- func (r *Resource) CopyMergeMetaDataFieldsFrom(other *Resource) error
- func (r *Resource) CurId() resid.ResId
- func (r *Resource) DeepCopy() *Resource
- func (r *Resource) EnableHashSuffix()
- func (r *Resource) ErrIfNotEquals(o *Resource) error
- func (r *Resource) GetGvk() resid.Gvk
- func (r *Resource) GetNamePrefixes() []string
- func (r *Resource) GetNameSuffixes() []string
- func (r *Resource) GetRefBy() []resid.ResId
- func (r *Resource) GetRefVarNames() []string
- func (r *Resource) Hash(h ifc.KustHasher) (string, error)
- func (r *Resource) KindChangeAllowed() bool
- func (r *Resource) MergeBinaryDataMapFrom(o *Resource)
- func (r *Resource) MergeDataMapFrom(o *Resource)
- func (r *Resource) MustYaml() string
- func (r *Resource) NameChangeAllowed() bool
- func (r *Resource) NeedHashSuffix() bool
- func (r *Resource) OrgId() resid.ResId
- func (r *Resource) PrefixesSuffixesEquals(o ResCtx) bool
- func (r *Resource) PrevIds() []resid.ResId
- func (r *Resource) ReferencesEqual(other *Resource) bool
- func (r *Resource) RemoveBuildAnnotations()
- func (r *Resource) ResetRNode(incoming *Resource)
- func (r *Resource) SetBehavior(behavior types.GenerationBehavior)
- func (r *Resource) SetGvk(gvk resid.Gvk)
- func (r *Resource) StorePreviousId()
- func (r *Resource) String() string
Constants ¶
This section is empty.
Variables ¶
var BuildAnnotations = []string{ utils.BuildAnnotationPreviousKinds, utils.BuildAnnotationPreviousNames, utils.BuildAnnotationPrefixes, utils.BuildAnnotationSuffixes, utils.BuildAnnotationPreviousNamespaces, utils.BuildAnnotationAllowNameChange, utils.BuildAnnotationAllowKindChange, utils.BuildAnnotationsRefBy, utils.BuildAnnotationsGenBehavior, utils.BuildAnnotationsGenAddHashSuffix, kioutil.PathAnnotation, kioutil.IndexAnnotation, kioutil.SeqIndentAnnotation, kioutil.LegacyPathAnnotation, kioutil.LegacyIndexAnnotation, }
nolint
Functions ¶
This section is empty.
Types ¶
type Factory ¶
type Factory struct { // When set to true, IncludeLocalConfigs indicates // that Factory should include resources with the // annotation 'config.kubernetes.io/local-config'. // By default these resources are ignored. IncludeLocalConfigs bool // contains filtered or unexported fields }
Factory makes instances of Resource.
func NewFactory ¶
func NewFactory(h ifc.KustHasher) *Factory
NewFactory makes an instance of Factory.
func (*Factory) DropLocalNodes ¶ added in v0.10.0
DropLocalNodes removes the local nodes by default. Local nodes are detected via the annotation `config.kubernetes.io/local-config: "true"`
func (*Factory) FromMapAndOption ¶
func (rf *Factory) FromMapAndOption( m map[string]interface{}, args *types.GeneratorArgs) *Resource
FromMapAndOption returns a new instance of Resource with given options.
func (*Factory) FromMapWithName ¶
FromMapWithName returns a new instance with the given "original" name.
func (*Factory) FromMapWithNamespaceAndName ¶
func (rf *Factory) FromMapWithNamespaceAndName(ns string, n string, m map[string]interface{}) *Resource
FromMapWithNamespaceAndName returns a new instance with the given "original" namespace.
func (*Factory) Hasher ¶
func (rf *Factory) Hasher() ifc.KustHasher
Hasher returns an ifc.KustHasher
func (*Factory) MakeConfigMap ¶
MakeConfigMap makes an instance of Resource for ConfigMap
func (*Factory) MakeSecret ¶
MakeSecret makes an instance of Resource for Secret
func (*Factory) RNodesFromBytes ¶ added in v0.8.6
func (*Factory) ResourcesFromRNodes ¶ added in v0.8.6
ResourcesFromRNodes converts RNodes to Resources.
func (*Factory) SliceFromBytes ¶
SliceFromBytes unmarshals bytes into a Resource slice.
func (*Factory) SliceFromBytesWithNames ¶ added in v0.6.0
SliceFromBytesWithNames unmarshals bytes into a Resource slice with specified original name.
func (*Factory) SliceFromPatches ¶
func (rf *Factory) SliceFromPatches( ldr ifc.Loader, paths []types.PatchStrategicMerge) ([]*Resource, error)
SliceFromPatches returns a slice of resources given a patch path slice from a kustomization file.
type Origin ¶ added in v0.9.0
type Origin struct { // Path is the path to the resource, rooted from the directory upon // which `kustomize build` was invoked Path string // Repo is the remote repository that the resource originated from if it is // not from a local file Repo string // Ref is the ref of the remote repository that the resource originated from // if it is not from a local file Ref string }
Origin retains information about where resources in the output of `kustomize build` originated from
type ResCtx ¶
type ResCtx interface { AddNamePrefix(p string) AddNameSuffix(s string) GetNamePrefixes() []string GetNameSuffixes() []string }
ResCtx is an interface describing the contextual added kept kustomize in the context of each Resource object. Currently mainly the name prefix and name suffix are added.
type ResCtxMatcher ¶
ResCtxMatcher returns true if two Resources are being modified in the same kustomize context.
type Resource ¶
Resource is an RNode, representing a Kubernetes Resource Model object, paired with metadata used by kustomize.
func (*Resource) AddNamePrefix ¶
Implements ResCtx AddNamePrefix
func (*Resource) AddNameSuffix ¶
Implements ResCtx AddNameSuffix
func (*Resource) AllowKindChange ¶ added in v0.8.10
func (r *Resource) AllowKindChange()
AllowKindChange allows kind changes to the resource.
func (*Resource) AllowNameChange ¶ added in v0.8.10
func (r *Resource) AllowNameChange()
AllowNameChange allows name changes to the resource.
func (*Resource) AppendRefBy ¶
AppendRefBy appends a ResId into the refBy list Using any type except fmt.Stringer here results in a compilation error
func (*Resource) AppendRefVarName ¶
AppendRefVarName appends a name of a var into the refVar list
func (*Resource) ApplySmPatch ¶ added in v0.6.6
ApplySmPatch applies the provided strategic merge patch.
func (*Resource) Behavior ¶
func (r *Resource) Behavior() types.GenerationBehavior
Behavior returns the behavior for the resource.
func (*Resource) CopyMergeMetaDataFieldsFrom ¶ added in v0.6.8
CopyMergeMetaDataFieldsFrom copies everything but the non-metadata in the resource. TODO: move to RNode, use GetMeta to improve performance. TODO: make a version of mergeStringMaps that is build-annotation aware
to avoid repeatedly setting refby and genargs annotations
Must remove the kustomize bit at the end.
func (*Resource) CurId ¶
CurId returns a ResId for the resource using the mutable parts of the resource. This should be unique in any ResMap.
func (*Resource) EnableHashSuffix ¶ added in v0.9.0
func (r *Resource) EnableHashSuffix()
EnableHashSuffix marks the resource as needing a content hash to be appended to the name of the resource.
func (*Resource) ErrIfNotEquals ¶ added in v0.6.6
func (*Resource) GetNamePrefixes ¶
Implements ResCtx GetNamePrefixes
func (*Resource) GetNameSuffixes ¶
Implements ResCtx GetNameSuffixes
func (*Resource) GetRefVarNames ¶
GetRefVarNames returns vars that refer to current resource
func (*Resource) KindChangeAllowed ¶ added in v0.8.6
KindChangeAllowed checks if a patch resource is allowed to change another resource's kind.
func (*Resource) MergeBinaryDataMapFrom ¶ added in v0.8.1
func (*Resource) MergeDataMapFrom ¶ added in v0.6.8
func (*Resource) NameChangeAllowed ¶ added in v0.8.6
NameChangeAllowed checks if a patch resource is allowed to change another resource's name.
func (*Resource) NeedHashSuffix ¶
NeedHashSuffix returns true if a resource content hash should be appended to the name of the resource.
func (*Resource) OrgId ¶
OrgId returns the original, immutable ResId for the resource. This doesn't have to be unique in a ResMap.
func (*Resource) PrefixesSuffixesEquals ¶
PrefixesSuffixesEquals is conceptually doing the same task as OutermostPrefixSuffix but performs a deeper comparison of the suffix and prefix slices.
func (*Resource) PrevIds ¶ added in v0.6.9
PrevIds returns a list of ResIds that includes every previous ResId the resource has had through all of its GVKN transformations, in the order that it had that ID. I.e. the oldest ID is first. The returned array does not include the resource's current ID. If there are no previous IDs, this will return nil.
func (*Resource) ReferencesEqual ¶
func (*Resource) RemoveBuildAnnotations ¶ added in v0.6.9
func (r *Resource) RemoveBuildAnnotations()
RemoveBuildAnnotations removes annotations created by the build process. These are internal-only to kustomize, added to the data pipeline to track name changes so name references can be fixed.
func (*Resource) ResetRNode ¶ added in v0.8.10
func (*Resource) SetBehavior ¶ added in v0.9.0
func (r *Resource) SetBehavior(behavior types.GenerationBehavior)
SetBehavior sets the behavior for the resource.
func (*Resource) StorePreviousId ¶ added in v0.6.9
func (r *Resource) StorePreviousId()
StorePreviousId stores the resource's current ID via build annotations.