mirror of
https://github.com/chartdb/chartdb.git
synced 2026-05-03 16:30:45 -05:00
46 lines
1.3 KiB
Docker
46 lines
1.3 KiB
Docker
FROM node:22-alpine AS builder
|
|
|
|
ARG VITE_OPENAI_API_KEY
|
|
ARG VITE_OPENAI_API_ENDPOINT
|
|
ARG VITE_LLM_MODEL_NAME
|
|
ARG VITE_HIDE_CHARTDB_CLOUD
|
|
ARG VITE_DISABLE_ANALYTICS
|
|
|
|
WORKDIR /usr/src/app
|
|
|
|
COPY package.json package-lock.json ./
|
|
|
|
RUN npm ci
|
|
|
|
COPY . .
|
|
|
|
RUN echo "VITE_OPENAI_API_KEY=${VITE_OPENAI_API_KEY}" > .env && \
|
|
echo "VITE_OPENAI_API_ENDPOINT=${VITE_OPENAI_API_ENDPOINT}" >> .env && \
|
|
echo "VITE_LLM_MODEL_NAME=${VITE_LLM_MODEL_NAME}" >> .env && \
|
|
echo "VITE_HIDE_CHARTDB_CLOUD=${VITE_HIDE_CHARTDB_CLOUD}" >> .env && \
|
|
echo "VITE_DISABLE_ANALYTICS=${VITE_DISABLE_ANALYTICS}" >> .env
|
|
|
|
RUN npm run build
|
|
|
|
FROM nginx:stable-alpine AS production
|
|
|
|
COPY --from=builder /usr/src/app/dist /usr/share/nginx/html
|
|
COPY ./default.conf.template /etc/nginx/conf.d/default.conf.template
|
|
COPY entrypoint.sh /entrypoint.sh
|
|
|
|
# Set permissions for nginx user to write to necessary directories
|
|
RUN chmod +x /entrypoint.sh && \
|
|
chown -R nginx:nginx /usr/share/nginx/html && \
|
|
chown -R nginx:nginx /etc/nginx/conf.d && \
|
|
chown -R nginx:nginx /var/cache/nginx && \
|
|
chown -R nginx:nginx /var/log/nginx && \
|
|
mkdir -p /var/run/nginx && \
|
|
chown -R nginx:nginx /var/run/nginx && \
|
|
touch /var/run/nginx.pid && \
|
|
chown -R nginx:nginx /var/run/nginx.pid
|
|
|
|
EXPOSE 80
|
|
|
|
USER nginx
|
|
|
|
ENTRYPOINT ["/entrypoint.sh"] |