diff --git a/Dockerfile b/Dockerfile index 5f4ae08..1210ec0 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,23 +1,21 @@ -FROM node:16.17.0 AS dependencies +FROM node:18.12.1 AS dependencies WORKDIR /usr/src/app COPY ./package*.json ./ RUN npm install -FROM node:16.17.0 AS builder +FROM node:18.12.1 AS builder WORKDIR /usr/src/app COPY ./ ./ COPY --from=dependencies /usr/src/app/node_modules ./node_modules RUN npm run build -FROM node:16.17.0 AS runner +FROM node:18.12.1 AS runner WORKDIR /usr/src/app ENV NODE_ENV=production -COPY --from=builder /usr/src/app/next.config.js ./next.config.js +ENV NEXT_TELEMETRY_DISABLED=1 +COPY --from=builder /usr/src/app/.next/standalone ./ +COPY --from=builder /usr/src/app/.next/static ./.next/static COPY --from=builder /usr/src/app/public ./public -COPY --from=builder /usr/src/app/.next ./.next -COPY --from=builder /usr/src/app/i18n.json ./i18n.json COPY --from=builder /usr/src/app/locales ./locales -COPY --from=builder /usr/src/app/pages ./pages -COPY --from=builder /usr/src/app/node_modules ./node_modules -RUN npx next telemetry disable -CMD ["node_modules/.bin/next", "start", "--port", "${PORT}"] +COPY --from=builder /usr/src/app/next.config.js ./next.config.js +CMD ["node", "server.js"] diff --git a/docker-compose.yml b/docker-compose.yml index 979c8e7..fcee1d4 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -5,7 +5,7 @@ services: build: context: './' ports: - - '${PORT}:${PORT}' + - '${PORT-3000}:${PORT-3000}' environment: - PORT: ${PORT} + PORT: ${PORT-3000} env_file: './.env' diff --git a/next.config.js b/next.config.js index c54edc8..c055c34 100644 --- a/next.config.js +++ b/next.config.js @@ -5,16 +5,16 @@ const nextPWA = require('next-pwa')({ const nextTranslate = require('next-translate') /** @type {import("next").NextConfig} */ -module.exports = nextTranslate( - nextPWA({ - reactStrictMode: false, - images: { - domains: [ - 'api.thream.divlo.fr', - 'thream-api.herokuapp.com', - 'file-uploads-api.thream.divlo.fr', - ...(process.env.NODE_ENV !== 'production' ? ['localhost'] : []) - ] - } - }) -) +const nextConfig = { + reactStrictMode: false, + output: 'standalone', + images: { + domains: [ + 'api.thream.divlo.fr', + 'file-uploads-api.thream.divlo.fr', + ...(process.env.NODE_ENV !== 'production' ? ['127.0.0.1'] : []) + ] + } +} + +module.exports = nextTranslate(nextPWA(nextConfig))