chore: add web Dockerfile and dev compose service
This commit is contained in:
parent
2f7313b9ac
commit
8e37beb76b
@ -24,6 +24,21 @@ services:
|
|||||||
networks:
|
networks:
|
||||||
- cmbot
|
- cmbot
|
||||||
|
|
||||||
|
web:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: docker/web.Dockerfile
|
||||||
|
image: cm-whatsapp-web:local
|
||||||
|
container_name: cmbot-web
|
||||||
|
restart: unless-stopped
|
||||||
|
environment:
|
||||||
|
DATABASE_URL: ${DATABASE_URL}
|
||||||
|
DATA_DIR: ${DATA_DIR}
|
||||||
|
MEDIA_DIR: ${MEDIA_DIR}
|
||||||
|
WEB_PORT: ${WEB_PORT}
|
||||||
|
networks:
|
||||||
|
- cmbot
|
||||||
|
|
||||||
networks:
|
networks:
|
||||||
cmbot:
|
cmbot:
|
||||||
driver: bridge
|
driver: bridge
|
||||||
|
|||||||
@ -33,3 +33,28 @@ services:
|
|||||||
- cmbot
|
- cmbot
|
||||||
depends_on:
|
depends_on:
|
||||||
- tools
|
- tools
|
||||||
|
|
||||||
|
web:
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
dockerfile: docker/web.Dockerfile
|
||||||
|
target: build
|
||||||
|
image: cm-whatsapp-web:dev
|
||||||
|
container_name: cmbot-web
|
||||||
|
user: "${HOST_UID:-1000}:${HOST_GID:-1000}"
|
||||||
|
working_dir: /app
|
||||||
|
command: ["pnpm", "--filter", "@cmbot/web", "dev"]
|
||||||
|
restart: unless-stopped
|
||||||
|
volumes:
|
||||||
|
- .:/app
|
||||||
|
- ./dev-data:/data
|
||||||
|
ports:
|
||||||
|
- "127.0.0.1:3000:3000"
|
||||||
|
environment:
|
||||||
|
NODE_ENV: development
|
||||||
|
DATABASE_URL: ${DATABASE_URL}
|
||||||
|
DATA_DIR: ${DATA_DIR}
|
||||||
|
MEDIA_DIR: ${MEDIA_DIR}
|
||||||
|
WEB_PORT: ${WEB_PORT}
|
||||||
|
depends_on:
|
||||||
|
- tools
|
||||||
|
|||||||
@ -1,3 +1,33 @@
|
|||||||
FROM node:22-alpine
|
FROM node:22-alpine AS base
|
||||||
|
RUN npm install -g pnpm@9.12.0
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
CMD ["echo", "web service: not yet implemented (see plan 3)"]
|
|
||||||
|
FROM base AS deps
|
||||||
|
COPY package.json pnpm-workspace.yaml pnpm-lock.yaml ./
|
||||||
|
COPY apps/web/package.json apps/web/
|
||||||
|
COPY packages/db/package.json packages/db/
|
||||||
|
COPY packages/shared/package.json packages/shared/
|
||||||
|
RUN pnpm install --frozen-lockfile
|
||||||
|
|
||||||
|
FROM base AS build
|
||||||
|
COPY --from=deps /app/node_modules /app/node_modules
|
||||||
|
COPY --from=deps /app/apps/web/node_modules /app/apps/web/node_modules
|
||||||
|
COPY --from=deps /app/packages/db/node_modules /app/packages/db/node_modules
|
||||||
|
COPY --from=deps /app/packages/shared/node_modules /app/packages/shared/node_modules
|
||||||
|
COPY tsconfig.base.json turbo.json ./
|
||||||
|
COPY apps/web apps/web
|
||||||
|
COPY packages/db packages/db
|
||||||
|
COPY packages/shared packages/shared
|
||||||
|
RUN pnpm --filter @cmbot/shared build && \
|
||||||
|
pnpm --filter @cmbot/db build && \
|
||||||
|
pnpm --filter @cmbot/web build
|
||||||
|
|
||||||
|
FROM base AS runtime
|
||||||
|
ENV NODE_ENV=production
|
||||||
|
ENV PORT=3000
|
||||||
|
ENV HOSTNAME=0.0.0.0
|
||||||
|
COPY --from=build /app/apps/web/.next/standalone ./
|
||||||
|
COPY --from=build /app/apps/web/.next/static ./apps/web/.next/static
|
||||||
|
COPY --from=build /app/apps/web/public ./apps/web/public
|
||||||
|
EXPOSE 3000
|
||||||
|
CMD ["node", "apps/web/server.js"]
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user