# This is a sample configuration file. You can generate your configuration # with the `bundle exec rails mastodon:setup` interactive setup wizard, but to customize # your setup even further, you'll need to edit it manually. This sample does # not demonstrate all available configuration options. Please look at # https://docs.joinmastodon.org/admin/config/ for the full documentation. # Note that this file accepts slightly different syntax depending on whether # you are using `docker-compose` or not. In particular, if you use # `docker-compose`, the value of each declared variable will be taken verbatim, # including surrounding quotes. # See: https://github.com/mastodon/mastodon/issues/16895 # Federation # ---------- # This identifies your server and cannot be changed safely later # ---------- # LOCAL_DOMAIN= # Redis # ----- REDIS_HOST=redis REDIS_PORT= # PostgreSQL # ---------- DB_HOST=db DB_USER=postgres DB_NAME=postgres DB_PASS= DB_PORT=5432 # Elasticsearch (optional) # ------------------------ ES_ENABLED=false ES_HOST=localhost ES_PORT=9200 # Authentication for ES (optional) ES_USER=elastic ES_PASS=password # Secrets # ------- # Make sure to use `bundle exec rails secret` to generate secrets # ------- #SECRET_KEY_BASE= #OTP_SECRET= # Encryption secrets # ------------------ # Must be available (and set to same values) for all server processes # These are private/secret values, do not share outside hosting environment # Use `bin/rails db:encryption:init` to generate fresh secrets # Do NOT change these secrets once in use, as this would cause data loss and other issues # ------------------ #ACTIVE_RECORD_ENCRYPTION_DETERMINISTIC_KEY= #ACTIVE_RECORD_ENCRYPTION_KEY_DERIVATION_SALT= #ACTIVE_RECORD_ENCRYPTION_PRIMARY_KEY= # Web Push # -------- # Generate with `bundle exec rails mastodon:webpush:generate_vapid_key` # -------- #VAPID_PRIVATE_KEY= #VAPID_PUBLIC_KEY= # Sending mail # ------------ #SMTP_SERVER= #SMTP_PORT= #SMTP_LOGIN= #SMTP_PASSWORD= #SMTP_FROM_ADDRESS= # File storage (optional) # ----------------------- S3_ENABLED=false S3_BUCKET=files.example.com AWS_ACCESS_KEY_ID= AWS_SECRET_ACCESS_KEY= S3_ALIAS_HOST=files.example.com # IP and session retention # ----------------------- # Make sure to modify the scheduling of ip_cleanup_scheduler in config/sidekiq.yml # to be less than daily if you lower IP_RETENTION_PERIOD below two days (172800). # ----------------------- IP_RETENTION_PERIOD=31556952 SESSION_RETENTION_PERIOD=31556952 # Fetch All Replies Behavior # -------------------------- # When a user expands a post (DetailedStatus view), fetch all of its replies # (default: false) FETCH_REPLIES_ENABLED=false # Period to wait between fetching replies (in minutes) FETCH_REPLIES_COOLDOWN_MINUTES=15 # Period to wait after a post is first created before fetching its replies (in minutes) FETCH_REPLIES_INITIAL_WAIT_MINUTES=5 # Max number of replies to fetch - total, recursively through a whole reply tree FETCH_REPLIES_MAX_GLOBAL=1000 # Max number of replies to fetch - for a single post FETCH_REPLIES_MAX_SINGLE=500 # Max number of replies Collection pages to fetch - total FETCH_REPLIES_MAX_PAGES=500 SINGLE_USER_MODE=false #EMAIL_DOMAIN_ALLOWLIST=