ldapweb/Dockerfile

47 lines
1.1 KiB
Docker

# The builder image, used to build the virtual environment
FROM python:3.11-buster as builder
RUN apt-get update && \
apt-get install -y libkrb5-dev libsasl2-dev libldap2-dev libssl-dev && \
rm -rf /var/lib/apt/lists/*
RUN pip install poetry==1.5.1
ENV POETRY_NO_INTERACTION=1 \
POETRY_VIRTUALENVS_IN_PROJECT=1 \
POETRY_VIRTUALENVS_CREATE=1 \
POETRY_CACHE_DIR=/tmp/poetry_cache
WORKDIR /venv
COPY pyproject.toml ./
COPY poetry.lock ./
RUN touch README.md
RUN poetry install --no-root && \
rm -rf $POETRY_CACHE_DIR
# The runtime image, used to just run the code provided its virtual environment
FROM python:3.11-slim-buster as runtime
RUN apt-get update && \
apt-get install -y libldap2-dev krb5-user libxml2 --no-install-recommends && \
rm -rf /var/lib/apt/lists/*
COPY krb5.conf /etc/krb5.conf
RUN useradd -rm app
USER app
ENV VIRTUAL_ENV=/venv/.venv \
PATH="/venv/.venv/bin:$PATH"
COPY --from=builder ${VIRTUAL_ENV} ${VIRTUAL_ENV}
WORKDIR /app
COPY . .
STOPSIGNAL SIGINT
CMD ["uwsgi", "--socket=0.0.0.0:8000", "--protocol=http", "--manage-script-name", "--force-cwd=/app", "--mount", "/=webapp:app"]