-
Notifications
You must be signed in to change notification settings - Fork 1
127 lines (116 loc) · 5.57 KB
/
deploy-dev.yml
File metadata and controls
127 lines (116 loc) · 5.57 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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
name: Deployment (Dev)
on:
push:
branches: [development]
jobs:
build-and-push:
name: Build and Push to Docker Hub
runs-on: ubuntu-latest
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Docker metadata
id: meta
uses: docker/metadata-action@v5
with:
images: ${{secrets.DOCKER_USERNAME}}/kokomen-client
tags: |
type=raw,value=latest
type=raw,value=development
- name: Build and push
uses: docker/build-push-action@v5
with:
context: .
push: true
file: ./apps/client/Dockerfile
tags: ${{ steps.meta.outputs.tags }}
cache-from: type=registry,ref=${{ secrets.DOCKER_USERNAME }}/kokomen-client:buildcache
cache-to: type=registry,ref=${{ secrets.DOCKER_USERNAME }}/kokomen-client:buildcache,mode=max
build-args: |
NEXT_PUBLIC_POSTHOG_KEY=${{ secrets.NEXT_PUBLIC_POSTHOG_KEY }}
NEXT_PUBLIC_POSTHOG_HOST=${{ secrets.NEXT_PUBLIC_POSTHOG_HOST }}
SENTRY_AUTH_TOKEN=${{ secrets.SENTRY_AUTH_TOKEN }}
NEXT_PUBLIC_CDN_BASE_URL=${{ secrets.DEV_CDN_BASE_URL }}
NEXT_PUBLIC_GOOGLE_CLIENT_ID=${{ secrets.GOOGLE_CLIENT_ID_DEV }}
NEXT_PUBLIC_TOSS_PAYMENTS_CLIENT_KEY=${{ secrets.TOSS_PAYMENTS_CLIENT_KEY_DEV }}
NODE_ENV=production
NEXT_PUBLIC_BASE_URL=https://dev.kokomen.kr
NEXT_PUBLIC_API_BASE_URL=https://api-dev.kokomen.kr/api/v1
NEXT_PUBLIC_V2_API_BASE_URL=https://api-dev.kokomen.kr/api/v2
NEXT_PUBLIC_NOTIFICATION_API_BASE_URL=https://notification-api-dev.kokomen.kr/api/v1
NEXT_PUBLIC_V3_API_BASE_URL=https://api-dev.kokomen.kr/api/v3
NEXT_PUBLIC_GRAPHQL_URL=https://api-dev.kokomen.kr/api/v3/graphql
- name: Build summary
run: |
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
echo "✅ Docker image built and pushed successfully!"
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
echo ""
echo "🏷️ Tags:"
echo "${{ steps.meta.outputs.tags }}" | tr ',' '\n'
echo ""
echo "📦 Image: ${{ secrets.DOCKER_USERNAME }}/kokomen-client"
echo "🔀 Branch: ${{ github.ref_name }}"
echo "📝 Commit: ${{ github.sha }}"
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
deploy-to-ec2:
name: Deploy to EC2
needs: build-and-push
runs-on: [self-hosted, org, dev, new]
steps:
- name: Checkout source code
uses: actions/checkout@v4
- name: create .env file
run: |
echo "NEXT_PUBLIC_POSTHOG_KEY=${{ secrets.NEXT_PUBLIC_POSTHOG_KEY }}" > .env
echo "NEXT_PUBLIC_POSTHOG_HOST=${{ secrets.NEXT_PUBLIC_POSTHOG_HOST }}" >> .env
echo "SENTRY_AUTH_TOKEN=${{ secrets.SENTRY_AUTH_TOKEN }}" >> .env
echo "NEXT_PUBLIC_CDN_BASE_URL=${{ secrets.DEV_CDN_BASE_URL }}" >> .env
echo "NEXT_PUBLIC_GOOGLE_CLIENT_ID=${{ secrets.GOOGLE_CLIENT_ID_DEV }}" >> .env
echo "NEXT_PUBLIC_TOSS_PAYMENTS_CLIENT_KEY=${{ secrets.TOSS_PAYMENTS_CLIENT_KEY_DEV }}" >> .env
echo "NODE_ENV=production" >> .env
echo "NEXT_PUBLIC_BASE_URL=https://dev.kokomen.kr" >> .env
echo "NEXT_PUBLIC_API_BASE_URL=https://api-dev.kokomen.kr/api/v1" >> .env
echo "NEXT_PUBLIC_V2_API_BASE_URL=https://api-dev.kokomen.kr/api/v2" >> .env
echo "NEXT_PUBLIC_NOTIFICATION_API_BASE_URL=https://notification-api-dev.kokomen.kr/api/v1" >> .env
echo "NEXT_PUBLIC_V3_API_BASE_URL=https://api-dev.kokomen.kr/api/v3" >> .env
echo "NEXT_PUBLIC_GRAPHQL_URL=https://api-dev.kokomen.kr/api/v3/graphql" >> .env
# Security: Restrict .env permissions (readable only by owner)
chmod 600 .env
echo "✅ .env file created with secure permissions (600)"
- name: login to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Pull Docker image
run: |
docker pull ${{ secrets.DOCKER_USERNAME }}/kokomen-client:development
echo "✅ Docker image pulled successfully!"
- name: Stop and remove existing container
run: |
echo "Stopping existing containers..."
docker stop kokomen-client || true
docker rm kokomen-client || true
echo "✅ Old container removed"
continue-on-error: true
- name: Clean up previous stack
run: |
docker compose --env-file .env -f ./docker/client/compose.dev.yaml down --remove-orphans || true
docker system prune -af --volumes || true
- name: Run Docker Compose
run: |
docker compose --env-file .env -f ./docker/client/compose.dev.yaml up -d --pull always
env:
DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }}
- name: Deployment summary
run: |
echo "🚀 Deployment completed"
docker compose --env-file .env -f ./docker/client/compose.dev.yaml ps