Skip to content

Merge pull request #346 from Pseudo-Lab/fix/getcloser-security-config #42

Merge pull request #346 from Pseudo-Lab/fix/getcloser-security-config

Merge pull request #346 from Pseudo-Lab/fix/getcloser-security-config #42

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"