2024-01-03 10:09:31 +01:00
|
|
|
# Django People
|
|
|
|
|
|
|
|
|
|
# ---- base image to inherit from ----
|
2024-11-15 16:36:14 +01:00
|
|
|
FROM python:3.12.6-alpine3.20 AS base
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
# Upgrade pip to its latest release to speed up dependencies installation
|
2024-09-27 17:39:17 +02:00
|
|
|
RUN python -m pip install --upgrade pip setuptools
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
# Upgrade system packages to install security updates
|
2024-09-27 17:39:17 +02:00
|
|
|
RUN apk update && \
|
|
|
|
|
apk upgrade
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
# ---- Back-end builder image ----
|
2024-11-15 16:36:14 +01:00
|
|
|
FROM base AS back-builder
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
WORKDIR /builder
|
|
|
|
|
|
|
|
|
|
# Copy required python dependencies
|
|
|
|
|
COPY ./src/backend /builder
|
|
|
|
|
|
|
|
|
|
RUN mkdir /install && \
|
|
|
|
|
pip install --prefix=/install .
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# ---- mails ----
|
2024-11-15 16:36:14 +01:00
|
|
|
FROM node:20 AS mail-builder
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
COPY ./src/mail /mail/app
|
|
|
|
|
|
|
|
|
|
WORKDIR /mail/app
|
|
|
|
|
|
|
|
|
|
RUN yarn install --frozen-lockfile && \
|
|
|
|
|
yarn build
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# ---- static link collector ----
|
2024-11-15 16:36:14 +01:00
|
|
|
FROM base AS link-collector
|
2024-01-03 10:09:31 +01:00
|
|
|
ARG PEOPLE_STATIC_ROOT=/data/static
|
|
|
|
|
|
|
|
|
|
# Install libpangocairo & rdfind
|
2024-09-27 17:39:17 +02:00
|
|
|
RUN apk add \
|
|
|
|
|
pango \
|
|
|
|
|
rdfind
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
# Copy installed python dependencies
|
|
|
|
|
COPY --from=back-builder /install /usr/local
|
|
|
|
|
|
|
|
|
|
# Copy people application (see .dockerignore)
|
|
|
|
|
COPY ./src/backend /app/
|
|
|
|
|
|
|
|
|
|
WORKDIR /app
|
|
|
|
|
|
|
|
|
|
# collectstatic
|
|
|
|
|
RUN DJANGO_CONFIGURATION=Build DJANGO_JWT_PRIVATE_SIGNING_KEY=Dummy \
|
|
|
|
|
python manage.py collectstatic --noinput
|
|
|
|
|
|
|
|
|
|
# Replace duplicated file by a symlink to decrease the overall size of the
|
|
|
|
|
# final image
|
|
|
|
|
RUN rdfind -makesymlinks true -followsymlinks true -makeresultsfile false ${PEOPLE_STATIC_ROOT}
|
|
|
|
|
|
|
|
|
|
# ---- Core application image ----
|
2024-11-15 16:36:14 +01:00
|
|
|
FROM base AS core
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
ENV PYTHONUNBUFFERED=1
|
|
|
|
|
|
|
|
|
|
# Install required system libs
|
2024-09-27 17:39:17 +02:00
|
|
|
RUN apk add \
|
|
|
|
|
gettext \
|
|
|
|
|
cairo \
|
|
|
|
|
libffi-dev \
|
|
|
|
|
gdk-pixbuf \
|
|
|
|
|
pango \
|
|
|
|
|
shared-mime-info
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
# Copy entrypoint
|
|
|
|
|
COPY ./docker/files/usr/local/bin/entrypoint /usr/local/bin/entrypoint
|
|
|
|
|
|
|
|
|
|
# Give the "root" group the same permissions as the "root" user on /etc/passwd
|
|
|
|
|
# to allow a user belonging to the root group to add new users; typically the
|
|
|
|
|
# docker user (see entrypoint).
|
|
|
|
|
RUN chmod g=u /etc/passwd
|
|
|
|
|
|
|
|
|
|
# Copy installed python dependencies
|
|
|
|
|
COPY --from=back-builder /install /usr/local
|
|
|
|
|
|
|
|
|
|
# Copy people application (see .dockerignore)
|
|
|
|
|
COPY ./src/backend /app/
|
|
|
|
|
|
|
|
|
|
WORKDIR /app
|
|
|
|
|
|
|
|
|
|
# We wrap commands run in this container by the following entrypoint that
|
|
|
|
|
# creates a user on-the-fly with the container user ID (see USER) and root group
|
|
|
|
|
# ID.
|
|
|
|
|
ENTRYPOINT [ "/usr/local/bin/entrypoint" ]
|
|
|
|
|
|
|
|
|
|
# ---- Development image ----
|
2024-11-15 16:36:14 +01:00
|
|
|
FROM core AS backend-development
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
# Switch back to the root user to install development dependencies
|
|
|
|
|
USER root:root
|
|
|
|
|
|
|
|
|
|
# Install psql
|
2024-09-27 17:39:17 +02:00
|
|
|
RUN apk add postgresql-client
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
# Uninstall people and re-install it in editable mode along with development
|
|
|
|
|
# dependencies
|
|
|
|
|
RUN pip uninstall -y people
|
|
|
|
|
RUN pip install -e .[dev]
|
|
|
|
|
|
|
|
|
|
# Restore the un-privileged user running the application
|
|
|
|
|
ARG DOCKER_USER
|
|
|
|
|
USER ${DOCKER_USER}
|
|
|
|
|
|
|
|
|
|
# Target database host (e.g. database engine following docker compose services
|
|
|
|
|
# name) & port
|
|
|
|
|
ENV DB_HOST=postgresql \
|
|
|
|
|
DB_PORT=5432
|
|
|
|
|
|
|
|
|
|
# Run django development server
|
2024-03-19 18:16:36 +01:00
|
|
|
CMD ["python", "manage.py", "runserver", "0.0.0.0:8000"]
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
# ---- Production image ----
|
2024-11-15 16:36:14 +01:00
|
|
|
FROM core AS backend-production
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
ARG PEOPLE_STATIC_ROOT=/data/static
|
|
|
|
|
|
|
|
|
|
# Gunicorn
|
|
|
|
|
RUN mkdir -p /usr/local/etc/gunicorn
|
|
|
|
|
COPY docker/files/usr/local/etc/gunicorn/people.py /usr/local/etc/gunicorn/people.py
|
|
|
|
|
|
|
|
|
|
# Un-privileged user running the application
|
|
|
|
|
ARG DOCKER_USER
|
|
|
|
|
USER ${DOCKER_USER}
|
|
|
|
|
|
|
|
|
|
# Copy statics
|
|
|
|
|
COPY --from=link-collector ${PEOPLE_STATIC_ROOT} ${PEOPLE_STATIC_ROOT}
|
|
|
|
|
|
|
|
|
|
# Copy people mails
|
2024-01-05 09:11:57 +01:00
|
|
|
COPY --from=mail-builder /mail/backend/core/templates/mail /app/core/templates/mail
|
2024-01-03 10:09:31 +01:00
|
|
|
|
|
|
|
|
# The default command runs gunicorn WSGI server in people's main module
|
2024-03-19 18:16:36 +01:00
|
|
|
CMD ["gunicorn", "-c", "/usr/local/etc/gunicorn/people.py", "people.wsgi:application"]
|