PhotoPrism — Config Package
Last Updated: November 21, 2025
Overview
PhotoPrism’s runtime configuration is managed by this package. Fields are defined in options.go and then initialized with values from command-line flags, environment variables, and optional YAML files (storage/config/*.yml).
Sources and Precedence
PhotoPrism loads configuration in the following order:
- Built-in defaults defined in this package.
defaults.yml— optional configuration defaults. PhotoPrism first checks/etc/photoprism/defaults.yml(or.yaml). If that file is missing or empty, it automatically falls back tostorage/config/defaults.yml(respecting.yml/.yamlas well) underPHOTOPRISM_CONFIG_PATH. Seedefaults.ymlif you package PhotoPrism for other environments and need to override the compiled defaults.- Environment variables prefixed with
PHOTOPRISM_…and specified inflags.goalong with the CLI flags. This is the primary override mechanism in container environments. options.yml— user-level configuration stored understorage/config/options.yml(or another directory controlled byPHOTOPRISM_CONFIG_PATH). Values here override both defaults and environment variables, seeoptions.yml.- CLI flags (for example
photoprism --cache-path=/tmp/cache). Flags always win when a conflict exists.
The PHOTOPRISM_CONFIG_PATH variable controls where PhotoPrism looks for YAML files (defaults to storage/config).
Any change to configuration (flags, env vars, YAML files) requires a restart. The Go process reads options during startup and does not watch for changes.
Inspect Before Editing
Before changing environment variables or YAML files, run photoprism config | grep -i <flag> to confirm the current value of a flag, such as site-url, or site to show all related values:
photoprism config | grep -i site
Example output:
| Name | Value |
|---|---|
| site-url | https://app.localssl.dev/ |
| site-https | true |
| site-domain | app.localssl.dev |
| site-author | @photoprism_app |
| site-title | PhotoPrism |
CLI Reference
photoprism help(orphotoprism --help) lists all subcommands and global flags.photoprism show config(aliasphotoprism config) renders every active option along with its current value. Pass--json,--md,--tsv, or--csvto change the output format.photoprism show config-optionsprints the description and default value for each option. Use this when updatingflags.go.photoprism show config-yamldisplays the configuration keys and their expected types in the same structure that the YAML files use. It is a read-only helper meant to guide you when editing files understorage/config.- Additional
showsubcommands document search filters, metadata tags, and supported thumbnail sizes; seeinternal/commands/show.gofor the complete list.