--- # template source: https://github.com/bretfisher/docker-build-workflow/blob/main/templates/call-docker-build.yaml name: Hashicorp Vault on: #[push,pull_request] push: &vaultPaths paths: - 'hashicorp-vault/**/*.tf' pull_request: *vaultPaths # cancel any previously-started, yet still active runs of this workflow on the same branch concurrency: group: ${{ github.ref }}-${{ github.workflow }} cancel-in-progress: true .vault_step: &vault_step name: read vault secret uses: https://gitea.arcodange.duckdns.org/arcodange-org/vault-action.git@main id: vault-secrets with: url: https://vault.arcodange.duckdns.org jwtGiteaOIDC: ${{ needs.gitea_vault_auth.outputs.gitea_vault_jwt }} role: gitea_cicd method: jwt path: gitea_jwt secrets: | kvv1/google/credentials credentials | GOOGLE_BACKEND_CREDENTIALS ; kvv1/gitea/app id | TF_VAR_gitea_app_id ; kvv1/postgres/credentials_editor/credentials * | TF_VAR_POSTGRES_CREDENTIALS_EDITOR_ ; jobs: gitea_vault_auth: name: Auth with gitea for vault runs-on: ubuntu-latest outputs: gitea_vault_jwt: ${{steps.gitea_vault_jwt.outputs.id_token}} steps: - name: Auth with gitea for vault id: gitea_vault_jwt run: | echo -n "${{ secrets.vault_oauth__sh_b64 }}" | base64 -d | bash tofu: name: Tofu - Vault IAC needs: - gitea_vault_auth runs-on: ubuntu-latest env: OPENTOFU_VERSION: 1.8.2 TERRAFORM_VAULT_AUTH_JWT: ${{ needs.gitea_vault_auth.outputs.gitea_vault_jwt }} steps: - *vault_step - uses: actions/checkout@v4 # - uses: dflook/terraform-plan@v1 # with: # path: hashicorp-vault/iac - name: terraform apply uses: dflook/terraform-apply@v1 with: path: hashicorp-vault/iac auto_approve: true