Skip to content

Templates

Shaun edited this page Apr 22, 2017 · 9 revisions

Go has an excellent and expandable text/template library which is utilised by Qaz for additional logic in creating templates. To read more on Go Template see Here. All features of Go Template are supported in Qaz.

Templating in Qaz

We'll run through some basics to get started.

asciicast

Templating In-Action

To demonstrate the process of creating templates with Qaz we'll start with a simple VPC Cloudformation block.

Single Mappings

config.yml

project: test
stacks:
  vpc:
    cf:
      cidr: 10.10.0.0/16

template.yml

Resources:
  {{ .stack }}:
    Type: "AWS::EC2::VPC"
    Properties:
      CidrBlock: {{ .vpc.cidr }}

Outputs:

$ ls
config.yml  template.yml

$ qaz generate -t vpc::template.yml

Resources:
  vpc:
    Type: "AWS::EC2::VPC"
    Properties:
      CidrBlock: 10.10.0.0/16

The template values wrapped by {{ }} where swapped for their respective values defined in config. Note that {{ .stack }} will always resolve to the name of the stack calling the template, this allow Qaz to use the same template for multiple stacks and generate dynamic content based on the stack calling the template.

If-Statements

Sometimes it may become necessary to add specific content to a template based on a particular config value. In this example we'll demonstrate and if-statement in Go Template logic by using the same template for to generate dynamic content for 2 different stacks.

config.yml

project: test
stacks:
  oneVPC:
    cf:
      cidr: 10.10.0.0/16

  twoVPC:
    cf:
      cidr: 192.168.0.0/16

template.yml

Resources:
  {{ .stack }}:
    Type: "AWS::EC2::VPC"
    Properties:
    {{ if eq .stack "oneVPC" }}
      CidrBlock: {{ .oneVPC.cidr }}
    {{ else }}
      CidrBlock: {{ .twoVPC.cidr }}
    {{ end }}

{{ if eq .stack "oneVPC" }} _simply says: if stack name equals oneVPC.

Outputs:

$ ls
config.yml template.yml

$ ## let's generate the onvVPC stack
$ qaz generate -t oneVPC::template.yml

Resources:
  oneVPC:
    Type: "AWS::EC2::VPC"
    Properties:
      CidrBlock: 10.10.0.0/16

$ ## now for twoVPC
$ qaz generate -t twoVPC::template.yml

Resources:
  twoVPC:
    Type: "AWS::EC2::VPC"
    Properties:

      CidrBlock: 192.168.0.0/16

Loops

Looping over items in config is something you'll probably be doing a lot. This example demonstrates a loop using Go Template.

Let's say I want a template that generates VPCs based on the amount of CIDR blocks I specify in my config.

config.yml

project: test
stacks:
  vpc:
    cf:
      cidrs:
        - 10.10.0.0/16
        - 10.20.0.0/16
        - 10.30.0.0/16

template.yml

{{- $stack := .stack -}}

Resources:
{{ range $index, $cidr := .vpc.cidrs }}
  {{ $stack }}00{{ $index }}:
    Type: "AWS::EC2::VPC"
    Properties:
      CidrBlock: {{ $cidr }}
{{ end }}

Important: There are few things happening in this template that should be clarified. The first line, {{ $stack := .stack }} is a variable assignment; and is done so that the value can be accessed later in the loop. Due to how scoping works with Go's template library, Config values cannot be reach directly while looping, they have to be specified as a template variable.

{{ range $index, $cidr := .vpc.cidrs }} is a loop over the .vpv.cidrs yaml list.

Outputs:

$  qaz-test qaz generate -t vpc::template.yml
Resources:

  vpc000:
    Type: "AWS::EC2::VPC"
    Properties:
      CidrBlock: 10.10.0.0/16

  vpc001:
    Type: "AWS::EC2::VPC"
    Properties:
      CidrBlock: 10.20.0.0/16

  vpc002:
    Type: "AWS::EC2::VPC"
    Properties:
      CidrBlock: 10.30.0.0/16

Templates do not have to be Cloudformation. By using the Go template library Qaz is able to operate at a string manipulation level, meaning, any file can be templated and written using Qaz.

For more information on the cool stuff you can do using Go Templates See Here

Clone this wiki locally