Files
Lageplan/docker-compose.portainer.yml
Pepe Ziberi 362a7e4666
Some checks failed
Build and Push Docker Image / build-and-push (push) Has been cancelled
chore(ci): setup Gitea Actions + Portainer auto-deploy pipeline
2026-05-19 18:07:56 +02:00

135 lines
4.4 KiB
YAML

##############################################
# Lageplan — Portainer Stack (Auto-Deploy)
#
# Setup in Portainer:
# 1. Stacks → Add Stack → "Repository"
# 2. Git-URL: https://git.purepixel.ch/adminpepe/Lageplan.git
# 3. Compose-Pfad: docker-compose.portainer.yml
# 4. "GitOps updates" aktivieren + Webhook kopieren
# 5. Webhook in Gitea eintragen (Repo → Einstellungen → Webhooks)
# 6. Environment-Variablen setzen (siehe unten)
# 7. Deploy
#
# Danach: Push auf main → Gitea Actions baut Image →
# Portainer Webhook/Watchtower holt neues Image
#
# Benötigte Environment-Variablen:
# POSTGRES_USER (default: lageplan)
# POSTGRES_PASSWORD (ÄNDERN!)
# POSTGRES_DB (default: lageplan)
# NEXTAUTH_SECRET (ÄNDERN! — z.B. openssl rand -base64 32)
# NEXTAUTH_URL (z.B. https://lageplan.ch)
# MINIO_ROOT_USER (default: minioadmin)
# MINIO_ROOT_PASSWORD (ÄNDERN!)
# MINIO_PUBLIC_URL (z.B. https://s3.example.com)
# GITEA_REGISTRY_USER (für Watchtower Registry-Auth)
# GITEA_REGISTRY_PASS (für Watchtower Registry-Auth)
##############################################
services:
# ─── PostgreSQL ────────────────────────────
db:
image: postgres:16-alpine
restart: unless-stopped
environment:
POSTGRES_USER: ${POSTGRES_USER:-lageplan}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-lageplan_secret}
POSTGRES_DB: ${POSTGRES_DB:-lageplan}
volumes:
- postgres_data:/var/lib/postgresql/data
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER:-lageplan}"]
interval: 10s
timeout: 5s
retries: 5
networks:
- lageplan
# ─── MinIO (S3-kompatibler Objektspeicher) ─
minio:
image: minio/minio:latest
restart: unless-stopped
command: server /data --console-address ":9001"
environment:
MINIO_ROOT_USER: ${MINIO_ROOT_USER:-minioadmin}
MINIO_ROOT_PASSWORD: ${MINIO_ROOT_PASSWORD:-minioadmin123}
volumes:
- minio_data:/data
ports:
- "${MINIO_API_PORT:-9000}:9000"
- "${MINIO_CONSOLE_PORT:-9001}:9001"
healthcheck:
test: ["CMD", "mc", "ready", "local"]
interval: 10s
timeout: 5s
retries: 5
networks:
- lageplan
# ─── MinIO Bucket Init ─────────────────────
minio-init:
image: minio/mc:latest
depends_on:
minio:
condition: service_healthy
entrypoint: >
/bin/sh -c "
mc alias set myminio http://minio:9000 $${MINIO_ROOT_USER:-minioadmin} $${MINIO_ROOT_PASSWORD:-minioadmin123};
mc mb myminio/$${MINIO_BUCKET:-lageplan-icons} --ignore-existing;
mc anonymous set download myminio/$${MINIO_BUCKET:-lageplan-icons};
echo 'Bucket initialized';
exit 0;
"
networks:
- lageplan
# ─── Lageplan Web App ──────────────────────
# Image kommt aus Gitea Container Registry (gebaut via Gitea Actions)
web:
image: git.purepixel.ch/adminpepe/lageplan:latest
restart: unless-stopped
environment:
DATABASE_URL: postgresql://${POSTGRES_USER:-lageplan}:${POSTGRES_PASSWORD:-lageplan_secret}@db:5432/${POSTGRES_DB:-lageplan}
NEXTAUTH_URL: ${NEXTAUTH_URL:-https://localhost:3000}
NEXTAUTH_SECRET: ${NEXTAUTH_SECRET:-super-secret-key-change-in-production}
MINIO_ENDPOINT: minio
MINIO_PORT: "9000"
MINIO_ACCESS_KEY: ${MINIO_ROOT_USER:-minioadmin}
MINIO_SECRET_KEY: ${MINIO_ROOT_PASSWORD:-minioadmin123}
MINIO_BUCKET: ${MINIO_BUCKET:-lageplan-icons}
MINIO_USE_SSL: "false"
MINIO_PUBLIC_URL: ${MINIO_PUBLIC_URL:-http://localhost:9000}
ports:
- "${WEB_PORT:-3000}:3000"
depends_on:
db:
condition: service_healthy
minio:
condition: service_healthy
networks:
- lageplan
# ─── Watchtower (Auto-Restart bei neuen Images) ─
watchtower:
image: containrrr/watchtower
restart: unless-stopped
volumes:
- /var/run/docker.sock:/var/run/docker.sock
environment:
WATCHTOWER_POLL_INTERVAL: 60
WATCHTOWER_CLEANUP: "true"
WATCHTOWER_LABEL_ENABLE: "false"
# Gitea Registry Auth
REPO_USER: ${GITEA_REGISTRY_USER}
REPO_PASS: ${GITEA_REGISTRY_PASS}
networks:
- lageplan
volumes:
postgres_data:
minio_data:
networks:
lageplan:
driver: bridge