import Config # For development, we disable any cache and enable # debugging and code reloading. # # The watchers configuration can be used to run external # watchers to your application. For example, we use it # with brunch.io to recompile .js and .css sources. config :mobilizon, Mobilizon.Web.Endpoint, http: [ port: 4000 ], url: [ host: System.get_env("MOBILIZON_INSTANCE_HOST", "mobilizon.local"), port: 80, scheme: "http" ], debug_errors: true, code_reloader: true, check_origin: false, watchers: [ # yarn: ["run", "dev", cd: Path.expand("../js", __DIR__)] node: [ "node_modules/webpack/bin/webpack.js", "--mode", "development", "--watch-stdin", "--config", "node_modules/@vue/cli-service/webpack.config.js", cd: Path.expand("../js", __DIR__) ] ] # ## SSL Support # # In order to use HTTPS in development, a self-signed # certificate can be generated by running the following # command from your terminal: # # openssl req -new -newkey rsa:4096 -days 365 -nodes -x509 -subj "/C=US/ST=Denial/L=Springfield/O=Dis/CN=www.example.com" -keyout priv/server.key -out priv/server.pem # # The `http:` config above can be replaced with: # # https: [port: 4000, keyfile: "priv/server.key", certfile: "priv/server.pem"], # # If desired, both `http:` and `https:` keys can be # configured to run both http and https servers on # different ports. # Watch static and templates for browser reloading. config :mobilizon, Mobilizon.Web.Endpoint, live_reload: [ patterns: [ ~r{priv/static/.*(js|css|png|jpeg|jpg|gif|svg)$}, ~r{priv/gettext/.*(po)$}, ~r{lib/mobilizon_web/views/.*(ex)$}, ~r{lib/mobilizon_web/templates/.*(eex)$} ] ] # Do not include metadata nor timestamps in development logs config :logger, :console, format: "[$level] $message\n", level: :debug config :mobilizon, Mobilizon.Service.Geospatial, service: Mobilizon.Service.Geospatial.Nominatim # Set a higher stacktrace during development. Avoid configuring such # in production as building large stacktraces may be expensive. config :phoenix, :stacktrace_depth, 20 # Initialize plugs at runtime for faster development compilation config :phoenix, :plug_init_mode, :runtime config :mobilizon, Mobilizon.Web.Email.Mailer, adapter: Bamboo.LocalAdapter # Configure your database config :mobilizon, Mobilizon.Storage.Repo, username: System.get_env("MOBILIZON_DATABASE_USERNAME", "mobilizon"), password: System.get_env("MOBILIZON_DATABASE_PASSWORD", "mobilizon"), database: System.get_env("MOBILIZON_DATABASE_DBNAME", "mobilizon_dev"), hostname: System.get_env("MOBILIZON_DATABASE_HOST", "localhost"), port: System.get_env("MOBILIZON_DATABASE_PORT", "5432"), pool_size: 10, show_sensitive_data_on_connection_error: true config :mobilizon, :instance, name: System.get_env("MOBILIZON_INSTANCE_NAME", "Mobilizon"), hostname: System.get_env("MOBILIZON_INSTANCE_HOST", "Mobilizon"), email_from: System.get_env("MOBILIZON_INSTANCE_EMAIL"), email_reply_to: System.get_env("MOBILIZON_INSTANCE_EMAIL"), registrations_open: System.get_env("MOBILIZON_INSTANCE_REGISTRATIONS_OPEN") == "true", groups: true # config :mobilizon, :activitypub, sign_object_fetches: false config :mobilizon, :anonymous, reports: [ allowed: true ] require Logger cond do System.get_env("INSTANCE_CONFIG") && File.exists?("./config/#{System.get_env("INSTANCE_CONFIG")}") -> import_config System.get_env("INSTANCE_CONFIG") System.get_env("DOCKER", "false") == "false" && File.exists?("./config/dev.secret.exs") -> import_config "dev.secret.exs" System.get_env("DOCKER", "false") == "true" -> Logger.info("Using environment configuration for Docker") true -> Logger.error("No configuration file found") end