fix: fixed security concern
This commit is contained in:
@@ -1,6 +1,9 @@
|
|||||||
FROM python:3.12-slim
|
FROM python:3.12-slim
|
||||||
ARG VERSION=unknown
|
ARG VERSION=unknown
|
||||||
|
|
||||||
|
# Create a non-root user
|
||||||
|
RUN useradd appuser
|
||||||
|
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
COPY . .
|
COPY . .
|
||||||
|
|
||||||
@@ -14,11 +17,17 @@ RUN pip install --no-cache-dir --upgrade -r requirements.txt
|
|||||||
|
|
||||||
ENV ENV=DEV
|
ENV ENV=DEV
|
||||||
|
|
||||||
|
# Switch to non-root user
|
||||||
|
USER appuser
|
||||||
|
|
||||||
EXPOSE 8000
|
EXPOSE 8000
|
||||||
CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "8000"]
|
CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "8000"]
|
||||||
|
|
||||||
# Install curl
|
# Install curl
|
||||||
|
USER root
|
||||||
RUN apt-get update && apt-get install --no-install-recommends -y curl && apt-get clean
|
RUN apt-get update && apt-get install --no-install-recommends -y curl && apt-get clean
|
||||||
|
|
||||||
|
# Switch back to non-root user for healthcheck
|
||||||
|
USER appuser
|
||||||
HEALTHCHECK --interval=30s --timeout=10s --retries=5 \
|
HEALTHCHECK --interval=30s --timeout=10s --retries=5 \
|
||||||
CMD curl --fail http://localhost:8000/openapi.json || exit 1
|
CMD curl --fail http://localhost:8000/openapi.json || exit 1
|
||||||
|
|||||||
Reference in New Issue
Block a user