diff --git a/stacks/traefik/docker-compose.yml b/stacks/traefik/docker-compose.yml new file mode 100644 index 0000000..4ba3d0d --- /dev/null +++ b/stacks/traefik/docker-compose.yml @@ -0,0 +1,64 @@ +services: + traefik: + image: traefik:v3.6 + container_name: traefik + restart: unless-stopped + security_opt: + - no-new-privileges:true + + command: + - --api.dashboard=true + - --api.insecure=false + - --providers.docker=true + - --providers.docker.exposedbydefault=false + - --providers.docker.network=frontend_net + - --providers.file.directory=/dynamic + - --providers.file.watch=true + - --entrypoints.web.address=:80 + - --entrypoints.web.http.redirections.entrypoint.to=websecure + - --entrypoints.web.http.redirections.entrypoint.scheme=https + - --entrypoints.web.http.redirections.entrypoint.permanent=true + - --entrypoints.websecure.address=:443 + - --entrypoints.websecure.http.tls=true + - --certificatesresolvers.le.acme.email=mi.kaleschke@gmx.de + - --certificatesresolvers.le.acme.storage=/letsencrypt/acme.json + - --certificatesresolvers.le.acme.dnschallenge=true + - --certificatesresolvers.le.acme.dnschallenge.provider=cloudflare + - --accesslog=true + - --log.level=INFO + + environment: + - CF_DNS_API_TOKEN_FILE=/run/secrets/cloudflare_dns_api_token + + ports: + - "80:80" + - "443:443" + + volumes: + - /var/run/docker.sock:/var/run/docker.sock:ro + - /mnt/user/appdata/traefik/dynamic:/dynamic:ro + - /mnt/user/appdata/traefik/letsencrypt:/letsencrypt + + secrets: + - cloudflare_dns_api_token + + networks: + - frontend_net + + labels: + - "traefik.enable=true" + - "traefik.docker.network=frontend_net" + - "traefik.http.routers.traefik.rule=Host(`traefik.kaleschke.info`)" + - "traefik.http.routers.traefik.entrypoints=websecure" + - "traefik.http.routers.traefik.tls=true" + - "traefik.http.routers.traefik.tls.certresolver=le" + - "traefik.http.routers.traefik.service=api@internal" + - "traefik.http.routers.traefik.middlewares=dashboard-auth@file,secure-headers@file" + +networks: + frontend_net: + external: true + +secrets: + cloudflare_dns_api_token: + file: /mnt/user/appdata/traefik/secrets/cloudflare_dns_api_token \ No newline at end of file