x-transcoder: &transcoder-base build: context: ./transcoder dockerfile: Dockerfile.dev networks: default: aliases: - transcoder ports: - "7666:7666" restart: on-failure cpus: 1 env_file: - ./.env environment: - GOCODER_PREFIX=/video volumes: - ${LIBRARY_ROOT}:/video:ro - ${CACHE_ROOT}:/cache - transcoder_metadata:/metadata develop: watch: - action: sync+restart path: ./transcoder target: /app services: # front: # build: # context: ./front # dockerfile: Dockerfile.dev # volumes: # - ./front:/app # - /app/.yarn # - /app/node_modules # - /app/apps/mobile/node_modules # - /app/apps/web/.next/ # - /app/apps/mobile/.expo/ # ports: # - "3000:3000" # - "8081:8081" # restart: on-failure # environment: # - KYOO_URL=${KYOO_URL:-http://api:5000/api} # labels: # - "traefik.enable=true" # - "traefik.http.routers.front.rule=PathPrefix(`/`)" auth: build: context: ./auth dockerfile: Dockerfile.dev restart: on-failure depends_on: postgres: condition: service_healthy ports: - "4568:4568" env_file: - ./.env labels: - "traefik.enable=true" - "traefik.http.routers.auth.rule=PathPrefix(`/auth/`) || PathPrefix(`/.well-known/`)" develop: watch: - action: sync+restart path: ./auth target: /app api: build: context: ./api dockerfile: Dockerfile.dev restart: on-failure depends_on: postgres: condition: service_healthy ports: - "3567:3567" environment: - KYOO_PREFIX=/api - JWT_ISSUER=${PUBLIC_URL} env_file: - ./.env labels: - "traefik.enable=true" - "traefik.http.routers.api.rule=PathPrefix(`/api/`) || PathPrefix(`/swagger`)" - "traefik.http.routers.api.middlewares=phantom-token" - "traefik.http.middlewares.phantom-token.forwardauth.address=http://auth:4568/auth/jwt" - "traefik.http.middlewares.phantom-token.forwardauth.authRequestHeaders=Authorization,X-Api-Key" - "traefik.http.middlewares.phantom-token.forwardauth.authResponseHeaders=Authorization" develop: watch: - action: sync path: ./api target: /app - action: rebuild path: ./api/packages.json scanner: build: ./scanner restart: on-failure depends_on: api: condition: service_started postgres: condition: service_healthy env_file: - ./.env ports: - "4389:4389" environment: # Use this env var once we use mTLS for auth # - KYOO_URL=${KYOO_URL:-http://api:3567/api} - KYOO_URL=${KYOO_URL:-http://traefik:8901/api} - JWKS_URL=http://auth:4568/.well-known/jwks.json - JWT_ISSUER=${PUBLIC_URL} volumes: - ${LIBRARY_ROOT}:/video:ro labels: - "traefik.enable=true" - "traefik.http.routers.scanner.rule=PathPrefix(`/scanner/`)" - "traefik.http.routers.scanner.middlewares=phantom-token" - "traefik.http.middlewares.phantom-token.forwardauth.address=http://auth:4568/auth/jwt" - "traefik.http.middlewares.phantom-token.forwardauth.authRequestHeaders=Authorization,X-Api-Key" - "traefik.http.middlewares.phantom-token.forwardauth.authResponseHeaders=Authorization" command: fastapi dev scanner --host 0.0.0.0 --port 4389 develop: watch: - action: sync path: ./scanner target: /app - action: rebuild path: ./scanner/pyproject.toml transcoder: <<: *transcoder-base profiles: ['', 'cpu'] transcoder-nvidia: <<: *transcoder-base deploy: resources: reservations: devices: - capabilities: [gpu] driver: cdi device_ids: - nvidia.com/gpu=all environment: - GOCODER_PREFIX=/video - GOCODER_HWACCEL=nvidia profiles: ['nvidia'] transcoder-vaapi: <<: *transcoder-base devices: - /dev/dri:/dev/dri environment: - GOCODER_PREFIX=/video - GOCODER_HWACCEL=vaapi - GOCODER_VAAPI_RENDERER=${GOCODER_VAAPI_RENDERER:-/dev/dri/renderD128} profiles: ['vaapi'] # qsv is the same setup as vaapi but with the hwaccel env var different transcoder-qsv: <<: *transcoder-base devices: - /dev/dri:/dev/dri environment: - GOCODER_PREFIX=/video - GOCODER_HWACCEL=qsv - GOCODER_VAAPI_RENDERER=${GOCODER_VAAPI_RENDERER:-/dev/dri/renderD128} profiles: ['qsv'] traefik: image: traefik:v3.4 restart: on-failure command: - "--providers.docker=true" - "--providers.docker.exposedbydefault=false" - "--entryPoints.web.address=:8901" - "--accesslog=true" ports: - "8901:8901" volumes: - "/var/run/docker.sock:/var/run/docker.sock:ro" postgres: image: postgres:15 restart: on-failure env_file: - ./.env volumes: - db:/var/lib/postgresql/data ports: - "5432:5432" environment: - POSTGRES_USER=$PGUSER - POSTGRES_PASSWORD=$PGPASSWORD - POSTGRES_DB=$PGDATABASE - POSTGRES_HOST_AUTH_METHOD=trust command: ["postgres", "-c", "log_statement=all"] healthcheck: test: ["CMD-SHELL", "pg_isready -U ${PGUSER} -d ${PGDATABASE}"] interval: 5s timeout: 5s retries: 5 volumes: db: transcoder_metadata: