-
Notifications
You must be signed in to change notification settings - Fork 0
71 lines (60 loc) · 2.29 KB
/
management-cluster-terraform-destroy-on-hcloud.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
name: "management cluster terraform destroy and delete workspace"
on:
workflow_call:
inputs:
workspace:
required: true
type: string
var_file:
required: true
type: string
environment:
required: true
type: string
secrets:
tf_api_token:
required: true
hcloud_secret:
required: true
hcloud_ssh_key_private:
required: true
hcloud_ssh_key_public:
required: true
jobs:
terraform:
name: "Terraform"
runs-on: ubuntu-latest
environment: ${{ inputs.environment }}
# Use the Bash shell regardless whether the GitHub Actions runner is ubuntu-latest, macos-latest, or windows-latest
defaults:
run:
shell: bash
steps:
# Checkout the repository to the GitHub Actions runner
- name: Checkout
uses: actions/checkout@v3
# Install the latest version of Terraform CLI and configure the Terraform CLI configuration file with a Terraform Cloud user API token
- name: Setup Terraform
uses: hashicorp/setup-terraform@v1
with:
cli_config_credentials_token: ${{ secrets.tf_api_token }}
# Initialize a new or existing Terraform working directory by creating initial files, loading any remote state, downloading modules, etc.
- name: Terraform Init
run: TF_WORKSPACE=fallback terraform init -input=false
# Selecting correct workspace (and create if not exist)
- name: Terraform Workspace Select
run: terraform workspace select ${{ inputs.workspace }} || terraform workspace new ${{ inputs.workspace }}
# Destroy ressources
- name: Terraform Destroy
run: |
terraform destroy -auto-approve -var-file=${{ inputs.var_file }} \
-var prefix="${{ inputs.prefix }}" \
-var hcloud_secret="${{ secrets.hcloud_secret }}" \
-var hcloud_ssh_key_private="${{ secrets.hcloud_ssh_key_private }}" \
-var hcloud_ssh_key_public="${{ secrets.hcloud_ssh_key_public }}"
# Selecting fallback workspace
- name: Terraform Workspace Select
run: terraform workspace select fallback
# Delete workspace
- name: Terraform Workspace delete
run: terraform workspace delete -force ${{ inputs.workspace }}