diff --git a/plays/boomhut.yml b/plays/boomhut.yml new file mode 100644 index 0000000..f0b38fe --- /dev/null +++ b/plays/boomhut.yml @@ -0,0 +1,25 @@ +--- +- hosts: boomhut + gather_facts: false + become: true + roles: + - 'any.common.python' + - 'any.common.debian-user' + tags: first + +- hosts: boomhut + become: true + roles: + # - 'any.common.debian-repositories' + - 'any.tools.default' + - 'any.tools.restic' + # First change SSH settings before enabling firewall + - 'any.common.ssh' + - 'any.tools.ufw' + tags: base + +- hosts: boomhut + become: true + roles: + - 'any.software.papermc-podman' + tags: papermc diff --git a/roles/any.software.papermc-podman/files/Dockerfile b/roles/any.software.papermc-podman/files/Dockerfile new file mode 100644 index 0000000..1fa7b59 --- /dev/null +++ b/roles/any.software.papermc-podman/files/Dockerfile @@ -0,0 +1,68 @@ +ARG BASE_IMAGE + +# Build dumb-init +FROM alpine AS dumb-init-builder + +ARG DI_VER=1.2.5 + +WORKDIR /app + +# Build dumb-init & download tshock +RUN apk add --update --no-cache build-base unzip curl && \ + curl -Lo - "https://github.com/Yelp/dumb-init/archive/refs/tags/v${DI_VER}.tar.gz" | tar -xzf - && \ + cd "dumb-init-${DI_VER}" && \ + make SHELL=/bin/sh && \ + mv dumb-init .. + + +# We use ${:-} instead of a default value because the argument is always passed +# to the build, it'll just be blank most likely +FROM ${BASE_IMAGE:-'eclipse-temurin:21-jre-alpine'} + +# Build arguments +ARG MC_VERSION +ARG PAPERMC_VERSION + +COPY ./alex /bin/alex + +# Install alex binary +# ADD "https://git.rustybever.be/api/packages/Chewing_Bever/generic/alex/0.4.0/alex-linux-amd64" /bin/alex + +# RUN chmod +x /bin/alex && \ +# addgroup -Sg 1000 paper && \ +# adduser -SHG paper -u 1000 paper + +# Create worlds and config directory +WORKDIR /app +RUN mkdir -p worlds config/cache backups + +# Download server file +# ADD "https://papermc.io/api/v2/projects/paper/versions/$MC_VERSION/builds/$PAPERMC_VERSION/downloads/paper-$MC_VERSION-$PAPERMC_VERSION.jar" server.jar +ADD "https://fill-data.papermc.io/v1/objects/0b32aa197452047a51772af05bb9fddc264304ad780dca87425a726d68f89149/paper-1.21.10-127.jar" server.jar + +# Make sure the server user can access all necessary folders +# RUN chown -R paper:paper /app + +# Store the cache in an anonymous volume, which means it won't get stored in the other volumes +# VOLUME /app/config/cache + +ENV ALEX_JAR=/app/server.jar \ + ALEX_CONFIG=/app/config \ + ALEX_WORLD=/app/worlds \ + ALEX_BACKUP=/app/backups \ + ALEX_SERVER=paper \ + ALEX_SERVER_VERSION="${MC_VERSION}-${PAPERMC_VERSION}" + +# Document exposed ports +EXPOSE 25565 + +# Switch to non-root user +# USER paper:paper + +COPY --from=dumb-init-builder /app/dumb-init /dumb-init + +ENTRYPOINT ["/dumb-init", "--"] +CMD /bin/alex run + +# HEALTHCHECK --interval=30s --timeout=5s --start-period=1m --retries=5 \ +# CMD mcstatus localhost:25565 ping diff --git a/roles/any.software.papermc-podman/files/alex b/roles/any.software.papermc-podman/files/alex new file mode 100755 index 0000000..a39a2cb Binary files /dev/null and b/roles/any.software.papermc-podman/files/alex differ diff --git a/roles/any.software.papermc-podman/files/papermc.container b/roles/any.software.papermc-podman/files/papermc.container new file mode 100644 index 0000000..51fba62 --- /dev/null +++ b/roles/any.software.papermc-podman/files/papermc.container @@ -0,0 +1,23 @@ +# vim: ft=systemd +[Unit] +Description=Self-hostable Minecraft server + +[Container] +Image=papermc:1.21.10 +EnvironmentFile=/etc/papermc/papermc.env +Pull=never + +PodmanArgs=--tty + +PublishPort=25565:25565 + +Volume=/data/papermc/config:/app/config +Volume=/data/papermc/worlds:/app/worlds +Volume=/data/papermc/backups:/app/backups +Volume=/data/papermc/cache:/app/config/cache + +[Service] +Restart=always + +[Install] +WantedBy=default.target diff --git a/roles/any.software.papermc-podman/files/papermc.env b/roles/any.software.papermc-podman/files/papermc.env new file mode 100644 index 0000000..530f795 --- /dev/null +++ b/roles/any.software.papermc-podman/files/papermc.env @@ -0,0 +1,3 @@ +ALEX_XMS=4096 +ALEX_XMX=6144 +ALEX_LAYERS=30min,30,1,48;daily,1440,7,1 diff --git a/roles/any.software.papermc-podman/tasks/main.yml b/roles/any.software.papermc-podman/tasks/main.yml new file mode 100644 index 0000000..cde0f9f --- /dev/null +++ b/roles/any.software.papermc-podman/tasks/main.yml @@ -0,0 +1,54 @@ +--- +- name: Ensure data directory is present + ansible.builtin.file: + path: '/data/papermc/{{ item }}' + state: directory + mode: '0755' + owner: 'debian' + group: 'debian' + loop: + - 'cache' + - 'worlds' + - 'config' + - 'backups' + +- name: Ensure configuration directory is present + ansible.builtin.file: + path: '/etc/papermc' + state: directory + mode: '0755' + +- name: Ensure files are present + ansible.builtin.copy: + src: '{{ item }}' + dest: '/etc/papermc/{{ item }}' + mode: '0644' + owner: 'root' + group: 'root' + loop: + - 'papermc.env' + - 'Dockerfile' + - 'alex' + +- name: Ensure user configuration directory is present + ansible.builtin.file: + path: '/home/debian/.config/containers/systemd' + state: directory + owner: 'debian' + group: 'debian' + mode: '0755' + +- name: Ensure Container unit files are present + ansible.builtin.copy: + src: "papermc.container" + dest: "/home/debian/.config/containers/systemd/papermc.container" + mode: '0644' + owner: 'debian' + group: 'debian' + register: res + +- name: systemd-reload + ansible.builtin.systemd_service: + daemon_reload: true + scope: "user" + when: 'res.changed'