-
Notifications
You must be signed in to change notification settings - Fork 1
51 lines (45 loc) · 2.41 KB
/
ssh-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
name: CI/CD Deploy Pipeline # The name of the workflow
on:
pull_request:
types:
- closed
workflow_dispatch:
env:
BRANCH: ${{ vars.BRANCH_DEPLOYMENT }}
PROJECT_SSH_FOLDER: ${{ vars.SSH_FOLDER }}
REGISTRY: ghcr.io
PROD_NAME: ${{ vars.PROD_NAME }}
LABEL_SERVER: backend
LABEL_CLIENT: frontend-client
LABEL_ADMIN: frontend-admin
jobs:
deploy:
name: 'Publish Application'
runs-on: ubuntu-latest
steps:
- name: 'Run deploy on SSH'
if: github.event.pull_request.merged == true && github.event.pull_request.base.ref == ${{ env.BRANCH }}
uses: appleboy/ssh-action@v1.0.0
with:
host: ${{ vars.SSH_HOST }}
username: ${{ secrets.SSH_USERNAME }}
password: ${{ secrets.SSH_PASSWORD }}
port: ${{ vars.SSH_PORT }}
script: |
echo ${{ secrets.SSH_PASSWORD }} | sudo -S aa-remove-unknown
cd ${{ env.PROJECT_SSH_FOLDER }}
echo ${{ secrets.GITHUB_TOKEN }} | docker login ghcr.io -u ${{ github.repository_owner }} --password-stdin
if [[ "${{ contains(github.event.pull_request.labels.*.name, env.LABEL_SERVER) }}" == "true" ]]; then
docker rm $(docker stop $(docker ps -a -q --filter ancestor=${{ env.REGISTRY }}/${{ github.repository_owner }}/${{ env.PROD_NAME }}-server:latest ))
docker rmi ${{ env.REGISTRY }}/${{ github.repository_owner }}/${{ env.PROD_NAME }}-server:latest
fi
if [[ "${{ contains(github.event.pull_request.labels.*.name, env.LABEL_CLIENT) }}" == "true" ]]; then
docker rm $(docker stop $(docker ps -a -q --filter ancestor=${{ env.REGISTRY }}/${{ github.repository_owner }}/${{ env.PROD_NAME }}-client:latest ))
docker rmi ${{ env.REGISTRY }}/${{ github.repository_owner }}/${{ env.PROD_NAME }}-client:latest
fi
if [[ "${{ contains(github.event.pull_request.labels.*.name, env.LABEL_ADMIN) }}" == "true" ]]; then
docker rm $(docker stop $(docker ps -a -q --filter ancestor=${{ env.REGISTRY }}/${{ github.repository_owner }}/${{ env.PROD_NAME }}-admin:latest ))
docker rmi ${{ env.REGISTRY }}/${{ github.repository_owner }}/${{ env.PROD_NAME }}-admin:latest
fi
docker compose -f docker-compose.prod-ci.yml -p ${{ env.PROD_NAME }} pull
docker compose -f docker-compose.prod-ci.yml -p ${{ env.PROD_NAME }} up -d