-
Notifications
You must be signed in to change notification settings - Fork 6
89 lines (79 loc) · 3.15 KB
/
prod-deploy.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
name: KTU Bot Production Deploy
on:
workflow_run:
workflows: ["KTU Bot Test Deploy"]
types:
- completed
jobs:
on-failure:
runs-on: ubuntu-latest
if: github.ref == 'refs/heads/prod' && github.event.workflow_run.conclusion == 'failure'
steps:
- run: echo "Test deployment failed.. Skipping prod deploy.." && exit 1
on-success:
runs-on: ubuntu-latest
if: github.ref == 'refs/heads/prod' && github.event.workflow_run.conclusion == 'success'
steps:
- run: echo "Test deployment successful.. Deploying prod..."
build-and-push:
name: Build and push docker image
runs-on: ubuntu-latest
needs: on-success
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Login to docker hub
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push docker image
uses: docker/build-push-action@v4
with:
context: .
push: true
tags: ${{ secrets.DOCKERHUB_USERNAME }}/ktu-bot:${{ github.sha }}
deploy:
name: Deploy docker container to VPS
runs-on: ubuntu-latest
needs: build-and-push
steps:
- name: Checkout repository
uses: actions/checkout@v4
- name: Deploy to VPS
uses: appleboy/ssh-action@master
with:
host: ${{ secrets.HOST }}
username: ${{ secrets.USERNAME }}
key: ${{ secrets.SSH_PRIVATE_KEY }}
port: 22
script: |
docker pull ${{ secrets.DOCKERHUB_USERNAME }}/ktu-bot:${{ github.sha }}
docker tag ${{ secrets.DOCKERHUB_USERNAME }}/ktu-bot:${{ github.sha }} ktu-bot:latest
docker stop ktu-bot || true
docker stop redis-queue-db || true
docker rm ktu-bot || true
docker rm redis-queue-db || true
docker network rm ktu-bot-network || true
docker network create ktu-bot-network || true
docker run -d --restart always -p 6379:6379 --network ktu-bot-network --network-alias redis-queue-db --name redis-queue-db redis
docker run -d \
--restart always \
-p 5000:5000 \
-e TZ=Asia/Kolkata \
--network ktu-bot-network \
-e ENV_TYPE=${{ secrets.ENV_TYPE }} \
-e ADMIN_ID=${{ secrets.ADMIN_ID }} \
-e WEBHOOK_DOMAIN=${{ secrets.WEBHOOK_DOMAIN }} \
-e WEBHOOK_PORT=${{ secrets.WEBHOOK_PORT }} \
-e BOT_TOKEN=${{ secrets.BOT_TOKEN }} \
-e FIREBASE_SERVICE_ACCOUNT="${{ secrets.FIREBASE_SERVICE_ACCOUNT }}" \
-e NODE_ENV=production \
-e HUGGING_FACE_TOKEN="${{ secrets.HUGGING_FACE_TOKEN }}" \
-e FIREBASE_STORAGE_BUCKET="${{ secrets.FIREBASE_STORAGE_BUCKET }}" \
-e LATEST_COMMIT=${{ github.sha }} \
-e UPTIME_ROBOT_API_KEY=${{ secrets.UPTIME_ROBOT_API_KEY }} \
-e ORIGIN_URL=${{ secrets.ORIGIN_URL }} \
--name ktu-bot \
-v /var/log/ktu-bot:/var/log/ktu-bot \
ktu-bot:latest