diff --git a/packages/prisma/helper.ts b/packages/prisma/helper.ts index 3acd113fc..512f7cd55 100644 --- a/packages/prisma/helper.ts +++ b/packages/prisma/helper.ts @@ -15,6 +15,10 @@ export const getDatabaseUrl = () => { process.env.NEXT_PRIVATE_DIRECT_DATABASE_URL = process.env.DATABASE_URL; } + if (process.env.DATABASE_URL_UNPOOLED) { + process.env.NEXT_PRIVATE_DIRECT_DATABASE_URL = process.env.DATABASE_URL_UNPOOLED; + } + if (process.env.POSTGRES_PRISMA_URL) { process.env.NEXT_PRIVATE_DATABASE_URL = process.env.POSTGRES_PRISMA_URL; } @@ -40,18 +44,5 @@ export const getDatabaseUrl = () => { process.env.NEXT_PRIVATE_DATABASE_URL = url.toString().replace('https://', 'postgres://'); } - // Support for neon.tech (Neon Database) - if (url.hostname.endsWith('neon.tech')) { - const [projectId, ...rest] = url.hostname.split('.'); - - if (!projectId.endsWith('-pooler')) { - url.hostname = `${projectId}-pooler.${rest.join('.')}`; - } - - url.searchParams.set('pgbouncer', 'true'); - - process.env.NEXT_PRIVATE_DATABASE_URL = url.toString().replace('https://', 'postgres://'); - } - return process.env.NEXT_PRIVATE_DATABASE_URL; }; diff --git a/scripts/vercel.sh b/scripts/vercel.sh index abdcb0126..4be594f4e 100755 --- a/scripts/vercel.sh +++ b/scripts/vercel.sh @@ -68,16 +68,17 @@ function remap_database_integration() { export NEXT_PRIVATE_DIRECT_DATABASE_URL="$DATABASE_URL" fi + if [[ ! -z "$DATABASE_URL_UNPOOLED" ]]; then + log "Remapping for Neon integration" + + export NEXT_PRIVATE_DATABASE_URL="$DATABASE_URL&pgbouncer=true" + export NEXT_PRIVATE_DIRECT_DATABASE_URL="$DATABASE_URL_UNPOOLED" + fi + if [[ ! -z "$POSTGRES_URL_NON_POOLING" ]]; then export NEXT_PRIVATE_DATABASE_URL="$POSTGRES_URL?pgbouncer=true" export NEXT_PRIVATE_DIRECT_DATABASE_URL="$POSTGRES_URL_NON_POOLING" fi - - if [[ "$NEXT_PRIVATE_DATABASE_URL" == *"neon.tech"* ]]; then - log "Remapping for Neon integration" - - export NEXT_PRIVATE_DATABASE_URL="postgres://${PGUSER}:${PGPASSWORD}@${PGHOST}/${PGDATABASE}?pgbouncer=true" - fi } # Navigate to the root of the project. diff --git a/turbo.json b/turbo.json index 995ed43e5..5e2c5526c 100644 --- a/turbo.json +++ b/turbo.json @@ -90,6 +90,7 @@ "FONT_CAVEAT_URI", "POSTGRES_URL", "DATABASE_URL", + "DATABASE_URL_UNPOOLED", "POSTGRES_PRISMA_URL", "POSTGRES_URL_NON_POOLING", "E2E_TEST_AUTHENTICATE_USERNAME",