Skip to content

fix(devops): add deployment workflow #1

fix(devops): add deployment workflow

fix(devops): add deployment workflow #1

Workflow file for this run

name: Deploy Bot
on:
push:
branches:
- main
jobs:
dump-env:
runs-on: ubuntu-latest
environment: PROD
steps:

Check failure on line 13 in .github/workflows/deploy_bot.yml

View workflow run for this annotation

GitHub Actions / .github/workflows/deploy_bot.yml

Invalid workflow file

You have an error in your yaml syntax on line 13
- name: Checkout Repository
uses: actions/checkout@v3
- name: Write Secret to .env File
env:
ENV_FILE: ${{ secrets.ENV_FILE }}
run: |
echo "$ENV_FILE" > .env
echo ".env file created with the contents of ENV_FILE secret"
- name: Set up SSH for Deployment
env:
SSH_USER: ${{ secrets.SSH_USER }}
SSH_PASSWORD: ${{ secrets.SSH_PASSWORD }}
SSH_HOST: ${{ secrets.SSH_HOST }}
run: |
apt-get update && apt-get install -y sshpass
sshpass -p "$SSH_PASSWORD" ssh -o StrictHostKeyChecking=no "$SSH_USER@$SSH_HOST" "mkdir -p ~/ovisbot"
- name: Upload Code to Server
env:
SSH_USER: ${{ secrets.SSH_USER }}
SSH_PASSWORD: ${{ secrets.SSH_PASSWORD }}
SSH_HOST: ${{ secrets.SSH_HOST }}
run: |
sshpass -p "$SSH_PASSWORD" rsync -avz --exclude '.git' ./ "$SSH_USER@$SSH_HOST:~/ovisbot"
- name: Deploy Application
env:
SSH_USER: ${{ secrets.SSH_USER }}
SSH_PASSWORD: ${{ secrets.SSH_PASSWORD }}
SSH_HOST: ${{ secrets.SSH_HOST }}
run: |
sshpass -p "$SSH_PASSWORD" ssh -o StrictHostKeyChecking=no "$SSH_USER@$SSH_HOST" << 'EOF'
cd ~/ovisbot
if [ -f docker-compose.yml ]; then
docker compose -f docker-compose.yml -f docker-compose.prod.yml down || true
docker compose -f docker-compose.yml -f docker-compose.prod.yml pull
docker compose -f docker-compose.yml -f docker-compose.prod.yml up -d
else
echo "docker-compose.yml not found in the repository!"
exit 1
fi
EOF