evennia/Dockerfile

73 lines
2.6 KiB
Text
Raw Normal View History

#####
# Base docker image for running Evennia-based games in a container.
#
2017-10-20 00:25:33 +02:00
# Install:
# install `docker` (http://docker.com)
#
2017-10-20 00:25:33 +02:00
# Usage:
# cd to a folder where you want your game data to be (or where it already is).
#
# docker run -it --rm -p 4000:4000 -p 4001:4001 -p 4005:4005 -v $PWD:/usr/src/game evennia/evennia
#
# (If your OS does not support $PWD, replace it with the full path to your current
2017-10-20 00:25:33 +02:00
# folder).
#
# You will end up in a shell where the `evennia` command is available. From here you
# can install and run the game normally. Use Ctrl-D to exit the evennia docker container.
#
# You can also start evennia directly by passing arguments to the folder:
#
# docker run -it --rm -p 4000:4000 -p 4001:4001 -p 4005:4005 -v $PWD:/usr/src/game evennia/evennia evennia start -l
#
# This will start Evennia running as the core process of the container. Note that you *must* use -l
# or one of the foreground modes (like evennia ipstart) since otherwise the container will immediately
# die since no foreground process keeps it up.
#
2017-10-20 00:25:33 +02:00
# The evennia/evennia base image is found on DockerHub and can also be used
# as a base for creating your own custom containerized Evennia game. For more
# info, see https://github.com/evennia/evennia/wiki/Running%20Evennia%20in%20Docker .
#
FROM alpine
2016-12-14 19:21:59 -06:00
LABEL maintainer="www.evennia.com"
2017-10-20 23:28:59 +02:00
2016-12-14 19:21:59 -06:00
# install compilation environment
RUN apk update && apk add bash gcc jpeg-dev musl-dev procps py-pip \
py-setuptools py2-openssl python python-dev zlib-dev gettext
2016-12-14 19:21:59 -06:00
# add the files required for pip installation
COPY ./setup.py /usr/src/evennia/
COPY ./requirements.txt /usr/src/evennia/
COPY ./evennia/VERSION.txt /usr/src/evennia/evennia/
COPY ./bin /usr/src/evennia/bin/
2016-12-14 19:21:59 -06:00
# install dependencies
2018-07-31 11:50:05 +02:00
RUN pip install --upgrade pip && pip install -e /usr/src/evennia --trusted-host pypi.python.org
RUN pip install cryptography pyasn1 service_identity
2016-12-14 19:21:59 -06:00
# add the project source; this should always be done after all
# expensive operations have completed to avoid prematurely
# invalidating the build cache.
COPY . /usr/src/evennia
2017-10-20 23:10:08 +02:00
# add the game source when rebuilding a new docker image from inside
# a game dir
ONBUILD COPY . /usr/src/game
2016-12-14 19:21:59 -06:00
# make the game source hierarchy persistent with a named volume.
2017-10-20 23:10:08 +02:00
# mount on-disk game location here when using the container
# to just get an evennia environment.
VOLUME /usr/src/game
2016-12-14 19:21:59 -06:00
# set the working directory
2017-10-20 00:25:33 +02:00
WORKDIR /usr/src/game
2016-12-14 19:21:59 -06:00
2017-10-20 00:45:11 +02:00
# set bash prompt
2017-10-20 23:10:08 +02:00
ENV PS1 "evennia|docker \w $ "
2017-10-20 00:45:11 +02:00
2017-10-20 00:25:33 +02:00
# startup a shell when we start the container
ENTRYPOINT ["/usr/src/evennia/bin/unix/evennia-docker-start.sh"]
2016-12-14 19:21:59 -06:00
# expose the telnet, webserver and websocket client ports
EXPOSE 4000 4001 4005