docker-compose.yml 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. services:
  2. bambuddy:
  3. image: ghcr.io/maziggy/bambuddy:latest
  4. build: .
  5. # Usage:
  6. # docker compose up -d → pulls pre-built image from ghcr.io
  7. # docker compose up -d --build → builds locally from source
  8. container_name: bambuddy
  9. # Run as current user to avoid permission issues with mounted volumes
  10. # Override with: PUID=$(id -u) PGID=$(id -g) docker compose up -d
  11. user: "${PUID:-1000}:${PGID:-1000}"
  12. #
  13. # Proxy mode: allow binding to privileged ports (322, 990) as non-root user.
  14. # Without this, the FTP and RTSP proxies silently fail.
  15. cap_add:
  16. - NET_BIND_SERVICE
  17. #
  18. # LINUX: Use host mode for printer discovery and camera streaming
  19. network_mode: host
  20. #
  21. # macOS/WINDOWS: Docker Desktop doesn't support host mode.
  22. # Comment out "network_mode: host" above and uncomment "ports:" below.
  23. # Note: Printer discovery won't work - add printers manually by IP.
  24. #ports:
  25. # - "${PORT:-8000}:8000"
  26. # - "3000:3000" # Virtual printer bind/detect
  27. # - "3002:3002" # Virtual printer bind/detect
  28. # - "8883:8883" # Virtual printer MQTT
  29. # - "990:990" # Virtual printer FTP control
  30. # - "6000:6000" # Virtual printer file transfer tunnel
  31. # - "322:322" # Virtual printer RTSP camera (X1/H2/P2)
  32. # - "2024-2026:2024-2026" # Virtual printer proprietary ports (A1/P1S)
  33. # - "50000-50100:50000-50100" # Virtual printer FTP passive data
  34. volumes:
  35. - bambuddy_data:/app/data
  36. - bambuddy_logs:/app/logs
  37. #
  38. # Share virtual printer certs with native installation
  39. # This ensures the slicer only needs to trust one CA certificate.
  40. - ./virtual_printer:/app/data/virtual_printer
  41. #
  42. # Mount scheduled backup output to NAS or external storage
  43. # Backups default to DATA_DIR/backups/ inside the data volume.
  44. # Uncomment to store them externally (e.g. on a NAS share).
  45. #- /path/to/nas/bambuddy-backups:/app/data/backups
  46. environment:
  47. - TZ=${TZ:-Europe/Berlin}
  48. # Port BamBuddy runs on (default: 8000)
  49. # Usage: PORT=8080 docker compose up -d
  50. - PORT=${PORT:-8000}
  51. # Virtual printer: Set to the Docker host's IP when using bridge mode (ports:).
  52. # Required for FTP passive mode to work behind NAT.
  53. # Example: VIRTUAL_PRINTER_PASV_ADDRESS=192.168.1.100
  54. #- VIRTUAL_PRINTER_PASV_ADDRESS=
  55. #
  56. # External PostgreSQL (optional — uses SQLite by default)
  57. # Example: DATABASE_URL=postgresql+asyncpg://bambuddy:password@db-host:5432/bambuddy
  58. #- DATABASE_URL=
  59. restart: unless-stopped
  60. # Optional: External PostgreSQL database
  61. # Uncomment to run Postgres alongside Bambuddy (or use an external Postgres host)
  62. #postgres:
  63. # image: postgres:16-alpine
  64. # container_name: bambuddy-db
  65. # restart: unless-stopped
  66. # environment:
  67. # POSTGRES_USER: bambuddy
  68. # POSTGRES_PASSWORD: changeme
  69. # POSTGRES_DB: bambuddy
  70. # volumes:
  71. # - bambuddy_pgdata:/var/lib/postgresql/data
  72. # ports:
  73. # - "5432:5432"
  74. volumes:
  75. bambuddy_data:
  76. bambuddy_logs:
  77. #bambuddy_pgdata: