74 lines
2.7 KiB
Elixir
74 lines
2.7 KiB
Elixir
import Config
|
|
|
|
# config/runtime.exs is executed for all environments, including
|
|
# during releases. It is executed after compilation and before the
|
|
# system starts, so it is typically used to load production configuration
|
|
# and secrets from environment variables or elsewhere. Do not define
|
|
# any compile-time configuration in here, as it won't be applied.
|
|
# The block below contains prod specific runtime configuration.
|
|
|
|
# ## Using releases
|
|
#
|
|
# If you use `mix release`, you need to explicitly enable the server
|
|
# by passing the PHX_SERVER=true when you start it:
|
|
#
|
|
# PHX_SERVER=true bin/policy_service start
|
|
#
|
|
# Alternatively, you can use `mix phx.gen.release` to generate a `bin/server`
|
|
# script that automatically sets the env var above.
|
|
if System.get_env("PHX_SERVER") do
|
|
config :policy_service, PolicyServiceWeb.Endpoint, server: true
|
|
end
|
|
|
|
config :policy_service, PolicyServiceWeb.Endpoint,
|
|
http: [port: String.to_integer(System.get_env("PORT", "4000"))]
|
|
|
|
if config_env() == :prod do
|
|
database_url =
|
|
System.get_env("DATABASE_URL") ||
|
|
raise """
|
|
environment variable DATABASE_URL is missing.
|
|
For example: ecto://USER:PASS@HOST/DATABASE
|
|
"""
|
|
|
|
maybe_ipv6 = if System.get_env("ECTO_IPV6") in ~w(true 1), do: [:inet6], else: []
|
|
|
|
config :policy_service, PolicyService.Repo,
|
|
url: database_url,
|
|
pool_size: String.to_integer(System.get_env("POOL_SIZE") || "10"),
|
|
socket_options: maybe_ipv6
|
|
|
|
pg_host = System.get_env("PG_HOST") || System.get_env("PG_host")
|
|
pg_port = System.get_env("PG_PORT") || System.get_env("PG_port", "5432")
|
|
pg_user = System.get_env("PG_USER") || System.get_env("PG_username")
|
|
pg_password = System.get_env("PG_PASSWORD") || System.get_env("PG_password")
|
|
pg_database = System.get_env("PG_DATABASE") || System.get_env("PG_dbname")
|
|
|
|
config :policy_service, PolicyService.EventStore,
|
|
serializer: Commanded.Serialization.JsonSerializer,
|
|
username: pg_user || raise("PG_USER or PG_username is required"),
|
|
password: pg_password || raise("PG_PASSWORD or PG_password is required"),
|
|
database: pg_database || raise("PG_DATABASE or PG_dbname is required"),
|
|
hostname: pg_host || raise("PG_HOST or PG_host is required"),
|
|
port: String.to_integer(pg_port || "5432"),
|
|
pool_size: 5
|
|
|
|
secret_key_base =
|
|
System.get_env("SECRET_KEY_BASE") ||
|
|
raise """
|
|
environment variable SECRET_KEY_BASE is missing.
|
|
You can generate one by calling: mix phx.gen.secret
|
|
"""
|
|
|
|
host = System.get_env("PHX_HOST") || "example.com"
|
|
|
|
config :policy_service, :dns_cluster_query, System.get_env("DNS_CLUSTER_QUERY")
|
|
|
|
config :policy_service, PolicyServiceWeb.Endpoint,
|
|
url: [host: host, port: 80, scheme: "http"],
|
|
http: [
|
|
ip: {0, 0, 0, 0, 0, 0, 0, 0}
|
|
],
|
|
secret_key_base: secret_key_base
|
|
end
|