Hezi Aharon
14588f55a8
Some checks failed
society-ai-hub-container-cache Actions Demo / build (push) Failing after 56s
38 lines
969 B
Docker
38 lines
969 B
Docker
# Use a slim base image to reduce potential vulnerabilities
|
|
FROM python:3.10-slim-bookworm
|
|
|
|
# Set the working directory
|
|
WORKDIR /usr/src/app
|
|
|
|
# Copy the requirements file and install the dependencies
|
|
COPY requirements.txt .
|
|
|
|
# Install uv and the dependencies without caching to reduce image size
|
|
RUN pip install --no-cache-dir uv==0.4.28 && \
|
|
pip install --no-cache-dir -r requirements.txt
|
|
|
|
# Copy the application code
|
|
COPY . .
|
|
|
|
# Create a non-root user and group
|
|
RUN groupadd -r appuser && useradd --no-log-init -r -g appuser appuser
|
|
|
|
# Change ownership of the app directory to the new user
|
|
RUN chown -R appuser:appuser /usr/src/app
|
|
|
|
# Restrict permissions on all directories except /usr/src/app and /tmp
|
|
RUN chmod -R o-rwx / && \
|
|
chmod -R o+rx /usr/src/app /tmp
|
|
|
|
# Switch to the non-root user
|
|
USER appuser
|
|
|
|
# Expose the application port
|
|
EXPOSE 7860
|
|
|
|
# Set environment variables
|
|
ENV GRADIO_SERVER_NAME="0.0.0.0"
|
|
|
|
# Run the application
|
|
CMD ["python", "app.py"]
|