mirror of
https://github.com/factoriotools/factorio-docker.git
synced 2025-01-16 13:13:07 +01:00
bd76f1c541
* Swap to Debian slim baseimage Co-authored-by: Sandro <sandro.jaeckel@gmail.com> * Only install necessary packages --------- Co-authored-by: Doridian <git@doridian.net> Co-authored-by: Sandro <sandro.jaeckel@gmail.com>
63 lines
2.0 KiB
Docker
63 lines
2.0 KiB
Docker
FROM debian:stable-slim
|
|
|
|
LABEL maintainer="https://github.com/factoriotools/factorio-docker"
|
|
|
|
ARG USER=factorio
|
|
ARG GROUP=factorio
|
|
ARG PUID=845
|
|
ARG PGID=845
|
|
|
|
# version checksum of the archive to download
|
|
ARG VERSION
|
|
ARG SHA256
|
|
|
|
# number of retries that curl will use when pulling the headless server tarball
|
|
ARG CURL_RETRIES=8
|
|
|
|
ENV PORT=34197 \
|
|
RCON_PORT=27015 \
|
|
VERSION=${VERSION} \
|
|
SHA256=${SHA256} \
|
|
SAVES=/factorio/saves \
|
|
CONFIG=/factorio/config \
|
|
MODS=/factorio/mods \
|
|
SCENARIOS=/factorio/scenarios \
|
|
SCRIPTOUTPUT=/factorio/script-output \
|
|
PUID="$PUID" \
|
|
PGID="$PGID"
|
|
|
|
SHELL ["/bin/bash", "-eo", "pipefail", "-c"]
|
|
RUN set -ox pipefail \
|
|
&& if [[ "${VERSION}" == "" ]]; then \
|
|
echo "build-arg VERSION is required" \
|
|
&& exit 1; \
|
|
fi \
|
|
&& if [[ "${SHA256}" == "" ]]; then \
|
|
echo "build-arg SHA256 is required" \
|
|
&& exit 1; \
|
|
fi \
|
|
&& archive="/tmp/factorio_headless_x64_$VERSION.tar.xz" \
|
|
&& mkdir -p /opt /factorio \
|
|
&& apt-get -q update \
|
|
&& DEBIAN_FRONTEND=noninteractive apt-get -qy install ca-certificates curl jq pwgen xz-utils --no-install-recommends \
|
|
&& rm -rf /var/lib/apt/lists/* \
|
|
&& curl -sSL "https://www.factorio.com/get-download/$VERSION/headless/linux64" -o "$archive" --retry $CURL_RETRIES\
|
|
&& echo "$SHA256 $archive" | sha256sum -c \
|
|
|| (sha256sum "$archive" && file "$archive" && exit 1) \
|
|
&& tar xf "$archive" --directory /opt \
|
|
&& chmod ugo=rwx /opt/factorio \
|
|
&& rm "$archive" \
|
|
&& ln -s "$SCENARIOS" /opt/factorio/scenarios \
|
|
&& ln -s "$SAVES" /opt/factorio/saves \
|
|
&& mkdir -p /opt/factorio/config/ \
|
|
&& addgroup --system --gid "$PGID" "$GROUP" \
|
|
&& adduser --system --uid "$PUID" --gid "$PGID" --no-create-home --disabled-password --shell /bin/sh "$USER" \
|
|
&& chown -R "$USER":"$GROUP" /opt/factorio /factorio
|
|
|
|
COPY files/*.sh /
|
|
COPY files/config.ini /opt/factorio/config/config.ini
|
|
|
|
VOLUME /factorio
|
|
EXPOSE $PORT/udp $RCON_PORT/tcp
|
|
ENTRYPOINT ["/docker-entrypoint.sh"]
|