Files
stacks/gitea/compose.yml
Sebastian Krüger f21e0611b4 Add self-contained Docker Compose stacks for pivoine.art infrastructure
Migrated 11 services from monolithic docker-compose project into independent stacks,
each with dedicated databases, minimal .env configuration, and bind-mount data volumes.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-15 22:41:50 +01:00

105 lines
4.1 KiB
YAML

---
services:
gitea:
image: gitea/gitea:latest
container_name: gitea
environment:
TZ: ${TIMEZONE:-Europe/Amsterdam}
USER_UID: 1000
USER_GID: 1000
GITEA__APP_NAME: dev.pivoine.art
GITEA__database__DB_TYPE: postgres
GITEA__database__HOST: gitea_db:5432
GITEA__database__NAME: gitea
GITEA__database__USER: gitea
GITEA__database__PASSWD: gitea
GITEA__server__DOMAIN: ${TRAEFIK_HOST}
GITEA__server__SSH_DOMAIN: ${TRAEFIK_HOST}
GITEA__server__ROOT_URL: https://${TRAEFIK_HOST}/
GITEA__server__PROTOCOL: http
GITEA__server__HTTP_PORT: 3000
GITEA__server__START_SSH_SERVER: "true"
GITEA__server__SSH_PORT: 2222
GITEA__server__SSH_LISTEN_PORT: 2222
GITEA__mailer__ENABLED: "true"
GITEA__mailer__PROTOCOL: smtp
GITEA__mailer__SMTP_ADDR: mailpit
GITEA__mailer__SMTP_PORT: 1025
GITEA__service__DISABLE_REGISTRATION: "false"
GITEA__service__REQUIRE_SIGNIN_VIEW: "false"
GITEA__service__ENABLE_NOTIFY_MAIL: "true"
GITEA__service__DEFAULT_EMAIL_NOTIFICATIONS: enabled
GITEA__packages__ENABLED: "true"
GITEA__actions__ENABLED: "true"
GITEA__ui__THEMES: gitea-auto,gitea-light,gitea-dark,arc-green,edge-auto,edge-dark,edge-light,everforest-auto,everforest-dark,everforest-light,gruvbox-auto,gruvbox-dark,gruvbox-light,gruvbox-material-auto,gruvbox-material-dark,gruvbox-material-light,nord,palenight,soft-era,sonokai,sonokai-andromeda,sonokai-atlantis,sonokai-espresso,sonokai-maia,sonokai-shusia
GITEA__ui__DEFAULT_THEME: edge-dark
GITEA__ui__ENABLE_FEED: "true"
ports:
- "2222:2222"
volumes:
- ../.data/gitea/data:/data
- ../.data/gitea/config:/etc/gitea
- ./themes:/data/gitea/public/assets/css:ro
- /etc/localtime:/etc/localtime:ro
depends_on:
db:
condition: service_healthy
restart: always
labels:
- "traefik.enable=true"
- "traefik.http.middlewares.gitea-redirect-web-secure.redirectscheme.scheme=https"
- "traefik.http.routers.gitea-web.middlewares=gitea-redirect-web-secure"
- "traefik.http.routers.gitea-web.rule=Host(`${TRAEFIK_HOST}`)"
- "traefik.http.routers.gitea-web.entrypoints=web"
- "traefik.http.routers.gitea-web-secure.rule=Host(`${TRAEFIK_HOST}`)"
- "traefik.http.routers.gitea-web-secure.tls.certresolver=resolver"
- "traefik.http.routers.gitea-web-secure.entrypoints=web-secure"
- "traefik.http.routers.gitea-web-secure.middlewares=security-headers@file"
- "traefik.http.services.gitea-web-secure.loadbalancer.server.port=3000"
- "traefik.docker.network=${NETWORK_NAME}"
- "com.centurylinklabs.watchtower.enable=true"
networks:
- compose_network
runner:
image: gitea/act_runner:latest
container_name: gitea_runner
privileged: true
command: ["act_runner", "daemon", "--config", "/data/config.yaml"]
environment:
TZ: ${TIMEZONE:-Europe/Amsterdam}
GITEA_INSTANCE_URL: https://${TRAEFIK_HOST}
GITEA_RUNNER_REGISTRATION_TOKEN: ${RUNNER_TOKEN}
GITEA_RUNNER_NAME: docker-runner
GITEA_RUNNER_LABELS: ubuntu-latest:docker://catthehacker/ubuntu:act-latest,ubuntu-22.04:docker://catthehacker/ubuntu:act-22.04,ubuntu-20.04:docker://catthehacker/ubuntu:act-20.04
DOCKER_HOST: unix:///var/run/docker.sock
volumes:
- ../.data/gitea/runner:/data
- /var/run/docker.sock:/var/run/docker.sock
- ./runner-config.yaml:/data/config.yaml:ro
labels:
- "com.centurylinklabs.watchtower.enable=true"
restart: always
networks:
- compose_network
db:
image: postgres:16-alpine
container_name: gitea_db
environment:
POSTGRES_DB: gitea
POSTGRES_USER: gitea
POSTGRES_PASSWORD: gitea
volumes:
- ../.data/gitea/db:/var/lib/postgresql/data
restart: always
healthcheck:
test: ["CMD-SHELL", "pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}"]
interval: 5s
timeout: 5s
retries: 5
networks:
- compose_network
networks:
compose_network:
name: ${NETWORK_NAME}
external: true