| |
| |
| FROM python:3.10-slim-bullseye |
|
|
| |
| ENV PYTHONUNBUFFERED 1 |
| ENV PYTHONDONTWRITEBYTECODE 1 |
| ENV PIP_NO_CACHE_DIR off |
| ENV PIP_DISABLE_PIP_VERSION_CHECK 1 |
| ENV DEBIAN_FRONTEND=noninteractive |
| ENV LANG C.UTF-8 |
| ENV LC_ALL C.UTF-8 |
|
|
| |
| |
| |
| |
| RUN apt-get update && apt-get install -y --no-install-recommends \ |
| ffmpeg \ |
| imagemagick \ |
| git \ |
| build-essential \ |
| libffi-dev \ |
| fonts-dejavu-core \ |
| fonts-liberation \ |
| libgl1-mesa-glx \ |
| libglib2.0-0 \ |
| curl \ |
| && rm -rf /var/lib/apt/lists/* |
|
|
| |
| |
| RUN if [ -f /etc/ImageMagick-6/policy.xml ]; then \ |
| XML_FILE="/etc/ImageMagick-6/policy.xml"; \ |
| echo "INFO: Attempting to modify ImageMagick policy at $XML_FILE (v6)." ; \ |
| elif [ -f /etc/ImageMagick-7/policy.xml ]; then \ |
| XML_FILE="/etc/ImageMagick-7/policy.xml"; \ |
| echo "INFO: Attempting to modify ImageMagick policy at $XML_FILE (v7)." ; \ |
| else \ |
| XML_FILE=""; \ |
| echo "WARNING: ImageMagick policy.xml not found in /etc/ImageMagick-[67]/. MoviePy TextClip might fail." ; \ |
| fi && \ |
| if [ -n "$XML_FILE" ] && [ -f "$XML_FILE" ]; then \ |
| sed -i 's/<policy domain="path" rights="none" pattern="@\*"\/>/<!-- <policy domain="path" rights="none" pattern="@\*" \/> -->/' "$XML_FILE" && \ |
| sed -i 's/<policy domain="coder" rights="none" pattern="TEXT"\/>/<!-- <policy domain="coder" rights="none" pattern="TEXT" \/> -->/' "$XML_FILE" && \ |
| sed -i 's/<policy domain="coder" rights="none" pattern="LABEL"\/>/<!-- <policy domain="coder" rights="none" pattern="LABEL" \/> -->/' "$XML_FILE" && \ |
| sed -i 's/<policy domain="coder" rights="none" pattern="MVG"\/>/<!-- <policy domain="coder" rights="none" pattern="MVG" \/> -->/' "$XML_FILE" && \ |
| sed -i 's/<policy domain="coder" rights="none" pattern="MSL"\/>/<!-- <policy domain="coder" rights="none" pattern="MSL" \/> -->/' "$XML_FILE" && \ |
| sed -i 's/<policy domain="coder" rights="none" pattern="HTTPS"\/>/<!-- <policy domain="coder" rights="none" pattern="HTTPS" \/> -->/' "$XML_FILE" && \ |
| sed -i 's/<policy domain="coder" rights="none" pattern="HTTP"\/>/<!-- <policy domain="coder" rights="none" pattern="HTTP" \/> -->/' "$XML_FILE" && \ |
| echo "INFO: ImageMagick policy modifications applied to $XML_FILE." ; \ |
| else \ |
| echo "INFO: No ImageMagick policy file found to modify, or XML_FILE variable was empty." ; \ |
| fi |
|
|
| |
| |
| RUN groupadd -r appgroup --gid 1000 && \ |
| useradd --no-log-init -r -g appgroup -u 1000 --create-home --shell /bin/bash appuser && \ |
| mkdir -p /home/appuser/.cache/pip && \ |
| mkdir -p /home/appuser/.streamlit && \ |
| chown -R appuser:appgroup /home/appuser |
|
|
| |
| ENV STREAMLIT_HOME=/home/appuser/.streamlit |
| |
| ENV BROWSER_GATHERUSAGEDATA=false |
|
|
| |
| WORKDIR /app |
|
|
| |
| |
| COPY --chown=appuser:appgroup requirements.txt . |
|
|
| |
| USER appuser |
| RUN pip install --no-cache-dir --upgrade pip && \ |
| echo "Attempting to install packages from requirements.txt as appuser..." && \ |
| pip install --user --no-cache-dir -r requirements.txt |
| |
| |
| |
|
|
| |
| |
| ENV PATH="/home/appuser/.local/bin:${PATH}" |
|
|
| |
| |
| |
| USER root |
| COPY . . |
| |
| RUN chown -R appuser:appgroup /app |
|
|
| |
| USER appuser |
| RUN mkdir -p /app/temp_cinegen_media |
| RUN mkdir -p /app/assets/fonts |
|
|
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
|
|
| |
| EXPOSE 8501 |
|
|
| |
| |
| CMD ["streamlit", "run", "app.py", "--server.port=8501", "--server.address=0.0.0.0", "--browser.gatherUsageStats=false"] |