import Config # For production, we often load configuration from external # sources, such as your system environment. For this reason, # you won't find the :http configuration below, but set inside # Pleroma.Web.Endpoint.load_from_system_env/1 dynamically. # Any dynamic configuration should be moved to such function. # # Don't forget to configure the url host to something meaningful, # Phoenix uses this information when generating URLs. # # Finally, we also include the path to a cache manifest # containing the digested version of static files. This # manifest is generated by the mix phoenix.digest task # which you typically run after static files are built. config :pleroma, Pleroma.Web.Endpoint, http: [port: 4000], protocol: "http" config :phoenix, serve_endpoints: true # Do not print debug messages in production config :logger, :console, level: :info config :logger, :ex_syslogger, level: :info # PromEx set up config :pleroma, Pleroma.Web.Plugs.MetricsPredicate, auth_token: System.fetch_env!("PROMETHEUS_AUTH_TOKEN") config :pleroma, Pleroma.PromEx, prometheus_data_source_id: System.fetch_env!("PROMETHEUS_DATASOURCE_ID"), grafana: [ host: System.fetch_env!("GRAFANA_HOST"), auth_token: System.fetch_env!("GRAFANA_AUTH_TOKEN"), upload_dashboards_on_start: true, folder_name: "Pleroma - PromEx", annotate_app_lifecycle: true ] # ## SSL Support # # To get SSL working, you will need to add the `https` key # to the previous section and set your `:url` port to 443: # # config :pleroma, Pleroma.Web.Endpoint, # ... # url: [host: "example.com", port: 443], # https: [:inet6, # port: 443, # keyfile: System.get_env("SOME_APP_SSL_KEY_PATH"), # certfile: System.get_env("SOME_APP_SSL_CERT_PATH")] # # Where those two env variables return an absolute path to # the key and cert in disk or a relative path inside priv, # for example "priv/ssl/server.key". # # We also recommend setting `force_ssl`, ensuring no data is # ever sent via http, always redirecting to https: # # config :pleroma, Pleroma.Web.Endpoint, # force_ssl: [hsts: true] # # Check `Plug.SSL` for all available options in `force_ssl`. # ## Using releases # # If you are doing OTP releases, you need to instruct Phoenix # to start the server for all endpoints: # # config :phoenix, :serve_endpoints, true # # Alternatively, you can configure exactly which server to # start per endpoint: # # config :pleroma, Pleroma.Web.Endpoint, server: true # # Finally import the config/prod.secret.exs # which should be versioned separately. cond do File.exists?("./config/prod.secret.exs") -> import_config "prod.secret.exs" System.get_env("CI") == "true" -> nil true -> "`config/prod.secret.exs` not found. You may want to create one by running `mix pleroma.instance gen`" |> IO.warn([]) end if File.exists?("./config/prod.exported_from_db.secret.exs"), do: import_config("prod.exported_from_db.secret.exs")