863b9503b3
- Template detail page now shows the render matching the SELECTED aspect (poster +
preview video) instead of the 16:9 cover cropped into a 9:16/1:1 box. TemplateVariant
carries per-aspect image/previewVideo; fetchTemplateVariants + the detail page wire them.
- AppShowcase3D ships a distinct preview video per aspect (seed PERASPECT_VIDEO).
- Frontend Dockerfile: Alpine -> node:20-slim (glibc). Fixes next-swc ("ld-linux..."
load failure that broke `next build` once libc6-compat was removed) AND the original
CI Alpine-CDN issue. Healthcheck switched to node (slim has no wget).
Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
84 lines
3.6 KiB
Docker
84 lines
3.6 KiB
Docker
# ── Stage 1: install dependencies ────────────────────────────────────────────
|
|
FROM mirror.soroushasadi.com/node:20-slim AS deps
|
|
# Debian (glibc) base on purpose: Alpine (musl) needs `libc6-compat` for next-swc,
|
|
# which is only on the geo-blocked Alpine CDN (unreachable from the CI server).
|
|
# Debian ships glibc, so next-swc's gnu binary loads natively — no apk, no CDN.
|
|
WORKDIR /app
|
|
|
|
COPY package.json package-lock.json* ./
|
|
# npm installs through the self-hosted Nexus mirror (override with --build-arg
|
|
# NPM_REGISTRY=... for a different mirror). The proxy intermittently returns 500s
|
|
# / corrupted tarballs while it back-fills from upstream, so retry the whole
|
|
# install a few times — each pass re-requests only what's still missing.
|
|
ARG NPM_REGISTRY=https://mirror.soroushasadi.com/repository/npm-group/
|
|
RUN for i in 1 2 3 4 5; do \
|
|
npm ci --registry "${NPM_REGISTRY}" \
|
|
--fetch-retries=5 --fetch-retry-factor=2 \
|
|
--fetch-retry-mintimeout=20000 --fetch-retry-maxtimeout=120000 && exit 0; \
|
|
echo "npm ci attempt $i failed; retrying in 10s..."; sleep 10; \
|
|
done; \
|
|
echo "npm ci failed after 5 attempts" && exit 1
|
|
|
|
# ── Stage 2: build ───────────────────────────────────────────────────────────
|
|
FROM mirror.soroushasadi.com/node:20-slim AS builder
|
|
WORKDIR /app
|
|
|
|
COPY --from=deps /app/node_modules ./node_modules
|
|
COPY . .
|
|
|
|
# NEXT_PUBLIC_* vars are embedded at build time — pass them as build args.
|
|
# Server-side secrets (STRIPE_SECRET_KEY, SUPABASE_SERVICE_ROLE_KEY, etc.)
|
|
# are injected at runtime via env / docker-compose and never baked into the image.
|
|
ARG NEXT_PUBLIC_SUPABASE_URL
|
|
ARG NEXT_PUBLIC_SUPABASE_ANON_KEY
|
|
ARG NEXT_PUBLIC_STRIPE_PUBLISHABLE_KEY
|
|
ARG NEXT_PUBLIC_SITE_URL=http://localhost:3000
|
|
# V2: browser-facing gateway base (host-exposed port) + tenant for Identity auth
|
|
ARG NEXT_PUBLIC_API_URL=http://localhost:8088/v1
|
|
ARG NEXT_PUBLIC_TENANT_SLUG=flatrender
|
|
# Browser-reachable MinIO base for public (user-uploads) object URLs.
|
|
ARG NEXT_PUBLIC_MINIO_URL=http://localhost:9000
|
|
|
|
ENV NEXT_PUBLIC_SUPABASE_URL=$NEXT_PUBLIC_SUPABASE_URL
|
|
ENV NEXT_PUBLIC_SUPABASE_ANON_KEY=$NEXT_PUBLIC_SUPABASE_ANON_KEY
|
|
ENV NEXT_PUBLIC_STRIPE_PUBLISHABLE_KEY=$NEXT_PUBLIC_STRIPE_PUBLISHABLE_KEY
|
|
ENV NEXT_PUBLIC_SITE_URL=$NEXT_PUBLIC_SITE_URL
|
|
ENV NEXT_PUBLIC_API_URL=$NEXT_PUBLIC_API_URL
|
|
ENV NEXT_PUBLIC_TENANT_SLUG=$NEXT_PUBLIC_TENANT_SLUG
|
|
ENV NEXT_PUBLIC_MINIO_URL=$NEXT_PUBLIC_MINIO_URL
|
|
|
|
ENV NEXT_TELEMETRY_DISABLED=1
|
|
ENV NODE_ENV=production
|
|
|
|
RUN npm run build
|
|
|
|
# ── Stage 3: production runner ────────────────────────────────────────────────
|
|
FROM mirror.soroushasadi.com/node:20-slim AS runner
|
|
WORKDIR /app
|
|
|
|
ENV NODE_ENV=production
|
|
ENV NEXT_TELEMETRY_DISABLED=1
|
|
|
|
# Create a non-root user (security best practice). Debian uses groupadd/useradd.
|
|
RUN groupadd --system --gid 1001 nodejs \
|
|
&& useradd --system --uid 1001 --gid nodejs nextjs
|
|
|
|
# Copy public assets
|
|
COPY --from=builder /app/public ./public
|
|
|
|
# standalone output: server.js + chunk bundles (no full node_modules)
|
|
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
|
|
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
|
|
|
|
# Prepare prerender cache dir with correct ownership
|
|
RUN mkdir -p .next && chown nextjs:nodejs .next
|
|
|
|
USER nextjs
|
|
|
|
EXPOSE 3000
|
|
ENV PORT=3000
|
|
ENV HOSTNAME=0.0.0.0
|
|
|
|
# Next.js standalone entry point
|
|
CMD ["node", "server.js"]
|