infrastructure/.forgejo/workflows/tofu-plan-k8s-wheatley.yaml

77 lines
2.2 KiB
YAML
Raw Normal View History

2025-11-28 15:34:52 +01:00
---
2025-11-28 20:53:52 +01:00
name: tofu plan k8s-wheatley
2025-11-28 15:34:52 +01:00
on:
workflow_dispatch:
workflow_call:
pull_request:
branches:
- main
# paths:
2025-11-29 11:15:28 +01:00
# - pve01.wheatley.in/k8s-wheatley/**
env:
2025-11-29 12:15:12 +01:00
TOFU_VERSION: 1.10.7
TOFU_CHECKSUM: 765a7374aeafcad15fe8da5359de76ce11ba0fd3cb6c2dc85d3b390e6362cae5
2025-11-29 11:15:28 +01:00
TOFU_DIR: pve01.wheatley.in/k8s-wheatley
2025-11-29 11:22:33 +01:00
AWS_S3_ENDPOINT: ${{ secrets.AWS_S3_ENDPOINT }}
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
TF_VAR_PROXMOX_API_TOKEN: ${{ secrets.PROXMOX_API_TOKEN }}
TF_VAR_PROXMOX_ENDPOINT: ${{ secrets.PROXMOX_ENDPOINT }}
2025-11-28 15:34:52 +01:00
jobs:
2025-11-28 20:53:52 +01:00
tofu-plan-k8s-wheatley:
2025-11-28 15:34:52 +01:00
runs-on: docker
steps:
- uses: actions/checkout@v4
2025-11-29 12:15:12 +01:00
- name: Download OpenTofu
id: download
run: |
set -eo pipefail
echo "Downloading OpenTofu..."
curl -L https://github.com/opentofu/opentofu/releases/download/v{{ env.TOFU_VERSION }}/tofu_{{ env.TOFU_VERSION }}_linux_amd64.tar.gz
echo "Downloaded OpenTofu ✅"
echo "Verifying checksum..."
if echo "{{ env.TOFU_CHECKSUM }} tofu_{{ env.TOFU_VERSION }}_linux_amd64.tar.gz" | sha256sum --check --status; then
echo "Checksum OK ✅"
else
echo "Checksum mismatch! ❌"
exit 1
working-directory: /tmp/tofu
- name: Install OpenTofu
run: |
echo "Untarring..."
tar -xzf tofu_{{ env.TOFU_VERSION }}_linux_amd64.tar.gz
echo "Untarring ✅"
echo "Installing OpenTofu Binary..."
mv tofu /usr/local/bin/tofu
chmod +x /usr/local/bin/tofu
echo "Installed Open Tofu ✅ Installed version:"
tofu version
working-directory: /tmp/tofu
2025-11-28 15:34:52 +01:00
- name: OpenTofu fmt
id: fmt
run: tofu fmt -check
2025-11-29 11:15:28 +01:00
working-directory: ${{ env.TOFU_DIR }}
2025-11-28 15:34:52 +01:00
continue-on-error: true
- name: OpenTofu Init
id: init
run: tofu init
2025-11-29 11:15:28 +01:00
working-directory: ${{ env.TOFU_DIR }}
2025-11-28 15:34:52 +01:00
- name: OpenTofu Validate
id: validate
run: tofu validate -no-color
2025-11-29 11:15:28 +01:00
working-directory: ${{ env.TOFU_DIR }}
2025-11-28 15:34:52 +01:00
- name: OpenTofu Plan
id: plan
run: tofu plan -no-color
2025-11-29 11:15:28 +01:00
working-directory: ${{ env.TOFU_DIR }}
2025-11-28 15:34:52 +01:00
continue-on-error: true