--- name: tofu plan k8s-wheatley on: workflow_dispatch: workflow_call: pull_request: branches: - main # paths: # - pve01.wheatley.in/k8s-wheatley/** env: TOFU_VERSION: 1.10.7 TOFU_CHECKSUM: 765a7374aeafcad15fe8da5359de76ce11ba0fd3cb6c2dc85d3b390e6362cae5 TOFU_DIR: pve01.wheatley.in/k8s-wheatley 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 }} jobs: tofu-plan-k8s-wheatley: runs-on: docker steps: - uses: actions/checkout@v4 - 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 - name: OpenTofu fmt id: fmt run: tofu fmt -check working-directory: ${{ env.TOFU_DIR }} continue-on-error: true - name: OpenTofu Init id: init run: tofu init working-directory: ${{ env.TOFU_DIR }} - name: OpenTofu Validate id: validate run: tofu validate -no-color working-directory: ${{ env.TOFU_DIR }} - name: OpenTofu Plan id: plan run: tofu plan -no-color working-directory: ${{ env.TOFU_DIR }} continue-on-error: true