generated from Pseudo-Lab/builder-template
-
Notifications
You must be signed in to change notification settings - Fork 3
103 lines (95 loc) ยท 3.61 KB
/
certificate-system.yml
File metadata and controls
103 lines (95 loc) ยท 3.61 KB
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
name: cert-system deploy (Production/Development, self-hosted)
on:
push:
branches:
- main
- deploy/cert-develop
paths:
- 'cert/**'
- '.github/workflows/certificate-system.yml'
workflow_dispatch:
# ๊ฐ์ ๋ธ๋์น ๋์ ์คํ ์ ์ด์ ์ก ์ทจ์(๊ฒฝ์ ๋ฐฐํฌ ๋ฐฉ์ง)
concurrency:
group: cert-${{ github.ref }}
cancel-in-progress: true
jobs:
deploy-prod:
if: github.ref_name == 'main'
name: ๐ Deploy cert-system (Production)
runs-on: oracle
environment: cert_prod_deploy
defaults:
run:
working-directory: ./cert
steps:
- uses: actions/checkout@v4
- name: Write .env (prod)
run: |
cat > .env <<'EOF'
APP_HOST=${{ vars.APP_HOST }}
ENVIRONMENT=${{ vars.ENVIRONMENT }}
NODE_ENV=${{ vars.NODE_ENV }}
DB_HOST=${{ vars.DB_HOST }}
DB_PORT=${{ vars.DB_PORT }}
DB_NAME=${{ vars.DB_NAME }}
DB_USER=${{ vars.DB_USER }}
DB_PASSWORD=${{ secrets.DB_PASSWORD }}
CERT_TEMPLATE_ARCHIVE_PASSWORD=${{ secrets.CERT_TEMPLATE_ARCHIVE_PASSWORD }}
NOTION_API_KEY=${{ secrets.NOTION_API_KEY }}
NOTION_CERT_DB_ID=${{ secrets.NOTION_CERT_DB_ID }}
NOTION_PROJ_DB_ID=${{ secrets.NOTION_PROJ_DB_ID }}
SMTP_HOST=${{ vars.SMTP_HOST }}
SMTP_PORT=${{ vars.SMTP_PORT }}
SMTP_USERNAME=${{ secrets.SMTP_USERNAME }}
SMTP_PASSWORD=${{ secrets.SMTP_PASSWORD }}
ACCESS_LOGGING_IP_SALT=${{ secrets.ACCESS_LOGGING_IP_SALT }}
CORS_ORIGINS=${{ vars.CORS_ORIGINS }}
FRONTEND_EXTERNAL_API_URL=${{ vars.FRONTEND_EXTERNAL_API_URL }}
EOF
- name: Build & up (prod)
run: |
set -euxo pipefail
docker compose -p cert-main config -q
docker compose -p cert-main down --remove-orphans
docker compose -p cert-main up -d --build --remove-orphans
docker image prune -f --filter "label=org.pseudolab.project=cert"
deploy-dev:
if: github.ref_name == 'deploy/cert-develop'
name: ๐ Deploy cert-system (Development)
runs-on: oracle
environment: cert_dev_deploy
defaults:
run:
working-directory: ./cert
steps:
- uses: actions/checkout@v4
- name: Write .env (dev)
run: |
cat > .env <<'EOF'
APP_HOST=${{ vars.APP_HOST }}
ENVIRONMENT=${{ vars.ENVIRONMENT }}
NODE_ENV=${{ vars.NODE_ENV }}
DB_HOST=${{ vars.DB_HOST }}
DB_PORT=${{ vars.DB_PORT }}
DB_NAME=${{ vars.DB_NAME }}
DB_USER=${{ vars.DB_USER }}
DB_PASSWORD=${{ secrets.DB_PASSWORD }}
CERT_TEMPLATE_ARCHIVE_PASSWORD=${{ secrets.CERT_TEMPLATE_ARCHIVE_PASSWORD }}
NOTION_API_KEY=${{ secrets.NOTION_API_KEY }}
NOTION_CERT_DB_ID=${{ secrets.NOTION_CERT_DB_ID }}
NOTION_PROJ_DB_ID=${{ secrets.NOTION_PROJ_DB_ID }}
SMTP_HOST=${{ vars.SMTP_HOST }}
SMTP_PORT=${{ vars.SMTP_PORT }}
SMTP_USERNAME=${{ secrets.SMTP_USERNAME }}
SMTP_PASSWORD=${{ secrets.SMTP_PASSWORD }}
ACCESS_LOGGING_IP_SALT=${{ secrets.ACCESS_LOGGING_IP_SALT }}
CORS_ORIGINS=${{ vars.CORS_ORIGINS }}
FRONTEND_EXTERNAL_API_URL=${{ vars.FRONTEND_EXTERNAL_API_URL }}
EOF
- name: Build & up (dev)
run: |
set -euxo pipefail
docker compose -p cert-dev config -q
docker compose -p cert-dev down --remove-orphans
docker compose -p cert-dev up -d --build --remove-orphans
docker image prune -f --filter "label=org.pseudolab.project=cert"