version: "2.3" services: nextcloud: image: linuxserver/nextcloud:18.0.3-ls71 container_name: nextcloud environment: - PUID={{ docker_user.id }} - PGID={{ docker_user.id }} - TZ=Europe/London volumes: - ./nextcloud/config:/config/www/nextcloud/config - ./nextcloud/apps:/config/www/nextcloud/apps - ./nextcloud/nginx-default.conf:/config/nginx/site-confs/default - /srv/nextcloud-data/data:/data - /opt/gitea/repos:/repos:ro - /mnt/media:/content:ro restart: unless-stopped tmpfs: - /config/log labels: - "traefik.enable=true" - "traefik.http.routers.nextcloud.rule=Host(`intersect.jakehoward.tech`)" - "traefik.http.routers.nextcloud.tls=true" - "traefik.http.routers.nextcloud.tls.certresolver=le" db: image: postgres:12-alpine restart: unless-stopped volumes: - ./postgres:/var/lib/postgresql/data environment: - POSTGRES_PASSWORD=nextcloud - POSTGRES_USER=nextcloud redis: image: redis:5-alpine restart: unless-stopped volumes: - ./redis:/data onlyoffice: image: onlyoffice/documentserver container_name: onlyoffice restart: unless-stopped environment: - JWT_ENABLED=true - JWT_SECRET={{ nextcloud.onlyoffice_jwt_secret }} labels: - "traefik.enable=true" - "traefik.http.routers.onlyoffice.rule=Host(`onlyoffice.jakehoward.tech`)" - "traefik.http.routers.onlyoffice.tls=true" - "traefik.http.routers.onlyoffice.tls.certresolver=le" - "traefik.http.routers.onlyoffice.middlewares=oo-header" - "traefik.http.middlewares.oo-header.headers.customRequestHeaders.X-Forwarded-Proto=https"