Files
provider-service/config/runtime.exs
HaimKortovich 141104822e
Some checks failed
Build and Publish / build-release (push) Failing after 5s
add auth
2026-05-15 10:21:36 -05:00

105 lines
3.4 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.
logger_level =
case System.get_env("LOG_LEVEL", "info") do
"debug" -> :debug
"info" -> :info
"warn" -> :warning
"error" -> :error
val when val in ["warning", "error"] -> :error
_ -> :info
end
config :logger, level: logger_level
config :logger, :console, format: {Logger.Formatter, :format}
cors_origin = System.get_env("CORS_ORIGIN", "*")
config :cors_plug,
origin: cors_origin
# Zitadel OIDC configuration
zitadel_issuer = System.get_env("ZITADEL_ISSUER", "https://id.corredorconect.com")
zitadel_client_id = System.get_env("ZITADEL_CLIENT_ID")
zitadel_client_secret = System.get_env("ZITADEL_CLIENT_SECRET")
zitadel_project_id = System.get_env("ZITADEL_PROJECT_ID")
config :provider_service, :zitadel,
issuer: zitadel_issuer,
client_id: zitadel_client_id,
client_secret: zitadel_client_secret,
project_id: zitadel_project_id,
roles_claim: "urn:zitadel:iam:org:project:#{zitadel_project_id}:roles",
required_scopes: [
"openid",
"profile",
"urn:zitadel:iam:org:project:#{zitadel_project_id}:roles",
"urn:zitadel:iam:org:project:#{zitadel_project_id}:aud"
]
# ## 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/provider_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 :provider_service, ProviderServiceWeb.Endpoint, server: true
end
if cookie = System.get_env("RELEASE_COOKIE") do
config :elixir, :cookie, cookie
end
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 :provider_service, ProviderService.Repo,
url: database_url,
pool_size: String.to_integer(System.get_env("DATABASE_POOL_SIZE") || "1"),
socket_options: maybe_ipv6
config :provider_service, ProviderService.EventStore,
serializer: Commanded.Serialization.JsonSerializer,
url: database_url,
schema: "eventstore",
pool_size: String.to_integer(System.get_env("EVENTSTORE_POOL_SIZE") || "1")
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 :provider_service, :dns_cluster_query, System.get_env("DNS_CLUSTER_QUERY")
config :provider_service, ProviderServiceWeb.Endpoint,
url: [host: host, port: String.to_integer(System.get_env("PORT", "4000")), scheme: "http"],
http: [
ip: {0, 0, 0, 0, 0, 0, 0, 0},
port: String.to_integer(System.get_env("PORT", "4000"))
],
secret_key_base: secret_key_base
end