| # Use an official Python runtime as a parent image | |
| FROM python:3.12.3 | |
| # Set up a new user named "user" with user ID 1000 | |
| RUN useradd -m -u 1000 user | |
| # Switch to the "user" user | |
| USER user | |
| # Set home to the user's home directory | |
| ENV HOME=/home/user \ | |
| PATH=/home/user/.local/bin:$PATH | |
| # Set the working directory to the user's home directory | |
| WORKDIR $HOME/app | |
| # Try and run pip command after setting the user with `USER user` to avoid permission issues with Python | |
| RUN pip install --no-cache-dir --upgrade pip | |
| # Copy the current directory contents into the container at $HOME/app setting the owner to the user | |
| COPY --chown=user . $HOME/app | |
| # Download the parquet file from github | |
| RUN wget https://github.com/ImagingDataCommons/CloudSegmentatorResults/releases/download/0.0.1/qual_checks_and_quantitative_measurements.parquet | |
| # Download the mapping parquet file from github | |
| RUN wget https://github.com/ImagingDataCommons/CloudSegmentatorResults/releases/download/0.0.1/ct-seg-sr-map-with-series-uids-gcs-aws-ulrs.parquet | |
| # Install any needed packages specified in requirements.txt | |
| RUN pip install --no-cache-dir -r requirements.txt | |
| # Create the .streamlit directory | |
| RUN mkdir -p .streamlit | |
| # Create the config.toml file and set the maxMessageSize | |
| RUN echo "\ | |
| [server]\n\ | |
| maxMessageSize = 2000\n\ | |
| " > .streamlit/config.toml | |
| # Make port 8501 available to the world outside this container | |
| EXPOSE 8501 | |
| # Run filter_data_app.py when the container launches | |
| CMD streamlit run filter_data_app.py | |