-
Notifications
You must be signed in to change notification settings - Fork 2
113 lines (105 loc) · 3.66 KB
/
cd.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
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.walletconnect.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.walletconnect.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 }}