0eb0fb5ee4
Drizzle ORM mutates client.options (parsers/serializers) after the postgres client is created, which causes the separately-passed password option to be lost on the actual connection attempt. Root cause confirmed on VPS: raw postgres.js query succeeded while drizzle.execute() failed with auth error. Fix: encode the password directly in DATABASE_URL (%23 = #, %5D = ], %3D = =). postgres.js decodes percent-encoding correctly. No separate DB_PASSWORD env var needed in the app container anymore. DB_PASSWORD is still used by the Postgres container (POSTGRES_PASSWORD). Coolify env var to set: DATABASE_URL=postgres://wc:<encoded-pass>@db:5432/worldcup Also adds resolver-level isMissingTable() guards so the app returns empty results instead of GraphQL errors on a fresh deploy before sync runs. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
20 lines
1.0 KiB
Bash
20 lines
1.0 KiB
Bash
# ── Production (Coolify) ────────────────────────────────────────────────────
|
|
# DATABASE_URL must include the password. Special characters must be
|
|
# percent-encoded so the URL parser handles them correctly:
|
|
# # → %23 ] → %5D = → %3D @ → %40
|
|
#
|
|
# Example with password "p#ss]w=rd":
|
|
# DATABASE_URL=postgres://wc:p%23ss%5Dw%3Drd@db:5432/worldcup
|
|
#
|
|
# DB_PASSWORD is used ONLY by the Postgres container (no encoding needed).
|
|
DATABASE_URL=postgres://wc:changeme@db:5432/worldcup
|
|
DB_PASSWORD=changeme
|
|
|
|
# Traefik (set TRAEFIK_ENABLED=true when deploying behind Traefik)
|
|
TRAEFIK_ENABLED=false
|
|
TRAEFIK_HOST=worldcup.example.com
|
|
NETWORK_NAME=traefik-network
|
|
|
|
# ── Local development ─────────────────────────────────────────────────────────
|
|
# DATABASE_URL=postgres://wc:wc@localhost:5432/worldcup
|