lemniscat.plugin.terraform
A terraform plugin for lemniscat
Description
This plugin provides a terraform plugin for lemniscat. It allows you to run terraform commands from within lemniscat.
[!NOTE] This plugin allow only for the moment Azure backend.
Usage
Pre-requisites
To use this plugin, you need to have terraform installed on your machine. You can install terraform from here. In order to use this plugin, you need to add plugin into the required section of your manifest file.
requirements:
- name: lemniscat.plugin.terraform
version: 0.2.0
Run terraform init command with Storage Account Access Key
- task: terraform
displayName: 'Terraform init'
steps:
- pre
parameters:
action: init
tfPath: ${{ tfPath }}
backend:
backend_type: azurerm
storage_account_name: ${{ storage_account_name }}
container_name: tfstate
arm_access_key: ${{ arm_access_key }}
key: terraform.tfstate
Run terraform init command with Service Principal
If you want to use Service Principal to to get the storage account access key, you can use the following configuration. First you need to create a Service Principal and assign it to the storage account. You can use the following command to create a Service Principal.
az ad sp create-for-rbac --name <ServicePrincipalName> --role contributor --scopes /subscriptions/<subscription_id>/resourceGroups/<resource_group_name>/providers/Microsoft.Storage/storageAccounts/<storage_account_name>
Then store the output in environment variables.
ARM_SUBSCRIPTION_ID
: The subscription ID that you want to useARM_CLIENT_ID
: The client ID of the service principalARM_CLIENT_SECRET
: The client secret of the service principalARM_TENANT_ID
: The tenant ID of the service principal
Then you can use the following configuration to run terraform init command.
- task: terraform
displayName: 'Terraform init'
steps:
- pre
parameters:
action: init
tfPath: ${{ tfPath }}
backend:
backend_type: azurerm
storage_account_name: ${{ storage_account_name }}
container_name: tfstate
key: terraform.tfstate
Run terraform plan command
- task: terraform
displayName: 'Terraform plan'
steps:
- pre
parameters:
action: plan
tfPath: ${{ tfPath }}
tfVarFile: ${{ tfVarsPath }}/vars.tfvars
tfplanFile: ${{ tfPath }}/terrafom.tfplan
Run terraform apply command
- task: terraform
displayName: 'Terraform apply'
steps:
- run
parameters:
action: apply
tfPath: ${{ tfPath }}
tfplanFile: ${{ tfPath }}/terrafom.tfplan
Run terraform destroy command
- task: terraform
displayName: 'Terraform destroy'
steps:
- run
parameters:
action: destroy
tfPath: ${{ tfPath }}
tfVarFile: ${{ tfVarsPath }}/vars.tfvars
Inputs
Parameters
action
: The action to be performed. It can beinit
,plan
,apply
ordestroy
.tfPath
: The path to the terraform main file.tfVarFile
: The path to the terraform variable file.tfplanFile
: The path to the terraform plan file.backend
: The backend configuration. It contains the following fields.prefixOutput
: The prefix to be added to the output of the terraform command. It is optional. For example, if you have a terraform outputresource_group_name
and you want to add a prefixtf
to it, you can setprefixOutput
totf
. Then the output will betf.resource_group_name
.
Backend
backend_type
: The type of the backend. It can beazurerm
only for the moment. Must be provided iftf.backend_type
isn't in the lemniscat bag of variables.storage_account_name
: The name of the storage account. Only required ifbackend_type
isazurerm
. Must be provided iftf.storage_account_name
isn't in the lemniscat bag of variables.container_name
: The name of the container. Only required ifbackend_type
isazurerm
. Must be provided iftf.container_name
isn't in the lemniscat bag of variables.arm_access_key
: The access key of the storage account. Only required ifbackend_type
isazurerm
. Must be provided iftf.arm_access_key
isn't in the lemniscat bag of variables or if environment variablesARM_SUBSCRIPTION_ID
,ARM_CLIENT_ID
,ARM_CLIENT_SECRET
andARM_TENANT_ID
are not set.key
: The name of the state file. Must be provided iftf.key
isn't in the lemniscat bag of variables.
Outputs
You can push variables to the lemniscat runtime in order to be used after by other tasks. All the outpus defined in the terraform output file will be pushed to the lemniscat runtime. The sensitive outputs will be send to the lemniscat runtime as secret.
If you want to add a prefix to the output, you can use the prefixOutput
parameter.
For example, if you have a terraform output resource_group_name
and you want to add a prefix tf
to it, you can set prefixOutput
to tf
. Then the output will be tf.resource_group_name
.