lago/.github/workflows/delete-preview.yml
2022-03-23 14:42:47 +01:00

48 lines
2.1 KiB
YAML

name: Delete Preview from Staging
on:
workflow_dispatch:
inputs:
preview_name:
description: Preview Name (domain)
required: true
jobs:
delete-preview:
name: Delete Preview Branch
if: github.event.inputs.preview_name != 'main'
runs-on: ubuntu-latest
container:
image: getlago/deploy-staging
env:
PORTER_HOST: https://dashboard.getporter.dev
PORTER_CLUSTER: ${{ secrets.PORTER_CLUSTER }}
PORTER_PROJECT: ${{ secrets.PORTER_PROJECT }}
PORTER_TOKEN: ${{ secrets.PORTER_TOKEN_2643 }}
steps:
- name: Configure AWS Credentials
uses: aws-actions/configure-aws-credentials@v1
with:
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
aws-region: us-east-1
- name: Login to Amazon ECR
id: login-ecr
uses: aws-actions/amazon-ecr-login@v1
- name: Configure kubectl
run: echo "${{ secrets.KUBE_STAGING_CONFIG }}" | base64 -d > kubeconfig.yaml
- name: Get Helm deployment
id: helm_deployment
run: echo "::set-output name=deployment::$(helm --kubeconfig ./kubeconfig.yaml list -f ${{ github.event.inputs.preview_name }}-app -o=json | jq '.[0].name')"
- name: Delete Front Preview
if: ${{ steps.helm_deployment.outputs.deployment != 'null' }}
run: |
echo "${{ steps.helm_deployment.outputs.deployment }}"
helm --kubeconfig ./kubeconfig.yaml uninstall ${{ github.event.inputs.preview_name }}-app
- name: Delete database
uses: porter-dev/porter-cli-action@v0.1.0
with:
command: run PGPASSWORD=${{ secrets.DB_STAGING_PASSWORD }} psql -h ${{ secrets.DB_STAGING_HOST }} -U lago -d postgres -c 'DROP DATABASE "${{ github.event.inputs.preview_name }} WITH (FORCE)"'
- name: Delete API Preview
if: ${{ steps.helm_deployment.outputs.deployment != 'null' }}
run: |
echo "${{ steps.helm_deployment.outputs.deployment }}"
helm --kubeconfig ./kubeconfig.yaml uninstall ${{ github.event.inputs.preview_name }}-api