forked from SSWConsulting/SSW.Website
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile
128 lines (108 loc) · 4.46 KB
/
Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
FROM node:lts-alpine AS base
# Install dependencies only when needed
FROM base AS deps
# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed.
RUN apk add --no-cache libc6-compat
WORKDIR /app
# Install dependencies based on the preferred package manager
COPY package.json yarn.lock* package-lock.json* pnpm-lock.yaml* ./
RUN \
if [ -f yarn.lock ]; then yarn --frozen-lockfile; \
elif [ -f package-lock.json ]; then npm ci; \
elif [ -f pnpm-lock.yaml ]; then corepack enable pnpm && pnpm i --frozen-lockfile; \
else echo "Lockfile not found." && exit 1; \
fi
# Rebuild the source code only when needed
FROM base AS builder
WORKDIR /app
COPY --from=deps /app/node_modules ./node_modules
COPY . .
# Add env for production
# COPY .docker/production/.env.local .env.local
# Next.js collects completely anonymous telemetry data about general usage.
# Learn more here: https://nextjs.org/telemetry
# Uncomment the following line in case you want to disable telemetry during the build.
# ENV NEXT_TELEMETRY_DISABLED 1
ENV NODE_OPTIONS --max_old_space_size=8192
ARG NEXT_PUBLIC_GOOGLE_GTM_ID
ENV NEXT_PUBLIC_GOOGLE_GTM_ID $NEXT_PUBLIC_GOOGLE_GTM_ID
ARG NEXT_PUBLIC_GOOGLE_ANALYTICS
ENV NEXT_PUBLIC_GOOGLE_ANALYTICS $NEXT_PUBLIC_GOOGLE_ANALYTICS
ARG NEXT_PUBLIC_GITHUB_RUN_DATE
ENV NEXT_PUBLIC_GITHUB_RUN_DATE $NEXT_PUBLIC_GITHUB_RUN_DATE
ARG NEXT_PUBLIC_GITHUB_RUN_ID
ENV NEXT_PUBLIC_GITHUB_RUN_ID $NEXT_PUBLIC_GITHUB_RUN_ID
ARG NEXT_PUBLIC_GITHUB_RUN_NUMBER
ENV NEXT_PUBLIC_GITHUB_RUN_NUMBER $NEXT_PUBLIC_GITHUB_RUN_NUMBER
ARG NEXT_PUBLIC_GITHUB_REPOSITORY
ENV NEXT_PUBLIC_GITHUB_REPOSITORY $NEXT_PUBLIC_GITHUB_REPOSITORY
ARG NEXT_PUBLIC_HOTJAR_ID
ENV NEXT_PUBLIC_HOTJAR_ID $NEXT_PUBLIC_HOTJAR_ID
ARG NEXT_PUBLIC_HOTJAR_SV
ENV NEXT_PUBLIC_HOTJAR_SV $NEXT_PUBLIC_HOTJAR_SV
ARG NEXT_PUBLIC_TINA_CLIENT_ID
ENV NEXT_PUBLIC_TINA_CLIENT_ID $NEXT_PUBLIC_TINA_CLIENT_ID
ARG NEXT_PUBLIC_TINA_BRANCH
ENV NEXT_PUBLIC_TINA_BRANCH $NEXT_PUBLIC_TINA_BRANCH
ARG NEXT_PUBLIC_ZENDESK_CHAT_KEY
ENV NEXT_PUBLIC_ZENDESK_CHAT_KEY $NEXT_PUBLIC_ZENDESK_CHAT_KEY
ARG GOOGLE_RECAPTCHA_SITE_KEY
ENV GOOGLE_RECAPTCHA_SITE_KEY $GOOGLE_RECAPTCHA_SITE_KEY
ARG MICROSOFT_OAUTH_TENANT_ID
ENV MICROSOFT_OAUTH_TENANT_ID $MICROSOFT_OAUTH_TENANT_ID
ARG MICROSOFT_OAUTH_CLIENT_ID
ENV MICROSOFT_OAUTH_CLIENT_ID $MICROSOFT_OAUTH_CLIENT_ID
ARG MICROSOFT_OAUTH_CLIENT_SECRET
ENV MICROSOFT_OAUTH_CLIENT_SECRET $MICROSOFT_OAUTH_CLIENT_SECRET
ARG KEY_VAULT
ENV KEY_VAULT $KEY_VAULT
ARG NEXT_PUBLIC_APP_INSIGHT_CONNECTION_STRING
ENV NEXT_PUBLIC_APP_INSIGHT_CONNECTION_STRING $NEXT_PUBLIC_APP_INSIGHT_CONNECTION_STRING
ARG TINA_TOKEN
ENV TINA_TOKEN $TINA_TOKEN
ARG NEXT_PUBLIC_CHATBASE_BOT_ID
ENV NEXT_PUBLIC_CHATBASE_BOT_ID $NEXT_PUBLIC_CHATBASE_BOT_ID
ARG SITE_URL
ENV SITE_URL $SITE_URL
ARG YOUTUBE_PRIVATE_KEY
ENV YOUTUBE_PRIVATE_KEY $YOUTUBE_PRIVATE_KEY
ARG DYNAMICS_CLIENT_ID
ENV DYNAMICS_CLIENT_ID $DYNAMICS_CLIENT_ID
ARG DYNAMICS_CLIENT_SECRET
ENV DYNAMICS_CLIENT_SECRET $DYNAMICS_CLIENT_SECRET
ARG TINA_SEARCH_TOKEN
ENV TINA_SEARCH_TOKEN $TINA_SEARCH_TOKEN
ARG NEXT_PUBLIC_SLOT_URL
ENV NEXT_PUBLIC_SLOT_URL $NEXT_PUBLIC_SLOT_URL
RUN \
if [ -f yarn.lock ]; then yarn run build; \
elif [ -f package-lock.json ]; then npm run build; \
elif [ -f pnpm-lock.yaml ]; then corepack enable pnpm && pnpm run build; \
else echo "Lockfile not found." && exit 1; \
fi
# Production image, copy all the files and run next
FROM base AS runner
WORKDIR /app
ENV NODE_ENV production
# Uncomment the following line in case you want to disable telemetry during runtime.
# ENV NEXT_TELEMETRY_DISABLED 1
RUN addgroup --system --gid 1001 nodejs
RUN adduser --system --uid 1001 nextjs
COPY --from=builder /app/public ./public
# Set the correct permissions for the tina cache folder
RUN mkdir -p /app/tina
RUN chown nextjs:nodejs /app/tina
# Set the correct permission for prerender cache
RUN mkdir .next
RUN chown nextjs:nodejs .next
# Automatically leverage output traces to reduce image size
# https://nextjs.org/docs/advanced-features/output-file-tracing
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static
COPY --from=builder --chown=nextjs:nodejs /app/appInsight-api.js ./
USER nextjs
EXPOSE 3000
ENV PORT 3000
# server.js is created by next build from the standalone output
# https://nextjs.org/docs/pages/api-reference/next-config-js/output
CMD HOSTNAME="0.0.0.0" node --require ./appInsight-api.js server.js