fix(security): wire Guardian secret_key (raise in prod) #1

Merged
jules merged 1 commits from fix/audit-security-blockers into main 2026-06-21 01:15:22 +00:00
Showing only changes of commit 20ce45717a - Show all commits

View File

@@ -23,6 +23,18 @@ end
config :arcadia_cloud, ArcadiaCloudWeb.Endpoint,
http: [port: String.to_integer(System.get_env("PORT", "4005"))]
# Guardian shared secret — arcadia-cloud only *verifies* arcadia-core-issued
# JWTs, so this MUST match arcadia-core's Arcadia.Guardian secret or every
# authed route 401s. Without it Guardian cannot verify at all. Prod supplies
# GUARDIAN_SECRET_KEY (raise if missing); dev/test use the pinned shared secret.
config :arcadia_cloud, ArcadiaCloud.Guardian,
secret_key:
System.get_env("GUARDIAN_SECRET_KEY") ||
if(config_env() == :prod,
do: raise("environment variable GUARDIAN_SECRET_KEY is missing"),
else: "DuMkIRN3Qcxk8VqOu8nHj5i7a7a7YgBHF4oXqKwDI4A="
)
if config_env() == :prod do
database_url =
System.get_env("DATABASE_URL") ||