|
|
|
# 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
|