cd #80
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: cd | |
on: | |
workflow_dispatch: | |
push: | |
branches: | |
- "main" | |
paths: | |
- "terraform/**" | |
release: | |
types: ["published"] | |
concurrency: | |
# Only allow for one action to run at once, queue any others | |
group: cd | |
# Don't cancel existing | |
cancel-in-progress: false | |
jobs: | |
get-version: | |
runs-on: ubuntu-latest | |
outputs: | |
version: ${{ steps.clean_version.outputs.version }} | |
steps: | |
- id: get | |
uses: actions/github-script@v6 | |
env: | |
LATEST_TAG: ${{ steps.latest_release.outputs.release }} | |
with: | |
result-encoding: string | |
script: | | |
if (context.eventName == "release") { | |
return context.payload.release.tag_name | |
} else { | |
return "" | |
} | |
- id: clean_version | |
run: | | |
version=$(echo "${{ steps.get.outputs.result }}" | sed 's/v//g') | |
echo "version=$version" >> $GITHUB_OUTPUT | |
deploy-infra-staging: | |
runs-on: ubuntu-latest | |
environment: | |
name: staging | |
url: https://staging.cloud-auth-api.reown.com/health | |
needs: | |
- get-version | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- id: deploy-staging | |
uses: WalletConnect/actions/actions/deploy-terraform/@2.4.3 | |
env: | |
TF_VAR_node_env: staging | |
TF_VAR_supabase_jwt_secret: ${{ secrets.SUPABASE_JWT_SECRET }} | |
TF_VAR_cookie_name: ${{ secrets.COOKIE_NAME }} | |
TF_VAR_cookie_secret: ${{ secrets.COOKIE_SECRET }} | |
TF_VAR_hcaptcha_secret: ${{ secrets.HCAPTCHA_SECRET }} | |
TF_VAR_direct_url: ${{ secrets.DIRECT_URL }} | |
TF_VAR_database_url: ${{ secrets.DATABASE_URL }} | |
TF_VAR_redis_host: ${{ secrets.REDIS_HOST }} | |
TF_VAR_redis_port: ${{ secrets.REDIS_PORT }} | |
TF_VAR_redis_password: ${{ secrets.REDIS_PASSWORD }} | |
TF_VAR_walletconnect_project_id: ${{ secrets.WALLETCONNECT_PROJECT_ID }} | |
with: | |
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
aws-region: eu-central-1 | |
environment: staging | |
app-name: ${{ github.event.repository.name }} | |
# TODO add validation | |
# validate-staging: | |
# needs: [deploy-infra-staging] | |
# uses: ./.github/workflows/validate.yml | |
# with: | |
# environment: 'staging' | |
deploy-infra-prod: | |
runs-on: ubuntu-latest | |
environment: | |
name: prod | |
url: https://cloud-auth-api.reown.com/health | |
needs: | |
- get-version | |
# - validate-staging | |
- deploy-infra-staging | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- id: deploy-prod | |
uses: WalletConnect/actions/actions/deploy-terraform/@2.4.3 | |
env: | |
TF_VAR_node_env: production | |
TF_VAR_supabase_jwt_secret: ${{ secrets.SUPABASE_JWT_SECRET }} | |
TF_VAR_cookie_name: ${{ secrets.COOKIE_NAME }} | |
TF_VAR_cookie_secret: ${{ secrets.COOKIE_SECRET }} | |
TF_VAR_hcaptcha_secret: ${{ secrets.HCAPTCHA_SECRET }} | |
TF_VAR_direct_url: ${{ secrets.DIRECT_URL }} | |
TF_VAR_database_url: ${{ secrets.DATABASE_URL }} | |
TF_VAR_redis_host: ${{ secrets.REDIS_HOST }} | |
TF_VAR_redis_port: ${{ secrets.REDIS_PORT }} | |
TF_VAR_redis_password: ${{ secrets.REDIS_PASSWORD }} | |
TF_VAR_walletconnect_project_id: ${{ secrets.WALLETCONNECT_PROJECT_ID }} | |
with: | |
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
aws-region: eu-central-1 | |
environment: prod | |
app-name: ${{ github.event.repository.name }} |