# NOTE: Use the run-container.sh script to build and launch this container. # NOTE: Multi-stage builds require Docker >= 17.05. FROM centos:8 AS base # update packages and install requirements RUN dnf -y upgrade-minimal && \ dnf install -y python38 # NOTE: We don't need the following stuff for the build step, but it's nice to not have to re-install # it all every time we change the requirements :-/ # install Java RUN url="https://download.java.net/java/GA/jdk15.0.1/51f4f36ad4ef43e39d0dfdbaf6549e32/9/GPL/openjdk-15.0.1_linux-x64_bin.tar.gz" ; \ curl -s "$url" | tar -C /usr/bin/ -xz # install Firefox RUN dnf install -y wget bzip2 xorg-x11-server-Xvfb gtk3 dbus-glib && \ wget -qO- "https://download.mozilla.org/?product=firefox-latest-ssl&os=linux64&lang=en-US" \ | tar -C /usr/local/ -jx && \ ln -s /usr/local/firefox/firefox /usr/bin/firefox && \ echo "exclude=firefox" >>/etc/dnf/dnf.conf # install geckodriver RUN url=$( curl -s https://api.github.com/repos/mozilla/geckodriver/releases/latest | grep -Poh 'https.*linux64\.tar\.gz(?!\.)' ) && \ curl -sL "$url" | tar -C /usr/bin/ -xz # clean up RUN dnf clean all # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - FROM base AS build # set up a virtualenv RUN python3 -m venv /opt/venv ENV PATH="/opt/venv/bin:$PATH" RUN pip install --upgrade pip # install the application requirements COPY requirements.txt requirements-dev.txt /tmp/ RUN pip3 install -r /tmp/requirements.txt ARG CONTROL_TESTS_PORT RUN if [ -n "$CONTROL_TESTS_PORT" ]; then \ pip3 install -r /tmp/requirements-dev.txt \ ; fi # - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - FROM base # copy the virtualenv from the build image COPY --from=build /opt/venv /opt/venv ENV PATH="/opt/venv/bin:$PATH" # install the application WORKDIR /app COPY vasl_templates/ ./vasl_templates/ COPY vassal-shim/release/vassal-shim.jar ./vassal-shim/release/ COPY setup.py requirements.txt requirements-dev.txt LICENSE.txt ./ RUN pip3 install --editable . # install the config files COPY vasl_templates/webapp/config/logging.yaml.example ./vasl_templates/webapp/config/logging.yaml COPY docker/config/ ./vasl_templates/webapp/config/ # create a new user # NOTE: It would be nice to just specify the UID/GID in the "docker run" command, but VASSAL has problems # if there is no user :-/ We could specify these here, but that would bake them into the image. # In general, this is not a problem, since the application doesn't need to access files outside the container, # but if the user wants to e.g. keep the cached scenario index files outside the container, and they are # running with a non-default UID/GID, they will have to manage permissions themselves. Sigh... RUN useradd --create-home app USER app # run the application EXPOSE 5010 COPY docker/run.sh ./ CMD ./run.sh