55 lines
2.7 KiB
YAML
55 lines
2.7 KiB
YAML
kind: pipeline
|
|
type: docker # All steps will run in Docker containers.
|
|
|
|
name: update-and-restart-discord-bot # A descriptive name for the pipeline.
|
|
|
|
when:
|
|
- branch: main # This pipeline triggers on pushes to the 'main' branch.
|
|
event: push
|
|
|
|
steps:
|
|
- name: pull-latest-source # Step 1: Pull the latest code from Gitea.
|
|
image: alpine/git # A lightweight image that includes the 'git' command.
|
|
volumes:
|
|
# Mount your bot's source code directory with read-write permissions.
|
|
# This is crucial for 'git pull' to update the files on your host machine.
|
|
- /home/gary/Discord/Acrybot:/app:rw # ':rw' ensures read-write access.
|
|
commands:
|
|
- echo "--- Pulling latest source code from Git ---"
|
|
- cd /app # Navigate to the mounted project directory.
|
|
# Configure Git to trust the mounted directory to avoid 'unsafe repository' warnings.
|
|
- git config --global --add safe.directory /app
|
|
- git pull origin main # Pull the latest changes from the 'main' branch.
|
|
- echo "Source code updated."
|
|
|
|
- name: manage-bot-containers # Step 2: Manage your bot's Docker containers.
|
|
# Changed image to 'docker:latest' to use the unhyphenated 'docker compose'
|
|
image: docker:latest
|
|
volumes:
|
|
# Mount the Docker socket from the host to allow control over host Docker daemon.
|
|
- /var/run/docker.sock:/var/run/docker.sock
|
|
# Mount your Docker Compose project directory into the container.
|
|
- /home/gary/Discord/Acrybot:/app
|
|
environment:
|
|
# IMPORTANT: Explicitly set the Docker Compose project name.
|
|
# This ensures containers are managed with the 'Acrybot' prefix,
|
|
# matching your existing containers.
|
|
COMPOSE_PROJECT_NAME: Acrybot
|
|
commands:
|
|
- echo "--- Stopping Discord bot service python-app ---"
|
|
# Stop the specific Discord bot service using the unhyphenated 'docker compose'.
|
|
- docker compose stop python-app
|
|
|
|
- echo "--- Bringing Discord bot service up python-app ---"
|
|
# Bring the specific Discord bot service back up using the unhyphenated 'docker compose'.
|
|
# '--build' is essential if your docker-compose.yml uses 'build: .' to create the image,
|
|
# as it ensures the image is rebuilt with the newly pulled source code.
|
|
- docker compose up -d python-app --build
|
|
|
|
- echo "--- Verifying bot status ---"
|
|
# Get the container ID of the bot service to inspect its status and logs
|
|
- BOT_CONTAINER_ID=$(docker compose ps -q python-app)
|
|
- docker inspect --format='{{.State.Status}} (Exit Code: {{.State.ExitCode}})' "${BOT_CONTAINER_ID}"
|
|
- echo "--- Logs of Discord bot container (if it exited) ---"
|
|
- docker logs "${BOT_CONTAINER_ID}" # Fetch the logs of the bot container
|