Files
policy-service/config/runtime.exs
2026-04-14 12:37:54 -05:00

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