From 12e8875fa9dd29e81515d7fdcf99048e6b692447 Mon Sep 17 00:00:00 2001 From: pb-coding <71174645+pb-coding@users.noreply.github.com> Date: Sat, 23 Sep 2023 14:49:09 +0200 Subject: [PATCH] adds workflow --- .github/scripts/deploy.sh | 37 +++++++++++++++++++++++++++ .github/workflows/deploy.yml | 49 ++++++++++++++++++++++++++++++++++++ 2 files changed, 86 insertions(+) create mode 100644 .github/scripts/deploy.sh create mode 100644 .github/workflows/deploy.yml diff --git a/.github/scripts/deploy.sh b/.github/scripts/deploy.sh new file mode 100644 index 0000000..b8a6c1e --- /dev/null +++ b/.github/scripts/deploy.sh @@ -0,0 +1,37 @@ +#!/bin/bash +set -e + +# Configuration +DOCKER_REGISTRY="ghcr.io" +DOCKER_USERNAME="pb-coding" +DOCKER_IMAGE_NAME="skyjo-fe" +CONTAINER_NAME="skyjo-fe" +TARGET_DIRECTORY="/home/pb1497/deployments/$CONTAINER_NAME" +DOCKER_NETWORK="swag_net" + +# Authenticate with Docker registry +echo "Authenticating with Docker registry..." +docker login -u $DOCKER_USERNAME --password $GITHUB_TOKEN $DOCKER_REGISTRY + +# Pull the latest Docker image +echo "Pulling the latest Docker image..." +docker pull $DOCKER_REGISTRY/$DOCKER_USERNAME/$DOCKER_IMAGE_NAME:latest + +cd $TARGET_DIRECTORY + +# Stop and remove the existing container if it exists +if [ "$(docker ps -aq -f name=$CONTAINER_NAME)" ]; then + echo "Stopping and removing the existing container..." + docker stop $CONTAINER_NAME + docker rm $CONTAINER_NAME +fi + +# Run the new Docker container +echo "Starting a new container from the latest image..." +docker run -d \ + --name $CONTAINER_NAME \ + --network $DOCKER_NETWORK \ + -v $TARGET_DIRECTORY:/app \ + $DOCKER_REGISTRY/$DOCKER_USERNAME/$DOCKER_IMAGE_NAME:latest + +echo "Deployment complete." \ No newline at end of file diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml new file mode 100644 index 0000000..d6a7448 --- /dev/null +++ b/.github/workflows/deploy.yml @@ -0,0 +1,49 @@ +name: Build and push docker image and deploy + +on: + push: + branches: + - main + +jobs: + build_and_push: + runs-on: ubuntu-latest + + steps: + - name: Checkout repository + uses: actions/checkout@v3 + + - name: Log in to Github Container registry + uses: docker/login-action@v2 + with: + registry: ghcr.io + username: ${{ github.actor }} + password: ${{ secrets.DOCKER_REGISTRY_TOKEN }} + + - name: Build and push Docker image + uses: docker/build-push-action@v4 + with: + context: . + push: true + tags: ghcr.io/${{ github.actor }}/skyjo-fe:latest + + deploy: + needs: build_and_push + if: ${{ success() }} + runs-on: self-hosted + steps: + - name: Checkout repository + uses: actions/checkout@v3 + + - name: Deploy to target server + env: + DEPLOY_HOST: ${{ secrets.DEPLOY_HOST }} + DEPLOY_USER: ${{ secrets.DEPLOY_USER }} + DEPLOY_KEY: ${{ secrets.DEPLOY_KEY }} + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + run: | + echo "$DEPLOY_KEY" > deploy_key.pem + chmod 600 deploy_key.pem + scp -i deploy_key.pem -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null .github/scripts/deploy.sh $DEPLOY_USER@$DEPLOY_HOST:/tmp/ + ssh -i deploy_key.pem -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null $DEPLOY_USER@$DEPLOY_HOST "GITHUB_TOKEN=$GITHUB_TOKEN bash -s" < /tmp/deploy.sh + rm -f deploy_key.pem