name: CI/CD Pipeline on: push: branches: - master jobs: build-and-deploy: runs-on: shell steps: - name: Clone repository run: git clone --depth 1 "http://192.168.8.174:3000/${GITHUB_REPOSITORY}.git" . env: GIT_TERMINAL_PROMPT: '0' - name: Ensure Docker CLI run: which docker || apk add --no-cache docker-cli docker-cli-compose - name: Setup .env for CI/CD run: cp .env.example .env - name: Build Docker image run: docker compose build - name: Start container for test run: docker compose up -d - name: Verify bot running run: | sleep 5 docker compose logs --tail=20 - name: Stop container run: docker compose down - name: Login to Gitea Container Registry run: | echo "=== whoami: $(whoami) ===" echo "=== HOME: $HOME ===" echo "=== DOCKER_HOST: ${DOCKER_HOST:-unset} ===" echo "=== docker version ===" docker --version echo "=== docker info insecure ===" docker info 2>&1 | grep -A3 Insecure || echo "no insecure info" echo "=== attempting login ===" echo "${{ secrets.REGISTRY_TOKEN }}" | docker login http://192.168.8.174:3000 -u "${{ secrets.REGISTRY_USER }}" --password-stdin 2>&1 echo "=== exit code: $? ===" - name: Push image to registry run: docker push 192.168.8.174:3000/vrubel/t2s-telegram-bot:latest - name: Copy docker-compose to prod host run: scp docker-compose.prod.yml 192.168.8.171:~/services/t2sTelegramBot/docker-compose.yml - name: Deploy on prod host run: ssh 192.168.8.171 "cd ~/services/t2sTelegramBot && docker compose pull && docker compose up -d --remove-orphans"