Relates-To: #341 Change-Id: I65a5b8cf3bcf94321fc02f240b1d8075bca45c0c
Replacement Transformer
This plugin is written in go
and uses the kyaml
and airshipctl
libraries
for parsing the input and writing the output.
Function implementation
The function is implemented as an image, and built using make image
.
Function reads configuration, a collection of input resources, and performs values
replacement based on configuration.
Function invocation
The function is invoked by authoring a local Resource
with metadata.annotations.[config.kubernetes.io/function]
and running:
kustomize config run local-resource/
This exits non-zero if there is an error.
Running the Example
Run Replacement Transformer
with:
kustomize fn run local-resource --dry-run
Value of spec.version
in resource KubeadmControlPlane
(v1.18.6
) will be replaced
with value of kubernetes
field defined in VariableCatalogue
resource
Configuration file format
Replacement Transformer
configuration resource is represented as a standard
k8s resource with Group, Version, Kind and Metadata header. Replacement
configuration is defined under replacements
field which contains a list of
object with following structure.
source:
objref:
group: airshipit.org
version: v1alpha1
kind: Clusterctl
name: resource-name
namespace: capm3
value: "string value"
fieldref: {.data.host}
target:
objref:
group: airshipit.org
version: v1alpha1
kind: KubeConfig
name: resource-name
namespace: capi-system
fieldrefs:
- {.config.kind}
source
defines where a substitution is from. It can from two different kinds of sources from a field of one resource or from a string.objref
refers to a kubernetes object by Group, Version, Kind, Name and Namespace. Each field can be omitted or be an empty string.value
static string value to substitute intotarget
.fieldref
JSON path to particular object field. This field essentially represents JSON query with syntax used inkubectl
executed with flag--jsonpath
. JSON path syntax end elements is defined by https://goessner.net/articles/JsonPath/
target
defines a substitution target.objref
specifies a set of resources. Any resource that matches intersection of all conditions (Group, Version, Kind, Name and Namespace) is included in this set.fieldrefs
list of JSON path strings which identify target field to substitute into. Field reference may have include pattern which is used as a replacement variable. For example in following query{.metadata.name}%NAME%
string surrounded by%
symbols (i.e.NAME
) is considered as a pattern inside a field value identified by JSON pathmetadata.name
. Therefore if value ofmetadata.name
issome-NAME-of-the-pod
onlyNAME
substring is replaced with the string defined by substitution source.