25 lines
853 B
Docker
25 lines
853 B
Docker
# syntax=docker/dockerfile:1
|
|
|
|
FROM python:alpine
|
|
|
|
# Create non-root user
|
|
ARG CUSTOM_UID
|
|
ARG CUSTOM_GID
|
|
ENV CUSTOM_USERNAME=backend
|
|
ENV CUSTOM_GROUPNAME=backend
|
|
RUN addgroup --gid ${CUSTOM_GID:-1000} ${CUSTOM_GROUPNAME} && \
|
|
adduser --uid ${CUSTOM_UID:-1000} --shell /bin/ash ${CUSTOM_USERNAME} --ingroup ${CUSTOM_GROUPNAME} --disabled-password && \
|
|
mkdir /app && chown ${CUSTOM_UID:-1000}:${CUSTOM_GID:-1000} /app && chmod 700 /app
|
|
ENV PATH "$PATH:/home/${CUSTOM_GROUPNAME}/.local/bin"
|
|
|
|
# Copy source files
|
|
WORKDIR /app
|
|
COPY --chown=${CUSTOM_USERNAME}:${CUSTOM_GROUPNAME} backend/ /app/
|
|
|
|
# Install dependencies
|
|
USER ${CUSTOM_UID:-1000}:${CUSTOM_GID:-1000}
|
|
RUN pip install -r requirements.txt
|
|
|
|
# Run ASGI server
|
|
EXPOSE 3000/tcp
|
|
ENTRYPOINT ["uvicorn", "todo.main:app", "--root-path", "/api", "--host", "0.0.0.0", "--port", "3000", "--access-log"]
|