Skip to content

Latest commit

 

History

History
177 lines (137 loc) · 8.38 KB

File metadata and controls

177 lines (137 loc) · 8.38 KB
title sidebar_position
Accessing Component Descriptors
1

Accessing Component Descriptors in Templates

This example demonstrates the templating of DeployItems. In particular, we show how you can access component descriptors during the templating.

For prerequisites, see here.

References Between Component Descriptors

Component descriptors can reference other component descriptors. In this example we consider three component descriptors, which we name as follows:

The root component descriptor references the other two in its section component.componentReferences:

component:
  name: github.com/gardener/landscaper-examples/guided-tour/templating-components-root
  version: 2.2.0
  componentReferences:
    - componentName: github.com/gardener/landscaper-examples/guided-tour/templating-components-core
      name: core
      version: 2.2.0
    - componentName: github.com/gardener/landscaper-examples/guided-tour/templating-components-extension
      name: extension
      version: 2.2.0
  ...

We have uploaded these three component descriptors into an OCI registry, so that the Landscaper can read them from there (root, core, extension).

The Blueprint

The blueprint of the present example belongs to the root component. Part of the blueprint is a deploy execution. The deploy execution is a Go Template, which is used to generate a DeployItem. The template can be filled with values from a certain data structure. The following fields in this data structure provide access to the involved component descriptors:

NOTE: If you are using Component Descriptors Version 3 instead of Version 2, the data structure of the component descriptors themselves is slightly different from what is described below (e.g. a component's name is under metadata.name instead of component.name).
Per default, the component descriptor version a blueprint is templating against is the version of the component descriptor referenced in the installation.
Since a blueprint could be used in different installations with different component descriptor versions, it is also possible to specify the component descriptor version (v2 or ocm.software/v3alpha1) to template against in the blueprint itself. So you may decide that you want to template against v2 even though v3alpha1 is the component descriptor version provided in the installation (or vice versa). Therefore, you may simply add the following annotation to the blueprint:

apiVersion: landscaper.gardener.cloud/v1alpha1
kind: Blueprint
jsonSchema: "https://json-schema.org/draft/2019-09/schema"
annotations:
  ocmSchemaVersion: v2 #or ocm.software/v3alpha1
...
  • cd : the component descriptor of the Installation. In our case, this is the root component descriptor.
    Let's consider an example, how this field can be used. The expression below evaluates to the component name. That is because field cd contains the complete component descriptor, and inside it, the component name is located at the path component.name.

    {{ .cd.component.name }}
  • components : a list of component descriptors. It contains the component descriptor of the Installation, and all further component descriptors which can be reached from this one by (transitively) following component references. In our case, the list contains the three component descriptors from above. To give an example, a list with the names of the involved components can be obtained as follows:

    componentNames:
    {{ range $index, $comp := .components.components }}
      - {{ $comp.component.name }}  
    {{ end }}

Let's discuss the deploy execution of our blueprint.

  • First, it loops over all components and collects all their resources in a list: $resources.
  • In a second step, it selects the resources with certain labels. Resources with label landscaper.gardener.cloud/guided-tour/type are added to a dictionary $typedResources, and resources with label landscaper.gardener.cloud/guided-tour/auxiliary are added to a dictionary $auxiliaryResources.
  • Finally, these "typed" and "auxiliary" resources are inserted at different places in a ConfigMap manifest, which will be deployed by the manifest deployer.

The resources that we have collected from the component descriptors look for example like this:

- access:
    imageReference: europe-docker.pkg.dev/sap-gcp-cp-k8s-stable-hub/landscaper-examples/examples/images/image-a:1.0.0
    type: ociRegistry
  labels:
    - name: landscaper.gardener.cloud/guided-tour/type
      value: type-a
  name: image-a
  relation: external
  type: ociImage
  version: 1.0.0

This is not yet the desired result format. Therefore, we use a template formatResource to transform the resources. The template extracts the field .access.imageReference from a resource, splits the string value in three parts, and produces the following result:

registry: eu.gcr.io
repository: gardener-project/landscaper/examples/images/image-a
tag: 1.0.0

We can pass only one argument to a template. However, our template formatResource needs two inputs, a resource and an indent. To solve this, we put both values in a dictionary $args and pass this dictionary to template:

{{- $args := dict "resource" $resource.access.imageReference "indent" 20 }}
{{- template "formatResource" $args }}

Note that you can use certain sprig template functions like list, append, dict etc.

For more details, see Templating.

Procedure

  1. On the target cluster, create a namespace example. It is the namespace of the resulting ConfigMap.

  2. On the Landscaper resource cluster, create a namespace cu-example.

  3. On the Landscaper resource cluster, in namespace cu-example, create a Target, a Context, and an Installation. There are templates for these resources in the directory installation. To apply them:

    • adapt the settings file such that the entry TARGET_CLUSTER_KUBECONFIG_PATH points to the kubeconfig of the target cluster,
    • run the deploy-k8s-resources script, which will template and apply the Target, Context, and Installation.
  4. When the Installation has succeeded, there is a ConfigMap templating-components in namespace example, which contains the result of the templating that we have discussed.

Cleanup

You can remove the Installation with the delete-installation script. When the Installation is gone, you can delete the Context and Target with the delete-other-k8s-resources script.

References

Templating
Go Template
Sprig template functions