Skip to content

Terraform Destroy

Terraform Destroy #22

name: Terraform Destroy
on:
workflow_dispatch:
inputs:
vm_sku:
description: 'Virtual Machine SKU'
required: true
default: 'Standard_NV18ads_A10_v5'
num_instances:
description: 'Number of Instances'
required: true
default: '1'
max_bid:
description: 'Maximum spot bid amount'
required: true
default: '0.50'
allowed_ip:
description: 'Your IP address'
required: true
default: '77.249.236.43'
disk_size:
description: 'VM Disk Size (GB)'
required: true
default: '64'
resource_group:
description: 'Resource Group Name'
required: true
default: 'demo-rg'
github_username:
description: 'Github user with ssh-key to provision'
required: true
default: 'cloudymax'
vm_username:
description: 'Github user with ssh-key to provision'
required: true
default: 'friend'
jobs:
terraform-destroy:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Public IP
id: ip
uses: haythem/[email protected]
- name: Azure Login
uses: azure/login@v1
with:
creds: ${{ secrets.AZURE_CREDENTIALS }}
- name: Manage Firewalls
run: |
chmod +x access-helper.sh
bash access-helper.sh add $RUNNER_IP $RESOURCE_GROUP
shell: bash
env:
RUNNER_IP: ${{ steps.ip.outputs.ipv4 }}
RESOURCE_GROUP: ${{ github.event.inputs.resource_group }}
continue-on-error: true
- name: Terraform fmt
run: |
docker run --platform linux/amd64 \
-e ARM_CLIENT_ID=${{ secrets.ARM_CLIENT_ID }} \
-e ARM_CLIENT_SECRET=${{ secrets.ARM_CLIENT_SECRET }} \
-e ARM_SUBSCRIPTION_ID=${{ secrets.ARM_SUBSCRIPTION_ID }} \
-e ARM_TENANT_ID=${{ secrets.ARM_TENANT_ID }} \
-v $(pwd):/terraform -w /terraform \
hashicorp/terraform fmt
continue-on-error: false
shell: bash
- name: Terraform Init
run: |
docker run --platform linux/amd64 \
-e ARM_CLIENT_ID=${{ secrets.ARM_CLIENT_ID }} \
-e ARM_CLIENT_SECRET=${{ secrets.ARM_CLIENT_SECRET }} \
-e ARM_SUBSCRIPTION_ID=${{ secrets.ARM_SUBSCRIPTION_ID }} \
-e ARM_TENANT_ID=${{ secrets.ARM_TENANT_ID }} \
-v $(pwd):/terraform -w /terraform \
hashicorp/terraform init --upgrade
continue-on-error: false
shell: bash
- name: Terraform Validate
run: |
docker run --platform linux/amd64 \
-e ARM_CLIENT_ID=${{ secrets.ARM_CLIENT_ID }} \
-e ARM_CLIENT_SECRET=${{ secrets.ARM_CLIENT_SECRET }} \
-e ARM_SUBSCRIPTION_ID=${{ secrets.ARM_SUBSCRIPTION_ID }} \
-e ARM_TENANT_ID=${{ secrets.ARM_TENANT_ID }} \
-v $(pwd):/terraform -w /terraform \
hashicorp/terraform validate -no-color
continue-on-error: false
shell: bash
- name: Terraform Destroy
id: apply
run: |
docker run --platform linux/amd64 \
-e ARM_CLIENT_ID=${{ secrets.ARM_CLIENT_ID }} \
-e ARM_CLIENT_SECRET=${{ secrets.ARM_CLIENT_SECRET }} \
-e ARM_SUBSCRIPTION_ID=${{ secrets.ARM_SUBSCRIPTION_ID }} \
-e ARM_TENANT_ID=${{ secrets.ARM_TENANT_ID }} \
-v $(pwd):/terraform -w /terraform \
hashicorp/terraform destroy -no-color -auto-approve -input=false \
-var="vm_sku=$VM_SKU" \
-var="vm_instances=$NUM_INSTANCES" \
-var="max_bid_price=$MAX_BID" \
-var="github_username=$GITHUB_USERNAME" \
-var="username=$VM_USERNAME" \
-var='allowed_ips=["${{github.event.inputs.allowed_ip}}", "${{ steps.ip.outputs.ipv4 }}"]'
continue-on-error: false
shell: bash
env:
VM_SKU: ${{ github.event.inputs.vm_sku }}
DISK_SIZE: ${{ github.event.inputs.disk_size }}
NUM_INSTANCES: ${{ github.event.inputs.num_instances }}
MAX_BID: ${{ github.event.inputs.max_bid }}
ALLOWED_IPS: ${{ github.event.inputs.allowed_ip }}
RUNNER_IP: ${{ steps.ip.outputs.ipv4 }}
RESOURCE_GROUP: ${{ github.event.inputs.resource_group }}
GITHUB_USERNAME: ${{ github.event.inputs.github_username }}
VM_USERNAME: ${{ github.event.inputs.vm_username }}