version: '3.3' services: photoprism: build: . image: photoprism/photoprism:develop depends_on: - photoprism-db command: tail -f /dev/null volumes: - "~/.cache/npm:/root/.cache/npm" - "~/.cache/go-mod:/go/pkg/mod" environment: PHOTOPRISM_URL: "http://localhost:2342/" PHOTOPRISM_DEBUG: "false" PHOTOPRISM_READONLY: "false" PHOTOPRISM_PUBLIC: "true" PHOTOPRISM_UPLOAD_NSFW: "false" PHOTOPRISM_DETECT_NSFW: "true" PHOTOPRISM_PID_FILENAME: "photoprism.pid" PHOTOPRISM_LOG_FILENAME: "photoprism.log" PHOTOPRISM_DETACH_SERVER: "true" PHOTOPRISM_HTTP_HOST: "0.0.0.0" PHOTOPRISM_HTTP_PORT: 2342 PHOTOPRISM_DATABASE_DRIVER: "mysql" PHOTOPRISM_DATABASE_DSN: "root:photoprism@tcp(photoprism-db:4001)/photoprism?parseTime=true" PHOTOPRISM_TEST_DRIVER: "test" PHOTOPRISM_TITLE: "PhotoPrism" PHOTOPRISM_SUBTITLE: "Browse your life" PHOTOPRISM_DESCRIPTION: "Personal Photo Management tested by Travis CI." PHOTOPRISM_AUTHOR: "PhotoPrism.org" PHOTOPRISM_THUMB_FILTER: "lanczos" # Resample filter, best to worst: blackman, lanczos, cubic, linear PHOTOPRISM_THUMB_UNCACHED: "true" # On-demand rendering of default thumbnails (high memory and cpu usage) PHOTOPRISM_THUMB_SIZE: 2048 # Default thumbnail size limit (default 2048, min 720, max 3840) PHOTOPRISM_THUMB_LIMIT: 3840 # On-demand thumbnail size limit (default 2048, min 720, max 3840) PHOTOPRISM_JPEG_QUALITY: 90 # Use 95 for high-quality thumbnails (requires more storage) PHOTOPRISM_JPEG_HIDDEN: "true" # Create JPEG files in .photoprism (when converting other file types) PHOTOPRISM_SIDECAR_JSON: "true" # Read metadata from JSON sidecar files created by exiftool PHOTOPRISM_SIDECAR_YAML: "true" # Backup photo metadata to YAML sidecar files PHOTOPRISM_SIDECAR_HIDDEN: "true" # Create JSON and YAML sidecar files in .photoprism (if enabled) CODECOV_TOKEN: CODECOV_ENV: CODECOV_URL: CODECOV_SLUG: VCS_COMMIT_ID: VCS_BRANCH_NAME: VCS_PULL_REQUEST: VCS_SLUG: VCS_TAG: CI_BUILD_URL: CI_BUILD_ID: CI_JOB_ID: photoprism-db: image: mariadb:10.5 command: mysqld --port=4001 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci --max-connections=1024 --innodb-rollback-on-timeout=ON --innodb-lock-wait-timeout=120 expose: - "4001" volumes: - "./scripts/reset-test-db.sql:/docker-entrypoint-initdb.d/reset-test-db.sql" environment: MYSQL_ROOT_PASSWORD: photoprism MYSQL_USER: photoprism MYSQL_PASSWORD: photoprism MYSQL_DATABASE: photoprism webdav-dummy: image: photoprism/webdav:20200327