Skip to content

fix(actions): simplify env calls & add port to scp #28

fix(actions): simplify env calls & add port to scp

fix(actions): simplify env calls & add port to scp #28

Workflow file for this run

name: Push image and deploy
on:
push:
jobs:
push:
env:
IMAGE_NAME: test-bot
runs-on: ubuntu-latest
permissions:
packages: write
contents: read
steps:
- uses: actions/checkout@v4
- name: Build image
run: docker build . --file Dockerfile --tag $IMAGE_NAME
- name: Log into registry
run: echo "${{ secrets.CR_PAT }}" | docker login ghcr.io -u $ --password-stdin
- name: Push image
run: |
IMAGE_ID=ghcr.io/${{ github.repository_owner }}/$IMAGE_NAME
IMAGE_ID=$(echo $IMAGE_ID | tr '[A-Z]' '[a-z]')
VERSION=latest
echo IMAGE_ID=$IMAGE_ID
echo VERSION=$VERSION
docker tag $IMAGE_NAME $IMAGE_ID:$VERSION
docker push $IMAGE_ID:$VERSION
deploy:
needs: push
env:
HOST: ${{ secrets.SERVER_USERNAME }}@${{ secrets.SERVER_HOST }}
SSH_PORT: ${{ secrets.SERVER_PORT }}
IMAGE_ID: ghcr.io/paulyakow/test-bot:latest
DEPLOY_DIRECTORY: /srv/test-bot
ENV_FILE_PATH: /srv/test-bot/.env
runs-on: ubuntu-latest
steps:
- name: Create file with deploy key
env:
SSH_KEY: ${{ secrets.SERVER_KEY }}
run: |
echo "$SSH_KEY" > deploy_key
chmod 600 deploy_key
- name: Copy compose file
run: |
scp -i deploy_key -p $SSH_PORT -o StrictHostKeyChecking=no ${{ github.workspace }}/docker-compose.yaml $HOST:$DEPLOY_DIRECTORY/docker-compose.yaml
- name: Create .env file into deploy directory
run: |
ssh -i deploy_key -p $SSH_PORT -o StrictHostKeyChecking=no $HOST "\
echo IMAGE_ID=$IMAGE_ID > $ENV_FILE_PATH && \
echo TG_TOKEN=${{ secrets.TG_TOKEN }} >> $ENV_FILE_PATH && \
echo WEBHOOK_URL=${{ secrets.WEBHOOK_URL }} >> $ENV_FILE_PATH && \
echo WEBHOOK_PORT=${{ secrets.WEBHOOK_PORT }} >> $ENV_FILE_PATH && \
chmod 600 $ENV_FILE_PATH"
- name: Restart container
run: |
ssh -i deploy_key -p $SSH_PORT -o StrictHostKeyChecking=no $HOST "\
cd $DEPLOY_DIRECTORY && \
docker compose up -d"