Template Strings

Template Strings are strings which are dynamically replaced by Preview during a deploy, allowing you to inject environment-specific values into your deployment.

Preview supports the use of Template Strings in both for all chart values and Kubernetes manifest files under the ./preview directory.

For example, it is recommended to use the PREVIEWHQ_HOSTNAME as part of your application's Ingress specification:

# .preview/chart-values/
ingress:
  enabled: true
  annotations:
    kubernetes.io/tls-acme: "true"
  path: /
  hosts:
    - host: ${PREVIEWHQ_HOSTNAME}
      paths:
        - /
  tls:
   - secretName: tls-secret
     hosts:
       - ${PREVIEWHQ_CLUSTER_HOSTNAME}
       - ${PREVIEWHQ_HOSTNAME}

There are 2 sets of Template Strings which can be utilized: one static set across all builds, and one set that is dynamically build based on image builds.

Static Template Strings

Template String

Description

Example

PREVIEWHQ_HOSTNAME

The hostname of the deployment, which will point to the root

my-pr-branch.nrmitchi.envs.dev

PREVIEWHQ_CLUSTER_HOSTNAME

The hostname of the cluster which the deployment is deployed on

nrmitchi.envs.dev

PREVIEWHQ_NAMESPACE

The namespace which the deployment is deployed in to

my-pr-branch

PREVIEWHQ_REVISION

The git hash being deployed

PREVIEWHQ_IMAGE_REPOSITORY

The URL of the Preview-provided Docker image repository that

Dynamic Template Strings

For each addition image specified in the images block of the configuration, Preview injects a PREVIEWHQ_CUSTOM_IMAGE_TAG_{} string, which is the Docker tag which was used for that custom build within the Docker image registry.

For example, if images is as follows:

images:
  - name: frontend
    dockerfile: ./src/react/Dockerfile
    context: ./src/react
  - name: backend
    dockerfile: ./src/flask/Dockerfile
    context: ./src/flask

The the following additional Templates Strings are available:

  • PREVIEWHQ_CUSTOM_IMAGE_TAG_FRONTEND

  • PREVIEWHQ_CUSTOM_IMAGE_TAG_BACKEND

Last updated