haste/.woodpecker.yml

172 lines
5.3 KiB
YAML

labels:
location: manager
clone:
git:
image: woodpeckerci/plugin-git
settings:
partial: false
depth: 1
# dns:
# - 1.1.1.1
# - 1.0.0.1
steps:
# Build and Push for Staging
build-push-staging:
name: build-push-staging
image: woodpeckerci/plugin-docker-buildx
environment:
REGISTRY_USER:
from_secret: REGISTRY_USER
REGISTRY_PASSWORD:
from_secret: REGISTRY_PASSWORD
DOCKER_REGISTRY_USER:
from_secret: DOCKER_REGISTRY_USER
DOCKER_REGISTRY_PASSWORD:
from_secret: DOCKER_REGISTRY_PASSWORD
settings:
# dns:
# - 1.1.1.1
# - 1.0.0.1
volumes:
- /var/run/docker.sock:/var/run/docker.sock
commands:
- HOSTNAME=$(docker info --format '{{.Name}}')
- 'echo "Worker hostname: $HOSTNAME"'
- 'echo "Logging into registries"'
- echo "$${DOCKER_REGISTRY_PASSWORD}" | docker login -u "$${DOCKER_REGISTRY_USER}" --password-stdin
- echo "$${REGISTRY_PASSWORD}" | docker login -u "$${REGISTRY_USER}" --password-stdin git.nixc.us
- 'echo "Building and pushing application for staging"'
- docker compose -f docker-compose.staging.yml build --no-cache
- docker compose -f docker-compose.staging.yml push
when:
branch: main
event: push
# Deploy Staging
deploy-staging:
name: deploy-staging
image: woodpeckerci/plugin-docker-buildx
environment:
REGISTRY_USER:
from_secret: REGISTRY_USER
REGISTRY_PASSWORD:
from_secret: REGISTRY_PASSWORD
settings:
# dns:
# - 1.1.1.1
# - 1.0.0.1
volumes:
- /var/run/docker.sock:/var/run/docker.sock
commands:
- HOSTNAME=$(docker info --format '{{.Name}}')
- 'echo "Worker hostname: $HOSTNAME"'
- 'echo "Deploying to staging environment"'
- echo "$${REGISTRY_PASSWORD}" | docker login -u "$${REGISTRY_USER}" --password-stdin git.nixc.us
- docker stack deploy --with-registry-auth -c ./stack.staging.yml $${CI_REPO_NAME}-staging
when:
branch: main
event: push
# Wait for Deploy to Complete
wait-for-deploy-staging:
name: wait-for-deploy-staging
image: woodpeckerci/plugin-docker-buildx # Changed to match other steps with Docker support
settings:
# dns:
# - 1.1.1.1
# - 1.0.0.1
volumes:
- /var/run/docker.sock:/var/run/docker.sock # Required for docker info
commands:
- HOSTNAME=$(docker info --format '{{.Name}}')
- 'echo "Worker hostname: $HOSTNAME"'
- 'echo "Waiting for staging deploy step to complete rollout."'
- sleep 20
when:
branch: main
event: push
# Cleanup Staging
cleanup-staging:
name: cleanup-staging
image: woodpeckerci/plugin-docker-buildx
environment:
REGISTRY_USER:
from_secret: REGISTRY_USER
REGISTRY_PASSWORD:
from_secret: REGISTRY_PASSWORD
settings:
# dns:
# - 1.1.1.1
# - 1.0.0.1
volumes:
- /var/run/docker.sock:/var/run/docker.sock
commands:
- HOSTNAME=$(docker info --format '{{.Name}}')
- 'echo "Worker hostname: $HOSTNAME"'
- 'echo "Cleaning up staging environment"'
- for i in {1..5}; do docker stack rm $${CI_REPO_NAME}-staging && break || sleep 10; done
- docker compose -f docker-compose.staging.yml down
- docker compose -f docker-compose.staging.yml rm -f
when:
branch: main
event: push
# Build and Push for Production
build-push-production:
name: build-push-production
image: woodpeckerci/plugin-docker-buildx
environment:
REGISTRY_USER:
from_secret: REGISTRY_USER
REGISTRY_PASSWORD:
from_secret: REGISTRY_PASSWORD
DOCKER_REGISTRY_USER:
from_secret: DOCKER_REGISTRY_USER
DOCKER_REGISTRY_PASSWORD:
from_secret: DOCKER_REGISTRY_PASSWORD
settings:
# dns:
# - 1.1.1.1
# - 1.0.0.1
volumes:
- /var/run/docker.sock:/var/run/docker.sock
commands:
- HOSTNAME=$(docker info --format '{{.Name}}')
- 'echo "Worker hostname: $HOSTNAME"'
- 'echo "Logging into registries"'
- echo "$${DOCKER_REGISTRY_PASSWORD}" | docker login -u "$${DOCKER_REGISTRY_USER}" --password-stdin
- echo "$${REGISTRY_PASSWORD}" | docker login -u "$${REGISTRY_USER}" --password-stdin git.nixc.us
- 'echo "Building and pushing application for production"'
- docker compose -f docker-compose.production.yml build --no-cache
- docker compose -f docker-compose.production.yml push
when:
branch: main
event: [push, cron]
# Deploy Production
deploy-production:
name: deploy-production
image: woodpeckerci/plugin-docker-buildx
environment:
REGISTRY_USER:
from_secret: REGISTRY_USER
REGISTRY_PASSWORD:
from_secret: REGISTRY_PASSWORD
settings:
# dns:
# - 1.1.1.1
# - 1.0.0.1
volumes:
- /var/run/docker.sock:/var/run/docker.sock
commands:
- HOSTNAME=$(docker info --format '{{.Name}}')
- 'echo "Worker hostname: $HOSTNAME"'
- 'echo "Deploying to production environment"'
- echo "$${REGISTRY_PASSWORD}" | docker login -u "$${REGISTRY_USER}" --password-stdin git.nixc.us
- docker stack deploy --with-registry-auth -c ./stack.production.yml $${CI_REPO_NAME}
when:
branch: main
event: [push, cron]