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

78 lines
2.3 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 12:20:13 +01:00
TOFU_ARCHIVE: tofu_${{ env.TOFU_VERSION }}_linux_amd64.tar.gz
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 }}
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..."
2025-11-29 12:20:13 +01:00
curl -L https://github.com/opentofu/opentofu/releases/download/v${{ env.TOFU_VERSION }}/${{ env.TOFU_ARCHIVE }} -o ${{ env.TOFU_ARCHIVE }}
2025-11-29 12:15:12 +01:00
echo "Downloaded OpenTofu ✅"
echo "Verifying checksum..."
2025-11-29 12:25:45 +01:00
printf "%s %s" "${{ env.TOFU_CHECKSUM }}" "${{ env.TOFU_ARCHIVE }}" | sha256sum --check --status
2025-11-29 12:29:13 +01:00
echo "Checksum ok ✅"
2025-11-29 12:15:55 +01:00
working-directory: /tmp
2025-11-29 12:15:12 +01:00
- name: Install OpenTofu
run: |
echo "Untarring..."
2025-11-29 12:20:13 +01:00
tar -xzf ${{ env.TOFU_ARCHIVE }}
2025-11-29 12:15:12 +01:00
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
2025-11-29 12:15:55 +01:00
working-directory: /tmp
2025-11-29 12:15:12 +01:00
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
env:
TF_VAR_PROXMOX_API_TOKEN: ${{ secrets.PROXMOX_API_TOKEN }}
TF_VAR_PROXMOX_ENDPOINT: ${{ secrets.PROXMOX_ENDPOINT }}
2025-11-29 15:42:26 +01:00
run: |
echo "Proxmox endpoint: ${TF_VAR_PROXMOX_ENDPOINT}"
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