-
Notifications
You must be signed in to change notification settings - Fork 7
93 lines (80 loc) · 2.68 KB
/
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
90
91
92
93
# name: CI/CD
# on:
# push:
# branches:
# - "*"
# pull_request:
# env:
# IMAGE_NAME: "project_badging"
# jobs:
# deploy:
# runs-on: ubuntu-latest
# if: github.ref == 'refs/heads/main' && github.event_name == 'push'
# steps:
# - uses: actions/checkout@v3
# - name: Build Docker image
# run: docker build -t ${{ env.IMAGE_NAME }}:${{ github.sha }} .
# - name: Create image archive
# run: docker save ${{ env.IMAGE_NAME }}:${{ github.sha }} -o badging.tar
# - name: Upload image archive using appleboy/scp-action
# uses: appleboy/[email protected]
# with:
# host: ${{ secrets.HOST }}
# username: ${{ secrets.USERNAME }}
# password: ${{ secrets.PASSWORD }}
# source: badging.tar
# target: ~/
# - name: Extract and load image on droplet
# uses: appleboy/[email protected]
# with:
# host: ${{ secrets.HOST }}
# username: ${{ secrets.USERNAME }}
# password: ${{ secrets.PASSWORD }}
# script: |
# if docker inspect ${{ env.IMAGE_NAME }} >/dev/null 2>&1; then
# docker stop ${{ env.IMAGE_NAME }}
# docker rm ${{ env.IMAGE_NAME }}
# fi
# docker load -i ~/badging.tar
# docker run -d \
# -p ${{ secrets.PORT }}:${{ secrets.PORT }} \
# --env-file /home/${{ secrets.USERNAME }}/.env \
# --restart=always \
# --name ${{ env.IMAGE_NAME }} \
# ${{ env.IMAGE_NAME }}:${{ github.sha }}
name: Node.js CI/CD
on:
push:
branches:
- "*"
pull_request:
env:
DEPLOY_FOLDER: "project-badging-backend"
jobs:
deploy:
runs-on: ubuntu-latest
if: github.ref == 'refs/heads/main' && github.event_name == 'push'
steps:
- name: Checkout repository
uses: actions/checkout@v2
- name: Cleanup existing content on the server
uses: appleboy/[email protected]
with:
host: ${{ secrets.HOST }}
username: ${{ secrets.USERNAME }}
password: ${{ secrets.PASSWORD }}
script: |
if [ -d ./${{ env.DEPLOY_FOLDER }} ]; then
cd ./${{ env.DEPLOY_FOLDER }}
find . -maxdepth 1 -type f ! -name '.env' -exec rm -f {} +
else
mkdir -p ./${{ env.DEPLOY_FOLDER }}
fi
- name: Upload repository contents to the server
uses: appleboy/[email protected]
with:
host: ${{ secrets.HOST }}
username: ${{ secrets.USERNAME }}
password: ${{ secrets.PASSWORD }}
source: ./
target: ./${{ env.DEPLOY_FOLDER }}/