diff --git a/.github/workflows/deploy-dev.yml b/.github/workflows/deploy-dev.yml new file mode 100644 index 0000000..6b2ded7 --- /dev/null +++ b/.github/workflows/deploy-dev.yml @@ -0,0 +1,43 @@ +name: Deploy dev + +on: + workflow_run: + workflows: + - Build and Push Docker Image for DEV + types: + - completed + +jobs: + deploy: + runs-on: ubuntu-latest + if: ${{ github.event.workflow_run.conclusion == 'success' }} + + env: + DOCKER_REGISTRY: ghcr.io + DOCKER_REPO: liberty52/liberty52-admin-server + + steps: + - name: Get latest Release tag + id: latest-tag + uses: robinraju/release-downloader@v1.8 + with: + latest: true + token: ${{ secrets.GITHUB_TOKEN }} + + - name: Set Docker Image Name + id: new-docker-image + run: echo "::set-output name=image_name::$DOCKER_REGISTRY/$DOCKER_REPO:dev-${{ steps.latest-tag.outputs.tag_name }}" + + - name: Deploy AWS EC2 dev + uses: appleboy/ssh-action@master + with: + host: ${{ secrets.REMOTE_IP_DEV }} + username: ${{ secrets.REMOTE_SSH_ID_DEV }} + key: ${{ secrets.REMOTE_SSH_KEY_DEV }} + port: ${{ secrets.REMOTE_SSH_PORT_DEV }} + script: | + echo ${{ secrets.GTOKEN }} | sudo docker login ghcr.io -u ${{ github.actor }} --password-stdin + sudo docker pull ${{ steps.new-docker-image.outputs.image_name }} + container_name=$(sudo docker ps | grep liberty52 | awk '{print $NF}') + sudo docker stop $container_name + sudo docker run -d -p 8080:8080 ${{ steps.new-docker-image.outputs.image_name }} \ No newline at end of file diff --git a/.github/workflows/deploy-prod.yml b/.github/workflows/deploy-prod.yml new file mode 100644 index 0000000..eb12004 --- /dev/null +++ b/.github/workflows/deploy-prod.yml @@ -0,0 +1,30 @@ +name: Deploy prod + +on: + workflow_run: + workflows: + - "Build and Push Docker Image for PROD" + types: + - completed + +jobs: + deploy: + runs-on: ubuntu-latest + if: ${{ github.event.workflow_run.conclusion == 'success' }} + env: + DOCKER_IMAGE: ghcr.io/liberty52/liberty52-admin-server:prod-${{ github.sha }} + + steps: + - name: Deploy AWS EC2 dev + uses: appleboy/ssh-action@master + with: + host: ${{ secrets.REMOTE_IP_PROD }} + username: ${{ secrets.REMOTE_SSH_ID_PROD }} + key: ${{ secrets.REMOTE_SSH_KEY_PROD }} + port: ${{ secrets.REMOTE_SSH_PORT_PROD }} + script: | + echo ${{ secrets.GTOKEN }} | sudo docker login ghcr.io -u ${{ github.actor }} --password-stdin + sudo docker pull $DOCKER_IMAGE + container_name=$(sudo docker ps | grep liberty52 | awk '{print $NF}') + sudo docker stop $container_name + sudo docker run -d -p 8080:8080 $DOCKER_IMAGE \ No newline at end of file