Merge remote-tracking branch 'origin/main'
This commit is contained in:
@@ -4,7 +4,7 @@ WORKDIR /app
|
|||||||
|
|
||||||
# --- Install + Build in one stage ---
|
# --- Install + Build in one stage ---
|
||||||
FROM base AS builder
|
FROM base AS builder
|
||||||
ARG CACHE_BUST=2
|
ARG CACHE_BUST=6
|
||||||
COPY . .
|
COPY . .
|
||||||
RUN pnpm install --no-frozen-lockfile
|
RUN pnpm install --no-frozen-lockfile
|
||||||
ENV NEXT_TELEMETRY_DISABLED=1
|
ENV NEXT_TELEMETRY_DISABLED=1
|
||||||
@@ -14,9 +14,11 @@ ENV NEXT_TELEMETRY_DISABLED=1
|
|||||||
ARG NEXT_PUBLIC_SITE_URL=https://myeasycms.de
|
ARG NEXT_PUBLIC_SITE_URL=https://myeasycms.de
|
||||||
ARG NEXT_PUBLIC_SUPABASE_URL=http://localhost:8000
|
ARG NEXT_PUBLIC_SUPABASE_URL=http://localhost:8000
|
||||||
ARG NEXT_PUBLIC_SUPABASE_PUBLIC_KEY
|
ARG NEXT_PUBLIC_SUPABASE_PUBLIC_KEY
|
||||||
|
ARG NEXT_PUBLIC_DEFAULT_LOCALE=de
|
||||||
ENV NEXT_PUBLIC_SITE_URL=${NEXT_PUBLIC_SITE_URL}
|
ENV NEXT_PUBLIC_SITE_URL=${NEXT_PUBLIC_SITE_URL}
|
||||||
ENV NEXT_PUBLIC_SUPABASE_URL=${NEXT_PUBLIC_SUPABASE_URL}
|
ENV NEXT_PUBLIC_SUPABASE_URL=${NEXT_PUBLIC_SUPABASE_URL}
|
||||||
ENV NEXT_PUBLIC_SUPABASE_PUBLIC_KEY=${NEXT_PUBLIC_SUPABASE_PUBLIC_KEY}
|
ENV NEXT_PUBLIC_SUPABASE_PUBLIC_KEY=${NEXT_PUBLIC_SUPABASE_PUBLIC_KEY}
|
||||||
|
ENV NEXT_PUBLIC_DEFAULT_LOCALE=${NEXT_PUBLIC_DEFAULT_LOCALE}
|
||||||
RUN pnpm --filter web build
|
RUN pnpm --filter web build
|
||||||
|
|
||||||
# --- Run ---
|
# --- Run ---
|
||||||
|
|||||||
@@ -321,13 +321,16 @@ services:
|
|||||||
environment:
|
environment:
|
||||||
NODE_ENV: production
|
NODE_ENV: production
|
||||||
NEXT_PUBLIC_SITE_URL: ${SITE_URL:-http://localhost:3000}
|
NEXT_PUBLIC_SITE_URL: ${SITE_URL:-http://localhost:3000}
|
||||||
# NEXT_PUBLIC_ vars are baked at build time — runtime values only apply
|
# Browser-side: external domain (baked at build time, re-stated here for SSR)
|
||||||
# to middleware/API routes. Don't override with Docker-internal URLs.
|
NEXT_PUBLIC_SUPABASE_URL: ${API_EXTERNAL_URL:-http://localhost:8000}
|
||||||
|
NEXT_PUBLIC_SUPABASE_PUBLIC_KEY: ${SUPABASE_ANON_KEY}
|
||||||
|
NEXT_PUBLIC_DEFAULT_LOCALE: de
|
||||||
|
# Server-side: Docker-internal URL (avoids hairpin NAT / DNS issues)
|
||||||
|
SUPABASE_INTERNAL_URL: http://supabase-kong:8000
|
||||||
SUPABASE_SECRET_KEY: ${SUPABASE_SERVICE_ROLE_KEY}
|
SUPABASE_SECRET_KEY: ${SUPABASE_SERVICE_ROLE_KEY}
|
||||||
SUPABASE_DB_WEBHOOK_SECRET: ${DB_WEBHOOK_SECRET:-webhooksecret}
|
SUPABASE_DB_WEBHOOK_SECRET: ${DB_WEBHOOK_SECRET:-webhooksecret}
|
||||||
EMAIL_SENDER: ${EMAIL_SENDER:-noreply@myeasycms.de}
|
EMAIL_SENDER: ${EMAIL_SENDER:-noreply@myeasycms.de}
|
||||||
NEXT_PUBLIC_PRODUCT_NAME: MyEasyCMS
|
NEXT_PUBLIC_PRODUCT_NAME: MyEasyCMS
|
||||||
NEXT_PUBLIC_DEFAULT_LOCALE: de
|
|
||||||
NEXT_PUBLIC_ENABLE_THEME_TOGGLE: "true"
|
NEXT_PUBLIC_ENABLE_THEME_TOGGLE: "true"
|
||||||
NEXT_PUBLIC_ENABLE_TEAM_ACCOUNTS: "true"
|
NEXT_PUBLIC_ENABLE_TEAM_ACCOUNTS: "true"
|
||||||
NEXT_PUBLIC_ENABLE_TEAM_ACCOUNTS_CREATION: "true"
|
NEXT_PUBLIC_ENABLE_TEAM_ACCOUNTS_CREATION: "true"
|
||||||
|
|||||||
@@ -2,8 +2,18 @@ import * as z from 'zod';
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns and validates the Supabase client keys from the environment.
|
* Returns and validates the Supabase client keys from the environment.
|
||||||
|
*
|
||||||
|
* On the server, prefers SUPABASE_INTERNAL_URL (Docker-internal)
|
||||||
|
* over NEXT_PUBLIC_SUPABASE_URL (external domain) to avoid
|
||||||
|
* hairpin NAT / DNS issues in containerized deployments.
|
||||||
*/
|
*/
|
||||||
export function getSupabaseClientKeys() {
|
export function getSupabaseClientKeys() {
|
||||||
|
const isServer = typeof window === 'undefined';
|
||||||
|
|
||||||
|
const url = isServer
|
||||||
|
? (process.env.SUPABASE_INTERNAL_URL || process.env.NEXT_PUBLIC_SUPABASE_URL)
|
||||||
|
: process.env.NEXT_PUBLIC_SUPABASE_URL;
|
||||||
|
|
||||||
return z
|
return z
|
||||||
.object({
|
.object({
|
||||||
url: z.string({
|
url: z.string({
|
||||||
@@ -14,7 +24,7 @@ export function getSupabaseClientKeys() {
|
|||||||
}),
|
}),
|
||||||
})
|
})
|
||||||
.parse({
|
.parse({
|
||||||
url: process.env.NEXT_PUBLIC_SUPABASE_URL,
|
url,
|
||||||
publicKey: process.env.NEXT_PUBLIC_SUPABASE_PUBLIC_KEY,
|
publicKey: process.env.NEXT_PUBLIC_SUPABASE_PUBLIC_KEY,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user