mirror of
https://github.com/itzg/docker-minecraft-server.git
synced 2026-02-17 15:13:55 +00:00
Compare commits
115 Commits
2022.3.0-j
...
java8-mult
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
ce3c66accd | ||
|
|
ea13695cc8 | ||
|
|
e09d92a18a | ||
|
|
089cff87e2 | ||
|
|
221568ce4d | ||
|
|
63a2628502 | ||
|
|
eaa83fde87 | ||
|
|
e1a2175425 | ||
|
|
107bebd34e | ||
|
|
620c35826b | ||
|
|
706709e6fd | ||
|
|
bd4f3a9a48 | ||
|
|
417fcface4 | ||
|
|
adde46bc73 | ||
|
|
6510a6f361 | ||
|
|
9204e06b63 | ||
|
|
95b5088c3b | ||
|
|
2c106575f0 | ||
|
|
234d70786e | ||
|
|
7cf7193ef4 | ||
|
|
1d923a5878 | ||
|
|
34125769fa | ||
|
|
c6124bdd01 | ||
|
|
9f0edde0b3 | ||
|
|
1d97fccfdf | ||
|
|
5ad85de964 | ||
|
|
c273e99007 | ||
|
|
72ea47148a | ||
|
|
25782fc63e | ||
|
|
283b5ba431 | ||
|
|
5933fffcca | ||
|
|
de5b7cb601 | ||
|
|
c836e29ac3 | ||
|
|
d9214f0204 | ||
|
|
a7efcfff49 | ||
|
|
618d6236ba | ||
|
|
929eeeedfc | ||
|
|
6494ca8864 | ||
|
|
d964231906 | ||
|
|
1d8c28e024 | ||
|
|
d63c570cf3 | ||
|
|
f7f1855e24 | ||
|
|
8ccf0201a8 | ||
|
|
fa9e59edd8 | ||
|
|
25a2ab6ff3 | ||
|
|
bb780c000d | ||
|
|
cb4691a9ac | ||
|
|
76b8b89295 | ||
|
|
551e4d6346 | ||
|
|
61a660ee48 | ||
|
|
5e9806736c | ||
|
|
d5865cd60c | ||
|
|
2b0b8f8a62 | ||
|
|
e94b40bddf | ||
|
|
2dabf34349 | ||
|
|
eb864c0fb8 | ||
|
|
2e0f469748 | ||
|
|
aa95dc291b | ||
|
|
d22280fae7 | ||
|
|
aac3c1c77a | ||
|
|
61b0eff4ca | ||
|
|
8c5f0a53bf | ||
|
|
fffeb7bb9c | ||
|
|
a060cc88d1 | ||
|
|
4421aaa22d | ||
|
|
3a51db6d24 | ||
|
|
969a23ae27 | ||
|
|
1a62592fe2 | ||
|
|
c316dbb5d2 | ||
|
|
bb64135c9b | ||
|
|
ef98de154c | ||
|
|
3d00077ef8 | ||
|
|
0d3ab75683 | ||
|
|
87681e64bb | ||
|
|
8ce986d3d7 | ||
|
|
67fda61de4 | ||
|
|
7c6ec41822 | ||
|
|
93af2025a2 | ||
|
|
c1b040af77 | ||
|
|
4148325787 | ||
|
|
7083cd15e8 | ||
|
|
7418dab476 | ||
|
|
94bbc8e649 | ||
|
|
3e5e62229a | ||
|
|
fe2a9d56ed | ||
|
|
27571999b2 | ||
|
|
bbd7d9e39a | ||
|
|
ef6f308229 | ||
|
|
49d89d3e73 | ||
|
|
74203b23f4 | ||
|
|
4fb791b490 | ||
|
|
ced25ad50a | ||
|
|
48efc224ba | ||
|
|
467c1d9954 | ||
|
|
9ced230f55 | ||
|
|
f3a8276362 | ||
|
|
b91d63716e | ||
|
|
46cccfd531 | ||
|
|
9fe1cb4a0d | ||
|
|
076038b470 | ||
|
|
aa416729ea | ||
|
|
812c6365ec | ||
|
|
42a5131b19 | ||
|
|
624f6a210f | ||
|
|
1c63cd18b7 | ||
|
|
6266a7e3cc | ||
|
|
871ecd4d9d | ||
|
|
c572c95161 | ||
|
|
f7b58fbbb1 | ||
|
|
eccfa444a9 | ||
|
|
e831d25706 | ||
|
|
12e931332b | ||
|
|
ceee9eddc9 | ||
|
|
60ba668743 | ||
|
|
fd1b15e01f |
93
.github/workflows/build-multiarch.yml
vendored
93
.github/workflows/build-multiarch.yml
vendored
@@ -3,60 +3,29 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- master
|
- master
|
||||||
|
- java8-multiarch
|
||||||
|
- java8-openj9
|
||||||
|
- java11*
|
||||||
|
- java16*
|
||||||
|
- java17*
|
||||||
- test/**
|
- test/**
|
||||||
tags:
|
tags:
|
||||||
- "[0-9]+.[0-9]+.[0-9]+"
|
- "[0-9]+.[0-9]+.[0-9]+"
|
||||||
|
- "[0-9]+.[0-9]+.[0-9]+-java8-multiarch"
|
||||||
|
- "[0-9]+.[0-9]+.[0-9]+-java8-openj9"
|
||||||
|
- "[0-9]+.[0-9]+.[0-9]+-java11*"
|
||||||
|
- "[0-9]+.[0-9]+.[0-9]+-java16*"
|
||||||
paths-ignore:
|
paths-ignore:
|
||||||
- "*.md"
|
- "*.md"
|
||||||
- "docs/**"
|
- "docs/**"
|
||||||
- "examples/**"
|
- "examples/**"
|
||||||
|
|
||||||
|
env:
|
||||||
|
IMAGE_TO_TEST: itzg/minecraft-server:test-${{ github.repository_owner }}-${{ github.run_id }}
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
if: github.repository == 'itzg/docker-minecraft-server'
|
if: github.repository == 'itzg/docker-minecraft-server'
|
||||||
strategy:
|
|
||||||
fail-fast: false
|
|
||||||
matrix:
|
|
||||||
variant:
|
|
||||||
- java17
|
|
||||||
- java17-openj9
|
|
||||||
- java8-multiarch
|
|
||||||
- java8-openj9
|
|
||||||
- java11
|
|
||||||
- java11-openj9
|
|
||||||
include:
|
|
||||||
- variant: java17
|
|
||||||
baseImage: eclipse-temurin:17
|
|
||||||
tagPrefix: java17-
|
|
||||||
platforms: linux/amd64,linux/arm/v7,linux/arm64
|
|
||||||
mcVersion: LATEST
|
|
||||||
- variant: java17-openj9
|
|
||||||
baseImage: ibm-semeru-runtimes:open-17-jdk
|
|
||||||
tagPrefix: java17-openj9-
|
|
||||||
platforms: linux/amd64,linux/arm64
|
|
||||||
mcVersion: LATEST
|
|
||||||
- variant: java8-multiarch
|
|
||||||
baseImage: eclipse-temurin:8-jdk
|
|
||||||
tagPrefix: java8-
|
|
||||||
platforms: linux/amd64,linux/arm64
|
|
||||||
mcVersion: 1.12.2
|
|
||||||
- variant: java8-openj9
|
|
||||||
baseImage: ibm-semeru-runtimes:open-8-jdk
|
|
||||||
tagPrefix: java8-openj9-
|
|
||||||
platforms: linux/amd64,linux/arm64
|
|
||||||
mcVersion: 1.12.2
|
|
||||||
- variant: java11
|
|
||||||
baseImage: adoptopenjdk:11-jdk-hotspot
|
|
||||||
tagPrefix: java11-
|
|
||||||
platforms: linux/amd64,linux/arm/v7,linux/arm64
|
|
||||||
mcVersion: 1.16.5
|
|
||||||
- variant: java11-openj9
|
|
||||||
baseImage: ibm-semeru-runtimes:open-11-jdk
|
|
||||||
tagPrefix: java11-openj9-
|
|
||||||
platforms: linux/amd64,linux/arm64
|
|
||||||
mcVersion: 1.16.5
|
|
||||||
env:
|
|
||||||
IMAGE_TO_TEST: itzg/minecraft-server:test-${{ matrix.variant }}-${{ github.run_id }}
|
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-20.04
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
@@ -69,13 +38,10 @@ jobs:
|
|||||||
images: |
|
images: |
|
||||||
itzg/minecraft-server
|
itzg/minecraft-server
|
||||||
tags: |
|
tags: |
|
||||||
type=ref,event=tag,enable=${{ matrix.variant == 'java17' }}
|
type=ref,event=branch
|
||||||
type=ref,event=tag,suffix=-${{ matrix.variant }}
|
type=ref,event=tag
|
||||||
type=raw,value=${{ matrix.variant }}
|
|
||||||
flavor: |
|
flavor: |
|
||||||
latest=${{ matrix.variant == 'java17' }}
|
latest=${{ github.event_name == 'push' && github.ref == 'refs/heads/master' }}
|
||||||
labels: |
|
|
||||||
org.opencontainers.image.authors=Geoff Bourne <itzgeoff@gmail.com>
|
|
||||||
|
|
||||||
- name: Setup Docker Buildx
|
- name: Setup Docker Buildx
|
||||||
uses: docker/setup-buildx-action@v1
|
uses: docker/setup-buildx-action@v1
|
||||||
@@ -90,37 +56,38 @@ jobs:
|
|||||||
password: ${{ secrets.DOCKER_PASSWORD }}
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||||
|
|
||||||
- name: Build for test
|
- name: Build for test
|
||||||
uses: docker/build-push-action@v2.8.0
|
uses: docker/build-push-action@v2.7.0
|
||||||
|
if: github.ref_name == 'master' || startsWith(github.ref_name, 'test/')
|
||||||
with:
|
with:
|
||||||
|
context: .
|
||||||
platforms: linux/amd64
|
platforms: linux/amd64
|
||||||
tags: ${{ env.IMAGE_TO_TEST }}
|
tags: ${{ env.IMAGE_TO_TEST }}
|
||||||
# ensure latest base image is used
|
# ensure latest base image is used
|
||||||
pull: true
|
pull: true
|
||||||
# load into daemon for test usage in next step
|
|
||||||
load: true
|
load: true
|
||||||
push: false
|
push: false
|
||||||
build-args: |
|
cache-from: type=gha
|
||||||
BASE_IMAGE=${{ matrix.baseImage }}
|
|
||||||
cache-from: type=gha,scope=${{ matrix.variant }}
|
|
||||||
# no cache-to to avoid cross-cache update from next build step
|
# no cache-to to avoid cross-cache update from next build step
|
||||||
|
|
||||||
- name: Run tests
|
- name: Run tests
|
||||||
env:
|
# It is assumed that image variants are merged from master and tested there
|
||||||
MINECRAFT_VERSION: ${{ matrix.mcVersion }}
|
if: github.ref_name == 'master' || startsWith(github.ref_name, 'test/')
|
||||||
run: |
|
run: |
|
||||||
tests/test.sh
|
tests/test.sh
|
||||||
|
|
||||||
- name: Build and push
|
- name: Build and push
|
||||||
id: docker_build
|
id: docker_build
|
||||||
uses: docker/build-push-action@v2.8.0
|
uses: docker/build-push-action@v2.7.0
|
||||||
with:
|
with:
|
||||||
platforms: ${{ matrix.platforms }}
|
context: .
|
||||||
push: ${{ github.ref_type == 'tag' || github.ref_name == 'master' }}
|
platforms: linux/amd64,linux/arm/v7,linux/arm64
|
||||||
|
push: true
|
||||||
tags: ${{ steps.meta.outputs.tags }}
|
tags: ${{ steps.meta.outputs.tags }}
|
||||||
# ensure latest base image is used
|
# ensure latest base image is used
|
||||||
pull: true
|
pull: true
|
||||||
|
cache-from: type=gha
|
||||||
|
cache-to: type=gha,mode=max
|
||||||
labels: ${{ steps.meta.outputs.labels }}
|
labels: ${{ steps.meta.outputs.labels }}
|
||||||
build-args: |
|
|
||||||
BASE_IMAGE=${{ matrix.baseImage }}
|
- name: Image digest
|
||||||
cache-from: type=gha,scope=${{ matrix.variant }}
|
run: echo ${{ steps.docker_build.outputs.digest }}
|
||||||
cache-to: type=gha,mode=max,scope=${{ matrix.variant }}
|
|
||||||
|
|||||||
4
.github/workflows/ci.yml
vendored
4
.github/workflows/ci.yml
vendored
@@ -27,7 +27,7 @@ jobs:
|
|||||||
uses: docker/setup-buildx-action@v1
|
uses: docker/setup-buildx-action@v1
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
uses: docker/build-push-action@v2.8.0
|
uses: docker/build-push-action@v2.7.0
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
platforms: linux/amd64
|
platforms: linux/amd64
|
||||||
@@ -36,7 +36,7 @@ jobs:
|
|||||||
cache-from: type=gha
|
cache-from: type=gha
|
||||||
|
|
||||||
- name: Run Setup Only Tests
|
- name: Run Setup Only Tests
|
||||||
run: bash tests/setuponlytests/test.sh
|
run: sh tests/setuponlytests/test.sh
|
||||||
|
|
||||||
# - name: Run Full Minecraft Service Tests
|
# - name: Run Full Minecraft Service Tests
|
||||||
# run: |
|
# run: |
|
||||||
|
|||||||
2
.github/workflows/discord.yml
vendored
2
.github/workflows/discord.yml
vendored
@@ -1,4 +1,4 @@
|
|||||||
name: Discord notifications
|
name: discord
|
||||||
|
|
||||||
on:
|
on:
|
||||||
workflow_run:
|
workflow_run:
|
||||||
|
|||||||
14
.github/workflows/issue-label.yml
vendored
14
.github/workflows/issue-label.yml
vendored
@@ -1,11 +1,9 @@
|
|||||||
name: Issue labels
|
|
||||||
|
|
||||||
on:
|
on:
|
||||||
issues:
|
issues:
|
||||||
types: [labeled]
|
types: [labeled]
|
||||||
|
|
||||||
env:
|
env:
|
||||||
DISCORD_WEBHOOK: ${{ secrets.DISCORD_ISSUES_WEBHOOK }}
|
DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }}
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
labelNotify:
|
labelNotify:
|
||||||
@@ -13,13 +11,7 @@ jobs:
|
|||||||
timeout-minutes: 5
|
timeout-minutes: 5
|
||||||
steps:
|
steps:
|
||||||
- name: notify
|
- name: notify
|
||||||
if: >
|
if: github.event.label.name == 'enhancement' || github.event.label.name == 'bug'
|
||||||
github.event.label.name == 'enhancement'
|
|
||||||
|| github.event.label.name == 'bug'
|
|
||||||
|| github.event.label.name == 'help wanted'
|
|
||||||
|| github.event.label.name == 'priority/high'
|
|
||||||
|| github.event.label.name == 'question'
|
|
||||||
|| github.event.label.name == 'status/waiting on upstream'
|
|
||||||
uses: Ilshidur/action-discord@master
|
uses: Ilshidur/action-discord@master
|
||||||
with:
|
with:
|
||||||
args: "[${{ github.event.issue.title }} (#${{ github.event.issue.number }})](<${{ github.event.issue.html_url }}>) added `${{ github.event.label.name }}` label"
|
args: "[${{ github.event.issue.title }}](<${{ github.event.issue.html_url }}>) added `${{ github.event.label.name }}` label"
|
||||||
|
|||||||
15
.github/workflows/main.yml
vendored
15
.github/workflows/main.yml
vendored
@@ -4,9 +4,16 @@ on:
|
|||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- java8
|
- java8
|
||||||
|
- openj9
|
||||||
|
- openj9-11
|
||||||
|
- adopt11
|
||||||
- test/alpine/*
|
- test/alpine/*
|
||||||
tags:
|
tags:
|
||||||
- "[0-9]+.[0-9]+.[0-9]+-java8"
|
- "[0-9]+.[0-9]+.[0-9]+-java8"
|
||||||
|
- "[0-9]+.[0-9]+.[0-9]+-openj9"
|
||||||
|
- "[0-9]+.[0-9]+.[0-9]+-openj9-11"
|
||||||
|
- "[0-9]+.[0-9]+.[0-9]+-openj9-nightly"
|
||||||
|
- "[0-9]+.[0-9]+.[0-9]+-adopt11"
|
||||||
|
|
||||||
env:
|
env:
|
||||||
IMAGE_TO_TEST: itzg/minecraft-server:test-${{ github.repository_owner }}-${{ github.run_id }}
|
IMAGE_TO_TEST: itzg/minecraft-server:test-${{ github.repository_owner }}-${{ github.run_id }}
|
||||||
@@ -46,7 +53,7 @@ jobs:
|
|||||||
password: ${{ secrets.DOCKER_PASSWORD }}
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||||
|
|
||||||
- name: Build for test
|
- name: Build for test
|
||||||
uses: docker/build-push-action@v2.8.0
|
uses: docker/build-push-action@v2.7.0
|
||||||
if: github.ref_name == 'java8'
|
if: github.ref_name == 'java8'
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
@@ -68,7 +75,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Build and push
|
- name: Build and push
|
||||||
id: docker_build
|
id: docker_build
|
||||||
uses: docker/build-push-action@v2.8.0
|
uses: docker/build-push-action@v2.7.0
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
file: ./Dockerfile
|
file: ./Dockerfile
|
||||||
@@ -85,4 +92,6 @@ jobs:
|
|||||||
org.opencontainers.image.version=${{ steps.prep.outputs.version }}
|
org.opencontainers.image.version=${{ steps.prep.outputs.version }}
|
||||||
org.opencontainers.image.source=https://github.com/itzg/docker-minecraft-server
|
org.opencontainers.image.source=https://github.com/itzg/docker-minecraft-server
|
||||||
org.opencontainers.image.revision=${{ github.sha }}
|
org.opencontainers.image.revision=${{ github.sha }}
|
||||||
org.opencontainers.image.authors=Geoff Bourne <itzgeoff@gmail.com>
|
|
||||||
|
- name: Image digest
|
||||||
|
run: echo ${{ steps.docker_build.outputs.digest }}
|
||||||
|
|||||||
4
.github/workflows/pr.yml
vendored
4
.github/workflows/pr.yml
vendored
@@ -24,7 +24,7 @@ jobs:
|
|||||||
uses: docker/setup-buildx-action@v1
|
uses: docker/setup-buildx-action@v1
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
uses: docker/build-push-action@v2.8.0
|
uses: docker/build-push-action@v2.7.0
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
platforms: linux/amd64
|
platforms: linux/amd64
|
||||||
@@ -53,7 +53,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Push
|
- name: Push
|
||||||
if: contains(github.event.pull_request.labels.*.name, 'ci/push-image')
|
if: contains(github.event.pull_request.labels.*.name, 'ci/push-image')
|
||||||
uses: docker/build-push-action@v2.8.0
|
uses: docker/build-push-action@v2.7.0
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
platforms: linux/amd64,linux/arm/v7,linux/arm64
|
platforms: linux/amd64,linux/arm/v7,linux/arm64
|
||||||
|
|||||||
63
Dockerfile
63
Dockerfile
@@ -1,32 +1,31 @@
|
|||||||
ARG BASE_IMAGE=openjdk:8-jdk-alpine
|
FROM eclipse-temurin:8-jdk
|
||||||
FROM ${BASE_IMAGE}
|
|
||||||
|
|
||||||
RUN apk add --no-cache -U \
|
LABEL org.opencontainers.image.authors="Geoff Bourne <itzgeoff@gmail.com>"
|
||||||
openssl \
|
|
||||||
imagemagick \
|
|
||||||
file \
|
|
||||||
lsof \
|
|
||||||
su-exec \
|
|
||||||
# GNU compatible 'find'
|
|
||||||
findutils \
|
|
||||||
shadow \
|
|
||||||
bash \
|
|
||||||
curl iputils \
|
|
||||||
git \
|
|
||||||
jq \
|
|
||||||
mysql-client \
|
|
||||||
tzdata \
|
|
||||||
rsync \
|
|
||||||
nano \
|
|
||||||
sudo \
|
|
||||||
knock \
|
|
||||||
ttf-dejavu \
|
|
||||||
zstd
|
|
||||||
|
|
||||||
RUN addgroup -g 1000 minecraft \
|
RUN apt-get update \
|
||||||
&& adduser -Ss /bin/false -u 1000 -G minecraft -h /home/minecraft minecraft \
|
&& DEBIAN_FRONTEND=noninteractive \
|
||||||
&& mkdir -m 777 /data \
|
apt-get install -y \
|
||||||
&& chown minecraft:minecraft /data /home/minecraft
|
imagemagick \
|
||||||
|
file \
|
||||||
|
gosu \
|
||||||
|
sudo \
|
||||||
|
net-tools \
|
||||||
|
iputils-ping \
|
||||||
|
curl \
|
||||||
|
git \
|
||||||
|
jq \
|
||||||
|
dos2unix \
|
||||||
|
mysql-client \
|
||||||
|
tzdata \
|
||||||
|
rsync \
|
||||||
|
nano \
|
||||||
|
unzip \
|
||||||
|
knockd \
|
||||||
|
ttf-dejavu \
|
||||||
|
&& apt-get clean
|
||||||
|
|
||||||
|
RUN addgroup --gid 1000 minecraft \
|
||||||
|
&& adduser --system --shell /bin/false --uid 1000 --ingroup minecraft --home /data minecraft
|
||||||
|
|
||||||
COPY --chmod=644 files/sudoers* /etc/sudoers.d
|
COPY --chmod=644 files/sudoers* /etc/sudoers.d
|
||||||
|
|
||||||
@@ -34,9 +33,9 @@ EXPOSE 25565 25575
|
|||||||
|
|
||||||
# hook into docker BuildKit --platform support
|
# hook into docker BuildKit --platform support
|
||||||
# see https://docs.docker.com/engine/reference/builder/#automatic-platform-args-in-the-global-scope
|
# see https://docs.docker.com/engine/reference/builder/#automatic-platform-args-in-the-global-scope
|
||||||
ARG TARGETOS=linux
|
ARG TARGETOS
|
||||||
ARG TARGETARCH=amd64
|
ARG TARGETARCH
|
||||||
ARG TARGETVARIANT=""
|
ARG TARGETVARIANT
|
||||||
|
|
||||||
ARG EASY_ADD_VER=0.7.1
|
ARG EASY_ADD_VER=0.7.1
|
||||||
ADD https://github.com/itzg/easy-add/releases/download/${EASY_ADD_VER}/easy-add_${TARGETOS}_${TARGETARCH}${TARGETVARIANT} /usr/bin/easy-add
|
ADD https://github.com/itzg/easy-add/releases/download/${EASY_ADD_VER}/easy-add_${TARGETOS}_${TARGETARCH}${TARGETVARIANT} /usr/bin/easy-add
|
||||||
@@ -62,7 +61,7 @@ RUN easy-add --var os=${TARGETOS} --var arch=${TARGETARCH}${TARGETVARIANT} \
|
|||||||
--var version=0.1.1 --var app=maven-metadata-release --file {{.app}} \
|
--var version=0.1.1 --var app=maven-metadata-release --file {{.app}} \
|
||||||
--from https://github.com/itzg/{{.app}}/releases/download/{{.version}}/{{.app}}_{{.version}}_{{.os}}_{{.arch}}.tar.gz
|
--from https://github.com/itzg/{{.app}}/releases/download/{{.version}}/{{.app}}_{{.version}}_{{.os}}_{{.arch}}.tar.gz
|
||||||
|
|
||||||
ARG MC_HELPER_VERSION=1.16.5
|
ARG MC_HELPER_VERSION=1.16.0
|
||||||
ARG MC_HELPER_BASE_URL=https://github.com/itzg/mc-image-helper/releases/download/v${MC_HELPER_VERSION}
|
ARG MC_HELPER_BASE_URL=https://github.com/itzg/mc-image-helper/releases/download/v${MC_HELPER_VERSION}
|
||||||
RUN curl -fsSL ${MC_HELPER_BASE_URL}/mc-image-helper-${MC_HELPER_VERSION}.tgz \
|
RUN curl -fsSL ${MC_HELPER_BASE_URL}/mc-image-helper-${MC_HELPER_VERSION}.tgz \
|
||||||
| tar -C /usr/share -zxf - \
|
| tar -C /usr/share -zxf - \
|
||||||
@@ -74,7 +73,7 @@ WORKDIR /data
|
|||||||
STOPSIGNAL SIGTERM
|
STOPSIGNAL SIGTERM
|
||||||
|
|
||||||
ENV UID=1000 GID=1000 \
|
ENV UID=1000 GID=1000 \
|
||||||
JVM_XX_OPTS="-XX:+UseG1GC" MEMORY="1G" \
|
MEMORY="1G" \
|
||||||
TYPE=VANILLA VERSION=LATEST \
|
TYPE=VANILLA VERSION=LATEST \
|
||||||
ENABLE_RCON=true RCON_PORT=25575 RCON_PASSWORD=minecraft \
|
ENABLE_RCON=true RCON_PORT=25575 RCON_PASSWORD=minecraft \
|
||||||
ENABLE_AUTOPAUSE=false AUTOPAUSE_TIMEOUT_EST=3600 AUTOPAUSE_TIMEOUT_KN=120 AUTOPAUSE_TIMEOUT_INIT=600 \
|
ENABLE_AUTOPAUSE=false AUTOPAUSE_TIMEOUT_EST=3600 AUTOPAUSE_TIMEOUT_KN=120 AUTOPAUSE_TIMEOUT_INIT=600 \
|
||||||
|
|||||||
62
README.md
62
README.md
@@ -68,8 +68,8 @@ By default, the container will download the latest version of the "vanilla" [Min
|
|||||||
* [Optional plugins, mods, and config attach points](#optional-plugins-mods-and-config-attach-points)
|
* [Optional plugins, mods, and config attach points](#optional-plugins-mods-and-config-attach-points)
|
||||||
* [Auto-downloading SpigotMC/Bukkit/PaperMC plugins](#auto-downloading-spigotmcbukkitpapermc-plugins)
|
* [Auto-downloading SpigotMC/Bukkit/PaperMC plugins](#auto-downloading-spigotmcbukkitpapermc-plugins)
|
||||||
* [Downloadable mod/plugin pack for Forge, Fabric, and Bukkit-like Servers](#downloadable-modplugin-pack-for-forge-fabric-and-bukkit-like-servers)
|
* [Downloadable mod/plugin pack for Forge, Fabric, and Bukkit-like Servers](#downloadable-modplugin-pack-for-forge-fabric-and-bukkit-like-servers)
|
||||||
* [ForgeAPI usage to use non-version specific projects](#forgeapi-usage-to-use-non-version-specific-projects)
|
* [<strong>ForgeAPI</strong> usage to use non-version specific projects](#forgeapi-usage-to-use-non-version-specific-projects)
|
||||||
* [Generic pack files](#generic-pack-files)
|
* [Generic pack file](#generic-pack-file)
|
||||||
* [Mod/Plugin URL Listing File](#modplugin-url-listing-file)
|
* [Mod/Plugin URL Listing File](#modplugin-url-listing-file)
|
||||||
* [Remove old mods/plugins](#remove-old-modsplugins)
|
* [Remove old mods/plugins](#remove-old-modsplugins)
|
||||||
* [Working with world data](#working-with-world-data)
|
* [Working with world data](#working-with-world-data)
|
||||||
@@ -134,7 +134,6 @@ By default, the container will download the latest version of the "vanilla" [Min
|
|||||||
* [Stop Duration](#stop-duration)
|
* [Stop Duration](#stop-duration)
|
||||||
* [Setup only](#setup-only)
|
* [Setup only](#setup-only)
|
||||||
* [Enable Flare Flags](#enable-flare-flags)
|
* [Enable Flare Flags](#enable-flare-flags)
|
||||||
* [Enable timestamps in init logs](#enable-timestamps-in-init-logs)
|
|
||||||
* [Autopause](#autopause)
|
* [Autopause](#autopause)
|
||||||
* [Description](#description)
|
* [Description](#description)
|
||||||
* [Enabling Autopause](#enabling-autopause)
|
* [Enabling Autopause](#enabling-autopause)
|
||||||
@@ -142,7 +141,7 @@ By default, the container will download the latest version of the "vanilla" [Min
|
|||||||
* [Running on RaspberryPi](#running-on-raspberrypi)
|
* [Running on RaspberryPi](#running-on-raspberrypi)
|
||||||
* [Contributing](#contributing)
|
* [Contributing](#contributing)
|
||||||
|
|
||||||
<!-- Added by: runner, at: Sat Feb 5 18:38:45 UTC 2022 -->
|
<!-- Added by: runner, at: Mon Jan 24 04:19:37 UTC 2022 -->
|
||||||
|
|
||||||
<!--te-->
|
<!--te-->
|
||||||
|
|
||||||
@@ -245,8 +244,6 @@ If you had used the commands in the first section, without the `-v` volume attac
|
|||||||
|
|
||||||
> In this example, it is assumed the original container was given a `--name` of "mc", so change the container identifier accordingly.
|
> In this example, it is assumed the original container was given a `--name` of "mc", so change the container identifier accordingly.
|
||||||
|
|
||||||
> You can also locate the Docker-managed directory from the `Source` field obtained from `docker inspect <container id or name> -f "{{json .Mounts}}"`
|
|
||||||
|
|
||||||
First, stop the existing container:
|
First, stop the existing container:
|
||||||
```shell
|
```shell
|
||||||
docker stop mc
|
docker stop mc
|
||||||
@@ -394,7 +391,7 @@ To troubleshoot any issues with memory allocation reported by the JVM, set the e
|
|||||||
|
|
||||||
### Running a Forge Server
|
### Running a Forge Server
|
||||||
|
|
||||||
Enable [Forge server](http://www.minecraftforge.net/) mode by adding a `-e TYPE=FORGE` to your command-line.
|
Enable [Forge server](http://www.minecraftforge.net/wiki/) mode by adding a `-e TYPE=FORGE` to your command-line.
|
||||||
|
|
||||||
The overall version is specified by `VERSION`, [as described in the section above](#versions) and will run the recommended Forge version by default. You can also choose to run a specific Forge version with `FORGEVERSION`, such as `-e FORGEVERSION=14.23.5.2854`.
|
The overall version is specified by `VERSION`, [as described in the section above](#versions) and will run the recommended Forge version by default. You can also choose to run a specific Forge version with `FORGEVERSION`, such as `-e FORGEVERSION=14.23.5.2854`.
|
||||||
|
|
||||||
@@ -747,9 +744,9 @@ You may also download or copy over individual mods using the `MODS` environment
|
|||||||
|
|
||||||
docker run -d -e MODS=https://www.example.com/mods/mod1.jar,/plugins/common,/plugins/special/mod2.jar ...
|
docker run -d -e MODS=https://www.example.com/mods/mod1.jar,/plugins/common,/plugins/special/mod2.jar ...
|
||||||
|
|
||||||
### ForgeAPI usage to use non-version specific projects
|
### **ForgeAPI** usage to use non-version specific projects
|
||||||
|
|
||||||
**NOTE:** This potentially could lead to unexpected behavior if the Mod receives an update with unexpected behavior.
|
**NOTE:** This potentially could lead to unexpected behavior if the Mod recieves an update with unexpected behavior.
|
||||||
|
|
||||||
This is more complicated because you will be pulling/using the latest mod for the release of your game. To get started make sure you have a [CursedForge API Key](https://docs.curseforge.com/#getting-started). Then use the environmental parameters in your docker build.
|
This is more complicated because you will be pulling/using the latest mod for the release of your game. To get started make sure you have a [CursedForge API Key](https://docs.curseforge.com/#getting-started). Then use the environmental parameters in your docker build.
|
||||||
|
|
||||||
@@ -759,7 +756,6 @@ Parameters to use the ForgeAPI:
|
|||||||
* `MODS_FORGEAPI_FILE` - Required or use MODS_FORGEAPI_PROJECTIDS (Overrides MODS_FORGEAPI_PROJECTIDS)
|
* `MODS_FORGEAPI_FILE` - Required or use MODS_FORGEAPI_PROJECTIDS (Overrides MODS_FORGEAPI_PROJECTIDS)
|
||||||
* `MODS_FORGEAPI_PROJECTIDS` - Required or use MODS_FORGEAPI_FILE
|
* `MODS_FORGEAPI_PROJECTIDS` - Required or use MODS_FORGEAPI_FILE
|
||||||
* `MODS_FORGEAPI_RELEASES` - Default is release, Options: [Release|Beta|Alpha]
|
* `MODS_FORGEAPI_RELEASES` - Default is release, Options: [Release|Beta|Alpha]
|
||||||
* `MODS_FORGEAPI_DOWNLOAD_DEPENDENCIES` - Default is False, attempts to download required mods (releaseType Release) defined in Forge.
|
|
||||||
* `REMOVE_OLD_FORGEAPI_MODS` - Default is False
|
* `REMOVE_OLD_FORGEAPI_MODS` - Default is False
|
||||||
* `REMOVE_OLD_DATAPACKS_DEPTH` - Default is 1
|
* `REMOVE_OLD_DATAPACKS_DEPTH` - Default is 1
|
||||||
* `REMOVE_OLD_DATAPACKS_INCLUDE` - Default is *.jar
|
* `REMOVE_OLD_DATAPACKS_INCLUDE` - Default is *.jar
|
||||||
@@ -772,13 +768,7 @@ Example of expected forge api project ids, releases, and key:
|
|||||||
MODS_FORGEAPI_KEY: $WRX...
|
MODS_FORGEAPI_KEY: $WRX...
|
||||||
```
|
```
|
||||||
|
|
||||||
Example of expected ForgeAPI file format.
|
Example of expected ForgeAPI file format: **Note**: name is currently unused, but can be used to document each entry.
|
||||||
|
|
||||||
**Field Description**:
|
|
||||||
* `name` is currently unused, but can be used to document each entry.
|
|
||||||
* `projectId` id is the id found on the CurseForge website for a particular mod
|
|
||||||
* `releaseType` Type corresponds to forge's R, B, A icon for each file. Default Release, options are (release|beta|alpha).
|
|
||||||
* `fileName` is used for version pinning if latest file will not work for you.
|
|
||||||
|
|
||||||
```json
|
```json
|
||||||
[
|
[
|
||||||
@@ -791,33 +781,15 @@ Example of expected ForgeAPI file format.
|
|||||||
"name": "fabric voice mod",
|
"name": "fabric voice mod",
|
||||||
"projectId": "416089",
|
"projectId": "416089",
|
||||||
"releaseType": "beta"
|
"releaseType": "beta"
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Biomes o plenty",
|
|
||||||
"projectId": "220318",
|
|
||||||
"fileName": "BiomesOPlenty-1.18.1-15.0.0.100-universal.jar",
|
|
||||||
"releaseType": "release"
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
```
|
```
|
||||||
|
|
||||||
### Generic pack files
|
### Generic pack file
|
||||||
|
|
||||||
To install all the server content (jars, mods, plugins, configs, etc.) from a zip or tgz file, then set `GENERIC_PACK` to the container path or URL of the archive file. This can also be used to apply a CurseForge modpack that is missing a server start script and/or Forge installer.
|
To install all of the server content (jars, mods, plugins, configs, etc) from a zip file, such as a CurseForge modpack that is missing a server start script, then set `GENERIC_PACK` to the container path of the zip file. That, combined with `TYPE`, allows for custom content along with container managed server download and install.
|
||||||
|
|
||||||
If multiple generic packs need to be applied together, set `GENERIC_PACKS` instead, with a comma separated list of archive file paths and/or URLs to files.
|
If multiple generic packs need to be applied together, set `GENERIC_PACKS` instead, with a comma separated list of zip file paths and/or URLs to zip files.
|
||||||
|
|
||||||
To avoid repetition, each entry will be prefixed by the value of `GENERIC_PACKS_PREFIX` and suffixed by the value of `GENERIC_PACKS_SUFFIX`, both of which are optional. For example, the following variables
|
|
||||||
|
|
||||||
```
|
|
||||||
GENERIC_PACKS=configs-v9.0.1,mods-v4.3.6
|
|
||||||
GENERIC_PACKS_PREFIX=https://cdn.example.org/
|
|
||||||
GENERIC_PACKS_SUFFIX=.zip
|
|
||||||
```
|
|
||||||
|
|
||||||
would expand to `https://cdn.example.org/configs-v9.0.1.zip,https://cdn.example.org/mods-v4.3.6.zip`.
|
|
||||||
|
|
||||||
If applying large generic packs, the update check can be time-consuming since a SHA1 checksum is compared. To skip the update check set `SKIP_GENERIC_PACK_UPDATE_CHECK` to "true". Conversely, the generic pack(s) can be forced to be applied without comparing the checksum by setting `FORCE_GENERIC_PACK_UPDATE` to "true".
|
|
||||||
|
|
||||||
### Mod/Plugin URL Listing File
|
### Mod/Plugin URL Listing File
|
||||||
|
|
||||||
@@ -1562,20 +1534,6 @@ To enable the JVM flags required to fully support the [Flare profiling suite](ht
|
|||||||
|
|
||||||
Flare is built-in to Airplane/Pufferfish/Purpur, and is available in [plugin form](https://github.com/TECHNOVE/FlarePlugin) for other server types.
|
Flare is built-in to Airplane/Pufferfish/Purpur, and is available in [plugin form](https://github.com/TECHNOVE/FlarePlugin) for other server types.
|
||||||
|
|
||||||
### Enable timestamps in init logs
|
|
||||||
|
|
||||||
Before the container starts the Minecraft Server its output is prefixed with `[init]`, such as
|
|
||||||
|
|
||||||
```
|
|
||||||
[init] Starting the Minecraft server...
|
|
||||||
```
|
|
||||||
|
|
||||||
To also include the timestamp with each log, set `LOG_TIMESTAMP` to "true". The log output will then look like:
|
|
||||||
|
|
||||||
```
|
|
||||||
[init] 2022-02-05 16:58:33+00:00 Starting the Minecraft server...
|
|
||||||
```
|
|
||||||
|
|
||||||
## Autopause
|
## Autopause
|
||||||
|
|
||||||
### Description
|
### Description
|
||||||
|
|||||||
@@ -3,6 +3,12 @@
|
|||||||
# Use this variable to indicate a list of branches that docker hub is watching
|
# Use this variable to indicate a list of branches that docker hub is watching
|
||||||
branches_list=(
|
branches_list=(
|
||||||
'java8'
|
'java8'
|
||||||
|
'java8-multiarch'
|
||||||
|
'java8-openj9'
|
||||||
|
'java11'
|
||||||
|
'java11-openj9'
|
||||||
|
'java17'
|
||||||
|
'java17-openj9'
|
||||||
)
|
)
|
||||||
|
|
||||||
function TrapExit {
|
function TrapExit {
|
||||||
|
|||||||
@@ -5,15 +5,15 @@ current_uptime() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
java_running() {
|
java_running() {
|
||||||
[[ $( ps -a -o stat,comm | grep 'java' | awk '{ print $1 }') =~ ^S.*$ ]]
|
[[ $( ps -ax -o stat,comm | grep 'java' | awk '{ print $1 }') =~ ^S.*$ ]]
|
||||||
}
|
}
|
||||||
|
|
||||||
java_process_exists() {
|
java_process_exists() {
|
||||||
[[ -n "$(ps -a -o comm | grep 'java')" ]]
|
[[ -n "$(ps -ax -o comm | grep 'java')" ]]
|
||||||
}
|
}
|
||||||
|
|
||||||
rcon_client_exists() {
|
rcon_client_exists() {
|
||||||
[[ -n "$(ps -a -o comm | grep 'rcon-cli')" ]]
|
[[ -n "$(ps -ax -o comm | grep 'rcon-cli')" ]]
|
||||||
}
|
}
|
||||||
|
|
||||||
mc_server_listening() {
|
mc_server_listening() {
|
||||||
|
|||||||
@@ -3,12 +3,12 @@
|
|||||||
[unpauseMCServer-server]
|
[unpauseMCServer-server]
|
||||||
sequence = 25565
|
sequence = 25565
|
||||||
seq_timeout = 1
|
seq_timeout = 1
|
||||||
command = /sbin/su-exec minecraft:minecraft /autopause/resume.sh
|
command = /usr/sbin/gosu minecraft:minecraft /autopause/resume.sh
|
||||||
tcpflags = syn
|
tcpflags = syn
|
||||||
[unpauseMCServer-rcon]
|
[unpauseMCServer-rcon]
|
||||||
sequence = 25575
|
sequence = 25575
|
||||||
seq_timeout = 1
|
seq_timeout = 1
|
||||||
command = /sbin/su-exec minecraft:minecraft /autopause/resume.sh
|
command = /usr/sbin/gosu minecraft:minecraft /autopause/resume.sh
|
||||||
tcpflags = syn
|
tcpflags = syn
|
||||||
[unpauseMCServer-bedrock]
|
[unpauseMCServer-bedrock]
|
||||||
sequence = 19132:udp
|
sequence = 19132:udp
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
. /start-utils
|
. /start-utils
|
||||||
|
|
||||||
if [[ $( ps -a -o stat,comm | grep 'java' | awk '{ print $1 }') =~ ^S.*$ ]] ; then
|
if [[ $( ps -ax -o stat,comm | grep 'java' | awk '{ print $1 }') =~ ^S.*$ ]] ; then
|
||||||
# save world
|
# save world
|
||||||
rcon-cli save-all >/dev/null
|
rcon-cli save-all >/dev/null
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
. /start-utils
|
. /start-utils
|
||||||
|
|
||||||
if [[ $( ps -a -o stat,comm | grep 'java' | awk '{ print $1 }') =~ ^T.*$ ]] ; then
|
if [[ $( ps -ax -o stat,comm | grep 'java' | awk '{ print $1 }') =~ ^T.*$ ]] ; then
|
||||||
logAutopauseAction "Knocked, resuming Java process"
|
logAutopauseAction "Knocked, resuming Java process"
|
||||||
pkill -CONT java
|
pkill -CONT java
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -40,7 +40,7 @@ if ! isTrue "${SKIP_SUDO:-false}" && [ $(id -u) = 0 ]; then
|
|||||||
echo 'hosts: files dns' > /etc/nsswitch.conf
|
echo 'hosts: files dns' > /etc/nsswitch.conf
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exec su-exec ${runAsUser}:${runAsGroup} ${SCRIPTS:-/}start-configuration "$@"
|
exec gosu ${runAsUser}:${runAsGroup} ${SCRIPTS:-/}start-configuration "$@"
|
||||||
else
|
else
|
||||||
exec ${SCRIPTS:-/}start-configuration "$@"
|
exec ${SCRIPTS:-/}start-configuration "$@"
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ set -euo pipefail
|
|||||||
IFS=$'\n\t'
|
IFS=$'\n\t'
|
||||||
|
|
||||||
# shellcheck source=start-utils
|
# shellcheck source=start-utils
|
||||||
. "${SCRIPTS:-/}start-utils"
|
. ${SCRIPTS:-/}start-utils
|
||||||
|
|
||||||
: "${EULA:=}"
|
: "${EULA:=}"
|
||||||
: "${PROXY:=}"
|
: "${PROXY:=}"
|
||||||
@@ -66,12 +66,9 @@ if [[ $RCON_PASSWORD_FILE ]]; then
|
|||||||
log ""
|
log ""
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Some Docker management UIs grab all the image declared variables and present them for configuration.
|
|
||||||
# When upgrading images across Java versions, that creates a mismatch in PATH's expected by base image.
|
|
||||||
if ! which java > /dev/null; then
|
if ! which java > /dev/null; then
|
||||||
log "ERROR: PATH should not be explicitly passed into the container"
|
log "Fixing PATH to include java"
|
||||||
log " Remove configuration of that variable."
|
PATH="${PATH}:/opt/java/openjdk/bin"
|
||||||
exit 1
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export VERSIONS_JSON=https://launchermeta.mojang.com/mc/game/version_manifest.json
|
export VERSIONS_JSON=https://launchermeta.mojang.com/mc/game/version_manifest.json
|
||||||
@@ -119,31 +116,27 @@ fi
|
|||||||
log "Resolving type given ${TYPE}"
|
log "Resolving type given ${TYPE}"
|
||||||
case "${TYPE^^}" in
|
case "${TYPE^^}" in
|
||||||
*BUKKIT|SPIGOT)
|
*BUKKIT|SPIGOT)
|
||||||
exec "${SCRIPTS:-/}start-deployBukkitSpigot" "$@"
|
exec ${SCRIPTS:-/}start-deployBukkitSpigot "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
PAPER)
|
PAPER)
|
||||||
exec "${SCRIPTS:-/}start-deployPaper" "$@"
|
exec ${SCRIPTS:-/}start-deployPaper "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
FORGE)
|
FORGE)
|
||||||
evaluateJavaCompatibilityForForge
|
exec ${SCRIPTS:-/}start-deployForge "$@"
|
||||||
exec "${SCRIPTS:-/}start-deployForge" "$@"
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
FABRIC)
|
FABRIC)
|
||||||
exec "${SCRIPTS:-/}start-deployFabric" "$@"
|
exec ${SCRIPTS:-/}start-deployFabric "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
FTBA)
|
FTBA)
|
||||||
log "ERROR: TYPE=FTBA is not supported with this image variant."
|
exec ${SCRIPTS:-/}start-deployFTBA "$@"
|
||||||
log " Use itzg/minecraft-server:java8-multiarch instead."
|
|
||||||
exit 1
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
FTB|CURSEFORGE)
|
FTB|CURSEFORGE)
|
||||||
evaluateJavaCompatibilityForForge
|
exec ${SCRIPTS:-/}start-deployCF "$@"
|
||||||
exec "${SCRIPTS:-/}start-deployCF" "$@"
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
VANILLA)
|
VANILLA)
|
||||||
@@ -151,47 +144,43 @@ case "${TYPE^^}" in
|
|||||||
;;
|
;;
|
||||||
|
|
||||||
SPONGEVANILLA)
|
SPONGEVANILLA)
|
||||||
exec "${SCRIPTS:-/}start-deploySpongeVanilla" "$@"
|
exec ${SCRIPTS:-/}start-deploySpongeVanilla "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
CUSTOM)
|
CUSTOM)
|
||||||
evaluateJavaCompatibilityForForge
|
exec ${SCRIPTS:-/}start-deployCustom "$@"
|
||||||
exec "${SCRIPTS:-/}start-deployCustom" "$@"
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
MAGMA)
|
MAGMA)
|
||||||
evaluateJavaCompatibilityForForge
|
exec ${SCRIPTS:-/}start-deployMagma "$@"
|
||||||
exec "${SCRIPTS:-/}start-deployMagma" "$@"
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
MOHIST)
|
MOHIST)
|
||||||
evaluateJavaCompatibilityForForge
|
exec ${SCRIPTS:-/}start-deployMohist "$@"
|
||||||
exec "${SCRIPTS:-/}start-deployMohist" "$@"
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
CATSERVER)
|
CATSERVER)
|
||||||
evaluateJavaCompatibilityForForge
|
exec ${SCRIPTS:-/}start-deployCatserver "$@"
|
||||||
exec "${SCRIPTS:-/}start-deployCatserver" "$@"
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
PURPUR)
|
PURPUR)
|
||||||
exec "${SCRIPTS:-/}start-deployPurpur" "$@"
|
exec ${SCRIPTS:-/}start-deployPurpur "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
AIRPLANE)
|
AIRPLANE)
|
||||||
exec "${SCRIPTS:-/}start-deployAirplane" "$@"
|
exec ${SCRIPTS:-/}start-deployAirplane "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
PUFFERFISH)
|
PUFFERFISH)
|
||||||
exec "${SCRIPTS:-/}start-deployPufferfish" "$@"
|
exec ${SCRIPTS:-/}start-deployPufferfish "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
CANYON)
|
CANYON)
|
||||||
exec "${SCRIPTS:-/}start-deployCanyon" "$@"
|
exec ${SCRIPTS:-/}start-deployCanyon "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
LIMBO)
|
LIMBO)
|
||||||
exec "${SCRIPTS:-/}start-deployLimbo" "$@"
|
exec ${SCRIPTS:-/}start-deployLimbo "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
CRUCIBLE)
|
CRUCIBLE)
|
||||||
|
|||||||
@@ -42,5 +42,6 @@ fi
|
|||||||
|
|
||||||
# Normalize on Spigot for later operations
|
# Normalize on Spigot for later operations
|
||||||
export FAMILY=SPIGOT
|
export FAMILY=SPIGOT
|
||||||
|
export SKIP_LOG4J_CONFIG=true
|
||||||
|
|
||||||
exec "${SCRIPTS:-/}start-spiget" "$@"
|
exec "${SCRIPTS:-/}start-spiget" "$@"
|
||||||
|
|||||||
@@ -127,5 +127,6 @@ fi
|
|||||||
|
|
||||||
# Normalize on Spigot for operations below
|
# Normalize on Spigot for operations below
|
||||||
export FAMILY=SPIGOT
|
export FAMILY=SPIGOT
|
||||||
|
export SKIP_LOG4J_CONFIG=true
|
||||||
|
|
||||||
exec ${SCRIPTS:-/}start-spiget "$@"
|
exec ${SCRIPTS:-/}start-spiget "$@"
|
||||||
|
|||||||
@@ -111,8 +111,6 @@ if ! isTrue "${USE_MODPACK_START_SCRIPT:-true}"; then
|
|||||||
exit 2
|
exit 2
|
||||||
fi
|
fi
|
||||||
|
|
||||||
forgeInstallerJar=$(ls -t "${forgeInstallerJar}" | head -1)
|
|
||||||
|
|
||||||
log "Installing forge server"
|
log "Installing forge server"
|
||||||
dirOfInstaller=$(dirname "${forgeInstallerJar}")
|
dirOfInstaller=$(dirname "${forgeInstallerJar}")
|
||||||
(cd "${dirOfInstaller}"; java -jar "$(basename "${forgeInstallerJar}")" --installServer)
|
(cd "${dirOfInstaller}"; java -jar "$(basename "${forgeInstallerJar}")" --installServer)
|
||||||
|
|||||||
@@ -44,5 +44,6 @@ fi
|
|||||||
|
|
||||||
# Normalize on Spigot for later operations
|
# Normalize on Spigot for later operations
|
||||||
export FAMILY=SPIGOT
|
export FAMILY=SPIGOT
|
||||||
|
export SKIP_LOG4J_CONFIG=true
|
||||||
|
|
||||||
exec ${SCRIPTS:-/}start-spiget "$@"
|
exec ${SCRIPTS:-/}start-spiget "$@"
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# shellcheck source=start-utils
|
. ${SCRIPTS:-/}start-utils
|
||||||
. "${SCRIPTS:-/}start-utils"
|
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
@@ -27,6 +26,8 @@ if [ ! -f ${SERVER} ]; then
|
|||||||
curl -H "Accept:application/octet-stream" -o "$SERVER" -fsSL https://api.github.com/repos/Luohuayu/CatServer/releases/assets/${latestJarId}
|
curl -H "Accept:application/octet-stream" -o "$SERVER" -fsSL https://api.github.com/repos/Luohuayu/CatServer/releases/assets/${latestJarId}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export FAMILY=HYBRID
|
export SKIP_LOG4J_CONFIG=true
|
||||||
|
|
||||||
exec "${SCRIPTS:-/}start-setupWorld" "$@"
|
export FAMILY=HYBRID
|
||||||
|
# Continue to Final Setup
|
||||||
|
exec ${SCRIPTS:-/}start-setupWorld "$@"
|
||||||
|
|||||||
@@ -47,7 +47,6 @@ if [ ! -d "$librariesDir" ]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mkdir "$librariesDir"
|
|
||||||
if ! unzip /tmp/libraries.zip -d "$librariesDir"; then
|
if ! unzip /tmp/libraries.zip -d "$librariesDir"; then
|
||||||
log "ERROR: failed to unzip Crucible libraries"
|
log "ERROR: failed to unzip Crucible libraries"
|
||||||
exit 1
|
exit 1
|
||||||
@@ -56,6 +55,7 @@ if [ ! -d "$librariesDir" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
export SERVER
|
export SERVER
|
||||||
|
export SKIP_LOG4J_CONFIG=true
|
||||||
export FAMILY=HYBRID
|
export FAMILY=HYBRID
|
||||||
|
|
||||||
exec "${SCRIPTS:-$(dirname "$0")}/start-setupWorld" "$@"
|
exec "${SCRIPTS:-$(dirname "$0")}/start-setupWorld" "$@"
|
||||||
|
|||||||
@@ -1,7 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# shellcheck source=start-utils
|
. ${SCRIPTS:-/}start-utils
|
||||||
. "${SCRIPTS:-/}start-utils"
|
|
||||||
isDebugging && set -x
|
isDebugging && set -x
|
||||||
|
|
||||||
if isURL ${CUSTOM_SERVER}; then
|
if isURL ${CUSTOM_SERVER}; then
|
||||||
@@ -31,6 +30,6 @@ else
|
|||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
export SKIP_LOG4J_CONFIG=true
|
||||||
export FAMILY=HYBRID
|
export FAMILY=HYBRID
|
||||||
|
|
||||||
exec ${SCRIPTS:-/}start-setupWorld $@
|
exec ${SCRIPTS:-/}start-setupWorld $@
|
||||||
|
|||||||
@@ -2,8 +2,7 @@
|
|||||||
|
|
||||||
ftbInstallMarker=".ftb-installed"
|
ftbInstallMarker=".ftb-installed"
|
||||||
|
|
||||||
# shellcheck source=start-utils
|
. ${SCRIPTS:-/}start-utils
|
||||||
. "${SCRIPTS:-/}start-utils"
|
|
||||||
isDebugging && set -x
|
isDebugging && set -x
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
@@ -81,5 +80,4 @@ if ! [ -v SERVER ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
export FAMILY=FORGE
|
export FAMILY=FORGE
|
||||||
|
|
||||||
exec ${SCRIPTS:-/}start-setupWorld $@
|
exec ${SCRIPTS:-/}start-setupWorld $@
|
||||||
|
|||||||
@@ -38,23 +38,18 @@ install() {
|
|||||||
get_installer "$normForgeVersion" "$shortForgeVersion"
|
get_installer "$normForgeVersion" "$shortForgeVersion"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
log "Installing Forge $shortForgeVersion. This might take a minute or two..."
|
log "Installing Forge $shortForgeVersion using $FORGE_INSTALLER"
|
||||||
mkdir -p mods
|
mkdir -p mods
|
||||||
tries=3
|
tries=3
|
||||||
while true; do
|
while ((--tries >= 0)); do
|
||||||
if ! java -jar "$FORGE_INSTALLER" --installServer &> forge-installer.log; then
|
if java -jar "$FORGE_INSTALLER" --installServer; then
|
||||||
if ((--tries <= 0)); then
|
break
|
||||||
cat forge-installer.log
|
|
||||||
log "
|
|
||||||
ERROR Forge failed to install after several tries.
|
|
||||||
"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
log "Install failed. Trying again..."
|
|
||||||
else
|
|
||||||
break # out of this loop
|
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
if ((tries < 0)); then
|
||||||
|
log "Forge failed to install after several tries." >&2
|
||||||
|
exit 10
|
||||||
|
fi
|
||||||
# NOTE $shortForgeVersion will be empty if installer location was given to us
|
# NOTE $shortForgeVersion will be empty if installer location was given to us
|
||||||
log "Finding installed server jar..."
|
log "Finding installed server jar..."
|
||||||
unset -v latest
|
unset -v latest
|
||||||
@@ -153,5 +148,4 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
export FAMILY=FORGE
|
export FAMILY=FORGE
|
||||||
|
|
||||||
exec "${SCRIPTS:-/}start-setupWorld" "$@"
|
exec "${SCRIPTS:-/}start-setupWorld" "$@"
|
||||||
|
|||||||
@@ -58,5 +58,7 @@ if [[ ${LEVEL} != *\;* ]]; then
|
|||||||
fi
|
fi
|
||||||
export LEVEL
|
export LEVEL
|
||||||
|
|
||||||
|
export SKIP_LOG4J_CONFIG=true
|
||||||
|
|
||||||
export FAMILY=LIMBO
|
export FAMILY=LIMBO
|
||||||
exec ${SCRIPTS:-/}start-setupWorld $@
|
exec ${SCRIPTS:-/}start-setupWorld $@
|
||||||
|
|||||||
@@ -1,12 +1,13 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# shellcheck source=start-utils
|
. ${SCRIPTS:-/}start-utils
|
||||||
. "${SCRIPTS:-/}start-utils"
|
export SKIP_LOG4J_CONFIG=true
|
||||||
|
|
||||||
isDebugging && set -x
|
isDebugging && set -x
|
||||||
|
|
||||||
: "${VANILLA_VERSION?}"
|
: ${VANILLA_VERSION?}
|
||||||
# stable, dev
|
# stable, dev
|
||||||
: "${MAGMA_CHANNEL:=stable}"
|
: ${MAGMA_CHANNEL:=stable}
|
||||||
|
|
||||||
|
|
||||||
magmaDownloadServer() {
|
magmaDownloadServer() {
|
||||||
@@ -89,5 +90,4 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
export FAMILY=HYBRID
|
export FAMILY=HYBRID
|
||||||
|
exec ${SCRIPTS:-/}start-setupWorld "$@"
|
||||||
exec "${SCRIPTS:-/}start-setupWorld" "$@"
|
|
||||||
|
|||||||
@@ -38,6 +38,7 @@ if [ ! -f "${SERVER}" ]; then
|
|||||||
get -o "${SERVER}" "${mohistJob}${MOHIST_BUILD}/artifact/${buildRelPath}"
|
get -o "${SERVER}" "${mohistJob}${MOHIST_BUILD}/artifact/${buildRelPath}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export FAMILY=HYBRID
|
export SKIP_LOG4J_CONFIG=true
|
||||||
|
|
||||||
|
export FAMILY=HYBRID
|
||||||
exec "${SCRIPTS:-$(dirname "$0")}/start-setupWorld" "$@"
|
exec "${SCRIPTS:-$(dirname "$0")}/start-setupWorld" "$@"
|
||||||
|
|||||||
@@ -74,5 +74,6 @@ fi
|
|||||||
|
|
||||||
# Normalize on Spigot for downstream operations
|
# Normalize on Spigot for downstream operations
|
||||||
export FAMILY=SPIGOT
|
export FAMILY=SPIGOT
|
||||||
|
export SKIP_LOG4J_CONFIG=true
|
||||||
|
|
||||||
exec ${SCRIPTS:-/}start-spiget "$@"
|
exec ${SCRIPTS:-/}start-spiget "$@"
|
||||||
|
|||||||
@@ -40,5 +40,6 @@ fi
|
|||||||
|
|
||||||
# Normalize on Spigot for later operations
|
# Normalize on Spigot for later operations
|
||||||
export FAMILY=SPIGOT
|
export FAMILY=SPIGOT
|
||||||
|
export SKIP_LOG4J_CONFIG=true
|
||||||
|
|
||||||
exec ${SCRIPTS:-/}start-spiget "$@"
|
exec ${SCRIPTS:-/}start-spiget "$@"
|
||||||
|
|||||||
@@ -6,9 +6,9 @@ IFS=$'\n\t'
|
|||||||
. "${SCRIPTS:-/}start-utils"
|
. "${SCRIPTS:-/}start-utils"
|
||||||
isDebugging && set -x
|
isDebugging && set -x
|
||||||
|
|
||||||
: "${VANILLA_VERSION:?}"
|
: ${VANILLA_VERSION:?}
|
||||||
: "${PURPUR_BUILD:=LATEST}"
|
: ${PURPUR_BUILD:=LATEST}
|
||||||
: "${FORCE_REDOWNLOAD:=false}"
|
: ${FORCE_REDOWNLOAD:=false}
|
||||||
|
|
||||||
if [[ ${PURPUR_BUILD} == LATEST ]]; then
|
if [[ ${PURPUR_BUILD} == LATEST ]]; then
|
||||||
if ! PURPUR_BUILD=$(get --json-path=".builds.latest" "https://api.purpurmc.org/v2/purpur/${VANILLA_VERSION}"); then
|
if ! PURPUR_BUILD=$(get --json-path=".builds.latest" "https://api.purpurmc.org/v2/purpur/${VANILLA_VERSION}"); then
|
||||||
@@ -31,5 +31,6 @@ fi
|
|||||||
|
|
||||||
# Normalize on Spigot for later operations
|
# Normalize on Spigot for later operations
|
||||||
export FAMILY=SPIGOT
|
export FAMILY=SPIGOT
|
||||||
|
export SKIP_LOG4J_CONFIG=true
|
||||||
|
|
||||||
exec "${SCRIPTS:-/}start-spiget" "$@"
|
exec "${SCRIPTS:-/}start-spiget" "$@"
|
||||||
|
|||||||
@@ -1,9 +1,97 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
# shellcheck source=start-utils
|
. ${SCRIPTS:-/}start-utils
|
||||||
. "${SCRIPTS:-/}start-utils"
|
|
||||||
isDebugging && set -x
|
isDebugging && set -x
|
||||||
|
|
||||||
|
if versionLessThan 1.7.6; then
|
||||||
|
opsFile=ops.txt
|
||||||
|
whitelistFile=white-list.txt
|
||||||
|
else
|
||||||
|
opsFile=ops.json
|
||||||
|
whitelistFile=whitelist.json
|
||||||
|
fi
|
||||||
|
|
||||||
|
function process_user_file() {
|
||||||
|
local output=$1
|
||||||
|
local source=$2
|
||||||
|
|
||||||
|
if isURL "$source"; then
|
||||||
|
log "Downloading $output from $source"
|
||||||
|
if ! get -o /data/$output "$source"; then
|
||||||
|
log "ERROR: failed to download from $source"
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
log "Copying $output from $source"
|
||||||
|
if ! cp "$source" /data/$output; then
|
||||||
|
log "ERROR: failed to copy from $source"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function process_user_csv() {
|
||||||
|
local output=$1
|
||||||
|
local list=$2
|
||||||
|
local playerDataList
|
||||||
|
|
||||||
|
if [[ "$output" == *"ops"* ]]; then
|
||||||
|
# Extra data for ops.json
|
||||||
|
userData='{"uuid": .id, "name": .username, "level": 4}'
|
||||||
|
else
|
||||||
|
userData='{"uuid": .id, "name": .username}'
|
||||||
|
fi
|
||||||
|
|
||||||
|
log "Updating ${output%.*}"
|
||||||
|
for i in ${list//,/ }
|
||||||
|
do
|
||||||
|
if [ -e "$output" ] && grep -q "$i" "$output"; then
|
||||||
|
log "$i already present in $output, skipping"
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
if ! playerData=$(get "https://playerdb.co/api/player/minecraft/$i" | jq -re ".data.player"); then
|
||||||
|
log "WARNING: Could not lookup user $i for ${output} addition"
|
||||||
|
else
|
||||||
|
playerDataList=$playerDataList$(echo $playerData | jq -r "$userData")
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
local newUsers=$(echo $playerDataList | jq -s .)
|
||||||
|
if [[ $output =~ .*\.txt ]]; then
|
||||||
|
# username list for txt config (Minecraft <= 1.7.5)
|
||||||
|
echo $newUsers | jq -r '.[].name' >> /data/${output}
|
||||||
|
sort -u /data/${output} -o /data/${output}
|
||||||
|
elif [ -e /data/${output} ]; then
|
||||||
|
# Merge with existing json file
|
||||||
|
local currentUsers=$(cat /data/${output})
|
||||||
|
jq --argjson current "$currentUsers" --argjson new "$newUsers" -n '$new + $current | unique_by(.uuid)' > /data/${output}
|
||||||
|
else
|
||||||
|
# New json file
|
||||||
|
echo $newUsers > /data/${output}
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
if isTrue "${OVERRIDE_OPS}"; then
|
||||||
|
log "Recreating ${opsFile} file at server startup"
|
||||||
|
rm -f /data/${opsFile}
|
||||||
|
fi
|
||||||
|
if [ -n "${OPS_FILE}" ] && [ ! -e "/data/${opsFile}" ]; then
|
||||||
|
process_user_file ${opsFile} "$OPS_FILE"
|
||||||
|
fi
|
||||||
|
if [ -n "${OPS}" ]; then
|
||||||
|
process_user_csv ${opsFile} "$OPS"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if isTrue "${OVERRIDE_WHITELIST}"; then
|
||||||
|
log "Recreating ${whitelistFile} file at server startup"
|
||||||
|
rm -f /data/${whitelistFile}
|
||||||
|
fi
|
||||||
|
if [ -n "${WHITELIST_FILE}" ] && [ ! -e "/data/${whitelistFile}" ]; then
|
||||||
|
process_user_file ${whitelistFile} "$WHITELIST_FILE"
|
||||||
|
fi
|
||||||
|
if [ -n "${WHITELIST}" ]; then
|
||||||
|
process_user_csv ${whitelistFile} "$WHITELIST"
|
||||||
|
fi
|
||||||
|
|
||||||
if [ -n "$ICON" ]; then
|
if [ -n "$ICON" ]; then
|
||||||
if [ ! -e server-icon.png ] || [ "${OVERRIDE_ICON}" == "TRUE" ]; then
|
if [ ! -e server-icon.png ] || [ "${OVERRIDE_ICON}" == "TRUE" ]; then
|
||||||
log "Using server icon from $ICON..."
|
log "Using server icon from $ICON..."
|
||||||
@@ -20,15 +108,13 @@ if [ -n "$ICON" ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
canUseRollingLogs=true
|
canUseRollingLogs=true
|
||||||
useFallbackJvmFlag=false
|
|
||||||
|
|
||||||
patchLog4jConfig() {
|
patchLog4jConfig() {
|
||||||
file=${1?}
|
file=${1?}
|
||||||
url=${2?}
|
url=${2?}
|
||||||
if ! get -o "$file" "$url"; then
|
if ! get -o "$file" "$url"; then
|
||||||
log "ERROR: failed to download corrected log4j config, fallback to JVM flag"
|
log "ERROR: failed to download corrected log4j config"
|
||||||
useFallbackJvmFlag=true
|
exit 1
|
||||||
return 1
|
|
||||||
fi
|
fi
|
||||||
JVM_OPTS="-Dlog4j.configurationFile=${file} ${JVM_OPTS}"
|
JVM_OPTS="-Dlog4j.configurationFile=${file} ${JVM_OPTS}"
|
||||||
canUseRollingLogs=false
|
canUseRollingLogs=false
|
||||||
@@ -48,10 +134,6 @@ elif isType PURPUR && versionLessThan 1.17; then
|
|||||||
elif isType PURPUR && versionLessThan 1.18.1; then
|
elif isType PURPUR && versionLessThan 1.18.1; then
|
||||||
patchLog4jConfig purpur_log4j2_117.xml https://purpurmc.org/docs/xml/purpur_log4j2_117.xml
|
patchLog4jConfig purpur_log4j2_117.xml https://purpurmc.org/docs/xml/purpur_log4j2_117.xml
|
||||||
elif versionLessThan 1.18.1; then
|
elif versionLessThan 1.18.1; then
|
||||||
useFallbackJvmFlag=true
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ${useFallbackJvmFlag}; then
|
|
||||||
JVM_OPTS="-Dlog4j2.formatMsgNoLookups=true ${JVM_OPTS}"
|
JVM_OPTS="-Dlog4j2.formatMsgNoLookups=true ${JVM_OPTS}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -87,7 +169,7 @@ if versionLessThan 1.14 && [[ ${CONSOLE,,} = false ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
# Optional disable GUI for headless servers
|
# Optional disable GUI for headless servers
|
||||||
if [[ ${GUI,,} = false ]]; then
|
if [[ ${GUI} = false || ${GUI} = FALSE ]]; then
|
||||||
EXTRA_ARGS+=" nogui"
|
EXTRA_ARGS+=" nogui"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -249,10 +331,6 @@ EOF
|
|||||||
elif [[ $SERVER =~ run.sh ]]; then
|
elif [[ $SERVER =~ run.sh ]]; then
|
||||||
log "Using Forge supplied run.sh script..."
|
log "Using Forge supplied run.sh script..."
|
||||||
echo $JVM_XX_OPTS $JVM_OPTS $expandedDOpts > user_jvm_args.txt
|
echo $JVM_XX_OPTS $JVM_OPTS $expandedDOpts > user_jvm_args.txt
|
||||||
if isTrue ${SETUP_ONLY:=false}; then
|
|
||||||
echo "SETUP_ONLY: bash ${SERVER}"
|
|
||||||
exit
|
|
||||||
fi
|
|
||||||
exec mc-server-runner "${mcServerRunnerArgs[@]}" --shell bash "${SERVER}"
|
exec mc-server-runner "${mcServerRunnerArgs[@]}" --shell bash "${SERVER}"
|
||||||
else
|
else
|
||||||
# If we have a bootstrap.txt file... feed that in to the server stdin
|
# If we have a bootstrap.txt file... feed that in to the server stdin
|
||||||
|
|||||||
@@ -32,4 +32,4 @@ if [[ ${PATCH_DEFINITIONS} ]]; then
|
|||||||
"${PATCH_DEFINITIONS}"
|
"${PATCH_DEFINITIONS}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exec "${SCRIPTS:-/}start-setupRbac" "$@"
|
exec "${SCRIPTS:-/}start-finalExec" "$@"
|
||||||
|
|||||||
@@ -7,7 +7,6 @@ set -e -o pipefail
|
|||||||
: "${MODS_FORGEAPI_PROJECTIDS:=}"
|
: "${MODS_FORGEAPI_PROJECTIDS:=}"
|
||||||
: "${MODS_FORGEAPI_FILE:=}"
|
: "${MODS_FORGEAPI_FILE:=}"
|
||||||
: "${MODS_FORGEAPI_RELEASES:=RELEASE}"
|
: "${MODS_FORGEAPI_RELEASES:=RELEASE}"
|
||||||
: "${MODS_FORGEAPI_DOWNLOAD_DEPENDENCIES:=false}"
|
|
||||||
: "${REMOVE_OLD_MODS_DEPTH:=1} "
|
: "${REMOVE_OLD_MODS_DEPTH:=1} "
|
||||||
: "${REMOVE_OLD_MODS_INCLUDE:=*.jar}"
|
: "${REMOVE_OLD_MODS_INCLUDE:=*.jar}"
|
||||||
|
|
||||||
@@ -37,11 +36,11 @@ ensureModKey(){
|
|||||||
# NOTE: downcasing release type for comparing types.
|
# NOTE: downcasing release type for comparing types.
|
||||||
updateReleaseNumber(){
|
updateReleaseNumber(){
|
||||||
releaseType=$1
|
releaseType=$1
|
||||||
if [ "release" = "${releaseType,,}" ] || [ 1 = "${releaseType,,}" ]; then
|
if [ "release" = "${releaseType,,}" ]; then
|
||||||
RELEASE_NUMBER_FILTER=1
|
RELEASE_NUMBER_FILTER=1
|
||||||
elif [ "beta" = "${releaseType,,}" ] || [ 2 = "${releaseType,,}" ]; then
|
elif [ "beta" = "${releaseType,,}" ]; then
|
||||||
RELEASE_NUMBER_FILTER=2
|
RELEASE_NUMBER_FILTER=2
|
||||||
elif [ "alpha" = "${releaseType,,}" ] || [ 3 = "${releaseType,,}" ]; then
|
elif [ "alpha" = "${releaseType,,}" ]; then
|
||||||
RELEASE_NUMBER_FILTER=3
|
RELEASE_NUMBER_FILTER=3
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@@ -53,12 +52,12 @@ retrieveVersionTypeNumber(){
|
|||||||
-H 'Accept: application/json' -H 'x-api-key: '${MODS_FORGEAPI_KEY}'')
|
-H 'Accept: application/json' -H 'x-api-key: '${MODS_FORGEAPI_KEY}'')
|
||||||
|
|
||||||
if [ ! "$minecraft_types" ]; then
|
if [ ! "$minecraft_types" ]; then
|
||||||
log "ERROR: unable to retrieve version types for ${VERSION_NAME} from ForgeAPI. Check Forge API key or supplied Minecraft version"
|
log "ERROR: unable to retrieve version types for ${VERSION_NAME} from ForgeAPI"
|
||||||
exit 2
|
exit 2
|
||||||
fi
|
fi
|
||||||
|
|
||||||
TYPE_ID=$(jq -n "$minecraft_types" | jq --arg VERSION_NAME "$VERSION_NAME" -jc '
|
TYPE_ID=$(jq -n "$minecraft_types" | jq --arg VERSION_NAME "$VERSION_NAME" -jc '
|
||||||
.data[]? | select(.name==$VERSION_NAME) | .id')
|
.data[] | select(.name==$VERSION_NAME) | .id')
|
||||||
|
|
||||||
if [ ! "$TYPE_ID" ]; then
|
if [ ! "$TYPE_ID" ]; then
|
||||||
log "ERROR: unable to retrieve version types for ${VERSION_NAME} from ForgeAPI"
|
log "ERROR: unable to retrieve version types for ${VERSION_NAME} from ForgeAPI"
|
||||||
@@ -69,7 +68,6 @@ retrieveVersionTypeNumber(){
|
|||||||
modFileByProjectID(){
|
modFileByProjectID(){
|
||||||
project_id=$(echo $1 | tr -d '"')
|
project_id=$(echo $1 | tr -d '"')
|
||||||
project_id_release_type=$2
|
project_id_release_type=$2
|
||||||
project_id_file_name=$3
|
|
||||||
unset PROJECT_FILE
|
unset PROJECT_FILE
|
||||||
|
|
||||||
# if Type id isn't defined use minecraft version to go get it.
|
# if Type id isn't defined use minecraft version to go get it.
|
||||||
@@ -102,13 +100,9 @@ modFileByProjectID(){
|
|||||||
fi
|
fi
|
||||||
# grabs the highest ID of the releaseTypes selected.
|
# grabs the highest ID of the releaseTypes selected.
|
||||||
# Default is 1 for Release, Beta is 2, and Alpha is 3. Using less than we can validate highest release.
|
# Default is 1 for Release, Beta is 2, and Alpha is 3. Using less than we can validate highest release.
|
||||||
if [ $project_id_file_name ]; then
|
current_project_file=$(jq -n "$project_files" | jq --arg RELEASE_FILTER "$RELEASE_NUMBER_FILTER" -jc '
|
||||||
current_project_file=$(jq -n "$project_files" | jq --arg FILE_NAME "$project_id_file_name" -jc '
|
.data | sort_by(.id) | reverse | map(select(.releaseType<=($RELEASE_FILTER|tonumber))) | .[0]')
|
||||||
.data | map(select(.fileName<=($FILE_NAME))) | .[0]')
|
|
||||||
else
|
|
||||||
current_project_file=$(jq -n "$project_files" | jq --arg RELEASE_FILTER "$RELEASE_NUMBER_FILTER" -jc '
|
|
||||||
.data | sort_by(.id) | reverse | map(select(.releaseType<=($RELEASE_FILTER|tonumber))) | .[0]')
|
|
||||||
fi
|
|
||||||
# Logic to grab the latest release over the entire pagination
|
# Logic to grab the latest release over the entire pagination
|
||||||
if [ ! "$PROJECT_FILE" ]; then
|
if [ ! "$PROJECT_FILE" ]; then
|
||||||
PROJECT_FILE=$current_project_file
|
PROJECT_FILE=$current_project_file
|
||||||
@@ -149,40 +143,6 @@ downloadModPackfromModFile() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
downloadDependencies(){
|
|
||||||
if [ "$PROJECT_FILE" ]; then
|
|
||||||
dependencies=$(jq -n "$PROJECT_FILE" | jq -jc '.dependencies' )
|
|
||||||
required_dependencies=$(jq -n "$dependencies" | jq --arg REQUIRED_FILTER "3" -jc '
|
|
||||||
map(select(.relationType==($REQUIRED_FILTER|tonumber)))')
|
|
||||||
if [ "$required_dependencies" ]; then
|
|
||||||
jq -n "$required_dependencies" | jq -c '.[]?' | while read current_dependency; do
|
|
||||||
mod_id=$(jq -n "$current_dependency" | jq -jc '.modId' )
|
|
||||||
|
|
||||||
# BROKEN: Example Voice mod keeps returning the voice mod file id instead of the mod file id.
|
|
||||||
# file_id=$(jq -n "$current_dependency" | jq -jc '.fileId' )
|
|
||||||
# dependency_data=$(curl -X GET -s \
|
|
||||||
# "${FORGEAPI_BASE_URL}/mods/${mod_id}/files/${file_id}/download-url" \
|
|
||||||
# -H 'Accept: application/json' -H 'x-api-key: '${MODS_FORGEAPI_KEY}'')
|
|
||||||
# if [ ! "$dependency_data" ]; then
|
|
||||||
# log "ERROR: unable to retrieve dependency data files for ${project_id} from ForgeAPI"
|
|
||||||
# exit 2
|
|
||||||
# fi
|
|
||||||
# dependency_download_url=$(jq -n "$dependency_data" | jq -jc '.data' )
|
|
||||||
# echo "Downloading dependency ${dependency_download_url}"
|
|
||||||
# if ! get -o "${out_dir}/" $dependency_download_url ; then
|
|
||||||
# log "ERROR: failed to download dependency from ${dependency_download_url}"
|
|
||||||
# exit 2
|
|
||||||
# fi
|
|
||||||
|
|
||||||
# Using current mod path and release to go get the REQUIRED DEPENDENCY
|
|
||||||
# NOTE: we are ASUMING it will be release.
|
|
||||||
modFileByProjectID $mod_id "release"
|
|
||||||
downloadModPackfromModFile
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# Use forge api json file to filter and download the correct mods
|
# Use forge api json file to filter and download the correct mods
|
||||||
if [ "$MODS_FORGEAPI_FILE" ] && [ -z "$MODS_FORGEAPI_PROJECTIDS" ]; then
|
if [ "$MODS_FORGEAPI_FILE" ] && [ -z "$MODS_FORGEAPI_PROJECTIDS" ]; then
|
||||||
ensureModKey
|
ensureModKey
|
||||||
@@ -190,19 +150,18 @@ if [ "$MODS_FORGEAPI_FILE" ] && [ -z "$MODS_FORGEAPI_PROJECTIDS" ]; then
|
|||||||
log "ERROR: given MODS_FORGEAPI_FILE file does not exist"
|
log "ERROR: given MODS_FORGEAPI_FILE file does not exist"
|
||||||
exit 2
|
exit 2
|
||||||
fi
|
fi
|
||||||
|
MODS_FORGEAPI_PROJECTIDS=$(jq --raw-output '[.[] | .projectId] | join(",")' $MODS_FORGEAPI_FILE)
|
||||||
|
if [ ! "$MODS_FORGEAPI_PROJECTIDS" ]; then
|
||||||
|
log "ERROR: unable to retrieve packs from $MODS_FORGEAPI_FILE"
|
||||||
|
exit 2
|
||||||
|
fi
|
||||||
|
|
||||||
# Needs loop here to look up release types befor calling download.
|
# Needs loop here to look up release types befor calling download.
|
||||||
jq -n "$required_dependencies" | jq -c '.[]?' | while read current_project; do
|
for project_id in ${MODS_FORGEAPI_PROJECTIDS//,/ }; do
|
||||||
# Per stack overflow we can use //empty to return empty string that works with -z
|
current_release_type=$(jq --arg PROJECT_ID "$project_id" -jc '
|
||||||
project_id=$(jq -n "$current_project" | jq -jc '.projectId // empty' )
|
.[] | select(.projectId==$PROJECT_ID) | .releaseType' "$MODS_FORGEAPI_FILE")
|
||||||
current_release_type=$(jq -n "$current_project" | jq -jc '.releaseType // empty' )
|
modFileByProjectID $project_id $current_release_type
|
||||||
current_file_name=$(jq -n "$current_project" | jq -jc '.fileName // empty' )
|
downloadModPackfromModFile
|
||||||
|
|
||||||
modFileByProjectID $project_id $current_release_type $current_file_name
|
|
||||||
downloadModPackfromModFile
|
|
||||||
if isTrue "${MODS_FORGEAPI_DOWNLOAD_DEPENDENCIES}"; then
|
|
||||||
downloadDependencies
|
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -211,10 +170,7 @@ if [ "$MODS_FORGEAPI_PROJECTIDS" ] && [ -z "$MODS_FORGEAPI_FILE" ]; then
|
|||||||
ensureModKey
|
ensureModKey
|
||||||
for project_id in ${MODS_FORGEAPI_PROJECTIDS//,/ }; do
|
for project_id in ${MODS_FORGEAPI_PROJECTIDS//,/ }; do
|
||||||
modFileByProjectID $project_id
|
modFileByProjectID $project_id
|
||||||
downloadModPackfromModFile
|
downloadModPackfromModFile
|
||||||
if isTrue "${MODS_FORGEAPI_DOWNLOAD_DEPENDENCIES}"; then
|
|
||||||
downloadDependencies
|
|
||||||
fi
|
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ if [[ "${PACKWIZ_URL}" ]]; then
|
|||||||
if [[ -z "${latestPackwiz}" ]]; then
|
if [[ -z "${latestPackwiz}" ]]; then
|
||||||
log "WARNING: Could not retrieve Packwiz bootstrap installer release information"
|
log "WARNING: Could not retrieve Packwiz bootstrap installer release information"
|
||||||
else
|
else
|
||||||
isDebugging && log "Latest packwiz ${latestPackwiz}"
|
isDebugging && log "Latest packwiz ${latestPackWiz}"
|
||||||
latestPackwizVer=$(echo ${latestPackwiz} | jq --raw-output '.tag_name')
|
latestPackwizVer=$(echo ${latestPackwiz} | jq --raw-output '.tag_name')
|
||||||
latestPackwizUrl=$(echo ${latestPackwiz} | jq --raw-output '.assets[] | select(.name | match("packwiz-installer-bootstrap.jar")) | .url')
|
latestPackwizUrl=$(echo ${latestPackwiz} | jq --raw-output '.assets[] | select(.name | match("packwiz-installer-bootstrap.jar")) | .url')
|
||||||
: "${PACKWIZ_JAR:=packwiz-installer-bootstrap_${latestPackwizVer}.jar}"
|
: "${PACKWIZ_JAR:=packwiz-installer-bootstrap_${latestPackwizVer}.jar}"
|
||||||
@@ -188,18 +188,14 @@ esac
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
: "${GENERIC_PACKS:=${GENERIC_PACK}}"
|
: "${GENERIC_PACKS:=${GENERIC_PACK}}"
|
||||||
: "${GENERIC_PACKS_PREFIX:=}"
|
|
||||||
: "${GENERIC_PACKS_SUFFIX:=}"
|
|
||||||
|
|
||||||
if [[ "${GENERIC_PACKS}" ]]; then
|
if [[ "${GENERIC_PACKS}" ]]; then
|
||||||
IFS=',' read -ra packs <<< "${GENERIC_PACKS}"
|
IFS=',' read -ra packs <<< "${GENERIC_PACKS}"
|
||||||
|
|
||||||
packFiles=()
|
packFiles=()
|
||||||
for packEntry in "${packs[@]}"; do
|
for pack in "${packs[@]}"; do
|
||||||
pack="${GENERIC_PACKS_PREFIX}${packEntry}${GENERIC_PACKS_SUFFIX}"
|
if isURL "$pack"; then
|
||||||
if isURL "${pack}"; then
|
|
||||||
mkdir -p /data/packs
|
mkdir -p /data/packs
|
||||||
log "Downloading generic pack from $pack"
|
|
||||||
if ! outfile=$(get -o /data/packs --output-filename --skip-existing "$pack"); then
|
if ! outfile=$(get -o /data/packs --output-filename --skip-existing "$pack"); then
|
||||||
log "ERROR: failed to download $pack"
|
log "ERROR: failed to download $pack"
|
||||||
exit 2
|
exit 2
|
||||||
@@ -211,18 +207,12 @@ if [[ "${GENERIC_PACKS}" ]]; then
|
|||||||
done
|
done
|
||||||
|
|
||||||
isDebugging && [ -f "$sum_file}" ] && cat "$sum_file"
|
isDebugging && [ -f "$sum_file}" ] && cat "$sum_file"
|
||||||
|
if ! sha256sum -c "${sum_file}" --status 2> /dev/null; then
|
||||||
log "Checking if generic packs are up to date"
|
|
||||||
if isTrue "${SKIP_GENERIC_PACK_UPDATE_CHECK:-false}" && [ -f "$sum_file" ]; then
|
|
||||||
log "Skipping generic pack update check"
|
|
||||||
elif isTrue "${FORCE_GENERIC_PACK_UPDATE}" || ! sha1sum -c "${sum_file}" --status 2> /dev/null; then
|
|
||||||
log "Generic pack(s) are out of date. Re-applying..."
|
|
||||||
|
|
||||||
base_dir=/tmp/generic_pack_base
|
base_dir=/tmp/generic_pack_base
|
||||||
mkdir -p ${base_dir}
|
mkdir -p ${base_dir}
|
||||||
for pack in "${packFiles[@]}"; do
|
for pack in "${packFiles[@]}"; do
|
||||||
isDebugging && ls -l "${pack}"
|
isDebugging && ls -l "${pack}"
|
||||||
extract "${pack}" "${base_dir}"
|
unzip -q -d ${base_dir} "${pack}"
|
||||||
done
|
done
|
||||||
|
|
||||||
# recalculate the actual base directory of content
|
# recalculate the actual base directory of content
|
||||||
@@ -250,8 +240,7 @@ if [[ "${GENERIC_PACKS}" ]]; then
|
|||||||
cp -R -f "${base_dir}"/* /data
|
cp -R -f "${base_dir}"/* /data
|
||||||
rm -rf /tmp/generic_pack_base
|
rm -rf /tmp/generic_pack_base
|
||||||
|
|
||||||
log "Saving generic pack(s) checksum"
|
sha256sum "${packFiles[@]}" > "${sum_file}"
|
||||||
sha1sum "${packFiles[@]}" > "${sum_file}"
|
|
||||||
isDebugging && cat "$sum_file"
|
isDebugging && cat "$sum_file"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,98 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
# shellcheck source=start-utils
|
|
||||||
. "${SCRIPTS:-/}start-utils"
|
|
||||||
isDebugging && set -x
|
|
||||||
|
|
||||||
if versionLessThan 1.7.6; then
|
|
||||||
opsFile=ops.txt
|
|
||||||
whitelistFile=white-list.txt
|
|
||||||
else
|
|
||||||
opsFile=ops.json
|
|
||||||
whitelistFile=whitelist.json
|
|
||||||
fi
|
|
||||||
|
|
||||||
function process_user_file() {
|
|
||||||
local output=$1
|
|
||||||
local source=$2
|
|
||||||
|
|
||||||
if isURL "$source"; then
|
|
||||||
log "Downloading $output from $source"
|
|
||||||
if ! get -o "/data/$output" "$source"; then
|
|
||||||
log "ERROR: failed to download from $source"
|
|
||||||
exit 2
|
|
||||||
fi
|
|
||||||
else
|
|
||||||
log "Copying $output from $source"
|
|
||||||
if ! cp "$source" "/data/$output"; then
|
|
||||||
log "ERROR: failed to copy from $source"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function process_user_csv() {
|
|
||||||
local output=$1
|
|
||||||
local list=$2
|
|
||||||
local playerDataList
|
|
||||||
|
|
||||||
if [[ "$output" == *"ops"* ]]; then
|
|
||||||
# Extra data for ops.json
|
|
||||||
userData='{"uuid": .id, "name": .username, "level": 4}'
|
|
||||||
else
|
|
||||||
userData='{"uuid": .id, "name": .username}'
|
|
||||||
fi
|
|
||||||
|
|
||||||
log "Updating ${output%.*}"
|
|
||||||
for i in ${list//,/ }
|
|
||||||
do
|
|
||||||
if [ -e "$output" ] && grep -q "$i" "$output"; then
|
|
||||||
log "$i already present in $output, skipping"
|
|
||||||
continue
|
|
||||||
fi
|
|
||||||
if ! playerData=$(get "https://playerdb.co/api/player/minecraft/$i" | jq -re ".data.player"); then
|
|
||||||
log "WARNING: Could not lookup user $i for ${output} addition"
|
|
||||||
else
|
|
||||||
playerDataList=$playerDataList$(echo "$playerData" | jq -r "$userData")
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
local newUsers=$(echo "$playerDataList" | jq -s .)
|
|
||||||
if [[ $output =~ .*\.txt ]]; then
|
|
||||||
# username list for txt config (Minecraft <= 1.7.5)
|
|
||||||
echo $newUsers | jq -r '.[].name' >> "/data/${output}"
|
|
||||||
sort -u /data/${output} -o /data/${output}
|
|
||||||
elif [ -e /data/${output} ]; then
|
|
||||||
# Merge with existing json file
|
|
||||||
local currentUsers=$(cat "/data/${output}")
|
|
||||||
jq --argjson current "$currentUsers" --argjson new "$newUsers" -n '$new + $current | unique_by(.uuid)' > "/data/${output}"
|
|
||||||
else
|
|
||||||
# New json file
|
|
||||||
echo $newUsers > "/data/${output}"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
if isTrue "${OVERRIDE_OPS}"; then
|
|
||||||
log "Recreating ${opsFile} file at server startup"
|
|
||||||
rm -f /data/${opsFile}
|
|
||||||
fi
|
|
||||||
if [ -n "${OPS_FILE}" ] && [ ! -e "/data/${opsFile}" ]; then
|
|
||||||
process_user_file ${opsFile} "$OPS_FILE"
|
|
||||||
fi
|
|
||||||
if [ -n "${OPS}" ]; then
|
|
||||||
process_user_csv ${opsFile} "$OPS"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if isTrue "${OVERRIDE_WHITELIST}"; then
|
|
||||||
log "Recreating ${whitelistFile} file at server startup"
|
|
||||||
rm -f /data/${whitelistFile}
|
|
||||||
fi
|
|
||||||
if [ -n "${WHITELIST_FILE}" ] && [ ! -e "/data/${whitelistFile}" ]; then
|
|
||||||
process_user_file ${whitelistFile} "$WHITELIST_FILE"
|
|
||||||
fi
|
|
||||||
if [ -n "${WHITELIST}" ]; then
|
|
||||||
process_user_csv ${whitelistFile} "$WHITELIST"
|
|
||||||
fi
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
exec "${SCRIPTS:-/}start-finalExec" "$@"
|
|
||||||
@@ -40,10 +40,6 @@ function getFilenameFromUrl() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function isTrue() {
|
function isTrue() {
|
||||||
local oldState
|
|
||||||
oldState=$(shopt -po xtrace)
|
|
||||||
shopt -u -o xtrace
|
|
||||||
|
|
||||||
local value=${1,,}
|
local value=${1,,}
|
||||||
|
|
||||||
result=
|
result=
|
||||||
@@ -57,7 +53,6 @@ function isTrue() {
|
|||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
eval "$oldState"
|
|
||||||
return ${result}
|
return ${result}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -87,18 +82,7 @@ function logn() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function log() {
|
function log() {
|
||||||
local oldState
|
echo "[init] $*"
|
||||||
# The return status when listing options is zero if all optnames are enabled, non- zero otherwise.
|
|
||||||
oldState=$(shopt -po xtrace || true)
|
|
||||||
shopt -u -o xtrace
|
|
||||||
|
|
||||||
if isDebugging || isTrue "${LOG_TIMESTAMP:-false}"; then
|
|
||||||
ts=" $(date --rfc-3339=seconds)"
|
|
||||||
else
|
|
||||||
ts=
|
|
||||||
fi
|
|
||||||
echo "[init]${ts} $*"
|
|
||||||
eval "$oldState"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function logAutopause() {
|
function logAutopause() {
|
||||||
@@ -199,7 +183,6 @@ function isFamily() {
|
|||||||
}
|
}
|
||||||
function isType() {
|
function isType() {
|
||||||
for t in "${@}"; do
|
for t in "${@}"; do
|
||||||
# shellcheck disable=SC2153
|
|
||||||
if [[ $TYPE == "$t" ]]; then
|
if [[ $TYPE == "$t" ]]; then
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
@@ -207,32 +190,17 @@ function isType() {
|
|||||||
return 1
|
return 1
|
||||||
}
|
}
|
||||||
|
|
||||||
function evaluateJavaCompatibilityForForge() {
|
|
||||||
javaRelease=$(mc-image-helper java-release)
|
|
||||||
if versionLessThan 1.18 && (( javaRelease > 8 )); then
|
|
||||||
log "**********************************************************************"
|
|
||||||
log "WARNING: Some mods and modpacks may require Java 8."
|
|
||||||
log " Please use itzg/minecraft-server:java8"
|
|
||||||
log "**********************************************************************"
|
|
||||||
sleep 5
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function extract() {
|
function extract() {
|
||||||
src=${1?}
|
src=${1?}
|
||||||
destDir=${2?}
|
destDir=${2?}
|
||||||
|
|
||||||
type=$(file -b --mime-type "${src}")
|
type=$(file -b --mime-type "${src}")
|
||||||
case "${type}" in
|
if [[ $type == application/zip ]]; then
|
||||||
application/zip)
|
unzip -q -d "${destDir}" "${src}"
|
||||||
unzip -q -d "${destDir}" "${src}"
|
elif [[ $type == application/x-tar ]]; then
|
||||||
;;
|
tar -C "${destDir}" -xf "${src}"
|
||||||
application/x-tar|application/gzip|application/x-gzip|application/x-bzip2|application/zstd|application/x-zstd)
|
else
|
||||||
tar -C "${destDir}" -xf "${src}"
|
log "ERROR: unsupported archive type: $type"
|
||||||
;;
|
return 1
|
||||||
*)
|
fi
|
||||||
log "ERROR: unsupported archive type: $type"
|
}
|
||||||
return 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
}
|
|
||||||
@@ -8,11 +8,10 @@ services:
|
|||||||
EULA: "TRUE"
|
EULA: "TRUE"
|
||||||
SETUP_ONLY: "TRUE"
|
SETUP_ONLY: "TRUE"
|
||||||
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
||||||
MODS_FORGEAPI_FILE: /config/forgeapi_mods.json
|
MODS_FORGEAPI_FILE: /config/example.json
|
||||||
# Key is defined in .github/workflows/pr.yml and ci.yml
|
# Key is defined in .github/workflows/pr.yml and ci.yml
|
||||||
# This should be coming from github secrets.
|
# This should be coming from github secrets.
|
||||||
MODS_FORGEAPI_KEY: ${MODS_FORGEAPI_KEY}
|
MODS_FORGEAPI_KEY: ${MODS_FORGEAPI_KEY}
|
||||||
REMOVE_OLD_FORGEAPI_MODS: "TRUE"
|
REMOVE_OLD_FORGEAPI_MODS: "TRUE"
|
||||||
MODS_FORGEAPI_DOWNLOAD_DEPENDENCIES: "FALSE"
|
|
||||||
volumes:
|
volumes:
|
||||||
- ./forgeapi_mods.json:/config/forgeapi_mods.json:ro
|
- ./example.json:/config/example.json:ro
|
||||||
|
|||||||
@@ -7,11 +7,5 @@
|
|||||||
"name": "Fabric Voice Mod",
|
"name": "Fabric Voice Mod",
|
||||||
"projectId": "416089",
|
"projectId": "416089",
|
||||||
"releaseType": "beta"
|
"releaseType": "beta"
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Biomes o plenty",
|
|
||||||
"projectId": "220318",
|
|
||||||
"fileName": "BiomesOPlenty-1.18.1-15.0.0.100-universal.jar",
|
|
||||||
"releaseType": "release"
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
@@ -1 +0,0 @@
|
|||||||
[[ $MODS_FORGEAPI_KEY ]] || exit 1
|
|
||||||
@@ -8,8 +8,7 @@ services:
|
|||||||
EULA: "TRUE"
|
EULA: "TRUE"
|
||||||
SETUP_ONLY: "TRUE"
|
SETUP_ONLY: "TRUE"
|
||||||
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
||||||
MODS_FORGEAPI_DOWNLOAD_DEPENDENCIES: "TRUE"
|
MODS_FORGEAPI_PROJECTIDS: 306612,416089
|
||||||
MODS_FORGEAPI_PROJECTIDS: 306612,416089,220318
|
|
||||||
# Allows for Beta releases of 416089 the Fabric Voice Mod
|
# Allows for Beta releases of 416089 the Fabric Voice Mod
|
||||||
MODS_FORGEAPI_RELEASES: BETA
|
MODS_FORGEAPI_RELEASES: BETA
|
||||||
MODS_FORGEAPI_KEY: ${MODS_FORGEAPI_KEY}
|
MODS_FORGEAPI_KEY: ${MODS_FORGEAPI_KEY}
|
||||||
|
|||||||
@@ -1 +0,0 @@
|
|||||||
[[ $MODS_FORGEAPI_KEY ]] || exit 1
|
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
version: "3"
|
|
||||||
|
|
||||||
services:
|
|
||||||
mc:
|
|
||||||
image: ${IMAGE_TO_TEST:-itzg/minecraft-server}
|
|
||||||
environment:
|
|
||||||
EULA: "true"
|
|
||||||
SETUP_ONLY: "TRUE"
|
|
||||||
GENERIC_PACKS: testing
|
|
||||||
GENERIC_PACKS_PREFIX: /packs/
|
|
||||||
GENERIC_PACKS_SUFFIX: .zip
|
|
||||||
volumes:
|
|
||||||
- ./packs:/packs
|
|
||||||
- ./data:/data
|
|
||||||
Binary file not shown.
@@ -1 +0,0 @@
|
|||||||
mc-image-helper assert fileExists one.txt mods/two.txt
|
|
||||||
@@ -1,24 +1,12 @@
|
|||||||
version: "3"
|
version: "3"
|
||||||
|
|
||||||
services:
|
services:
|
||||||
web:
|
|
||||||
image: nginx
|
|
||||||
volumes:
|
|
||||||
- ./web:/usr/share/nginx/html
|
|
||||||
mc:
|
mc:
|
||||||
depends_on:
|
|
||||||
- web
|
|
||||||
image: ${IMAGE_TO_TEST:-itzg/minecraft-server}
|
image: ${IMAGE_TO_TEST:-itzg/minecraft-server}
|
||||||
environment:
|
environment:
|
||||||
EULA: "true"
|
EULA: "true"
|
||||||
SETUP_ONLY: "true"
|
SETUP_ONLY: "TRUE"
|
||||||
GENERIC_PACKS: http://web/configs.zip,/packs/testing.zip
|
GENERIC_PACKS: https://github.com/itzg/mc-image-helper/releases/download/v1.9.5/mc-image-helper-1.9.5.zip,/packs/testing.zip
|
||||||
LOG_TIMESTAMP: "true"
|
|
||||||
# the following are only used to speed up test execution
|
|
||||||
TYPE: CUSTOM
|
|
||||||
CUSTOM_SERVER: /servers/fake.jar
|
|
||||||
VERSION: 1.18.1
|
|
||||||
volumes:
|
volumes:
|
||||||
- ./packs:/packs
|
- ./packs:/packs
|
||||||
- ./data:/data
|
- ./data:/data
|
||||||
- ./fake.jar:/servers/fake.jar
|
|
||||||
|
|||||||
@@ -1,2 +1 @@
|
|||||||
mc-image-helper assert fileExists one.txt mods/two.txt
|
mc-image-helper assert fileExists one.txt mods/two.txt
|
||||||
mc-image-helper assert fileExists config/opt.yml
|
|
||||||
Binary file not shown.
@@ -1,13 +0,0 @@
|
|||||||
version: "3"
|
|
||||||
|
|
||||||
services:
|
|
||||||
mc:
|
|
||||||
restart: "no"
|
|
||||||
image: ${IMAGE_TO_TEST:-itzg/minecraft-server}
|
|
||||||
environment:
|
|
||||||
EULA: "TRUE"
|
|
||||||
SETUP_ONLY: "TRUE"
|
|
||||||
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
|
||||||
OPS: itzg
|
|
||||||
volumes:
|
|
||||||
- ./data:/data
|
|
||||||
@@ -1,3 +0,0 @@
|
|||||||
mc-image-helper assert jsonPathEquals --file=ops.json --path='$[0].name' --expect=itzg
|
|
||||||
mc-image-helper assert jsonPathEquals --file=ops.json --path='$[0].uuid' --expect=5cddfd26-fc86-4981-b52e-c42bb10bfdef
|
|
||||||
mc-image-helper assert jsonPathEquals --file=ops.json --path='$[0].level' --expect=4
|
|
||||||
@@ -11,26 +11,15 @@ setupOnlyMinecraftTest(){
|
|||||||
cd "$folder"
|
cd "$folder"
|
||||||
result=0
|
result=0
|
||||||
|
|
||||||
if [ -f require.sh ]; then
|
if ! logs=$(docker compose run --quiet-pull mc 2>&1); then
|
||||||
# require.sh scripts can check for environment variables, etc that are required for the test.
|
echo "${folder} setup FAILED"
|
||||||
# The script should exit with a non-zero status to indicate the test requirements are missing
|
|
||||||
# and the test should be skipped
|
|
||||||
if ! bash require.sh; then
|
|
||||||
echo "${folder} SKIP"
|
|
||||||
cd ..
|
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! logs=$(docker-compose run mc 2>&1); then
|
|
||||||
echo "${folder} test scenario FAILED"
|
|
||||||
echo ":::::::::::: LOGS ::::::::::::::::
|
echo ":::::::::::: LOGS ::::::::::::::::
|
||||||
$logs
|
$logs
|
||||||
::::::::::::::::::::::::::::::::::
|
::::::::::::::::::::::::::::::::::
|
||||||
"
|
"
|
||||||
result=1
|
result=1
|
||||||
elif [ -f verify.sh ]; then
|
elif [ -f verify.sh ]; then
|
||||||
if ! docker run --rm --entrypoint bash -v "${PWD}/data":/data -v "${PWD}/verify.sh":/verify "${IMAGE_TO_TEST:-itzg/minecraft-server}" -e /verify; then
|
if ! docker run --rm --entrypoint bash -v "${PWD}/data":/data -v "${PWD}/verify.sh":/verify "${IMAGE_TO_TEST:-itzg/minecraft-server}" /verify; then
|
||||||
echo "${folder} verify FAILED"
|
echo "${folder} verify FAILED"
|
||||||
result=1
|
result=1
|
||||||
else
|
else
|
||||||
@@ -40,7 +29,7 @@ $logs
|
|||||||
echo "${folder} PASS"
|
echo "${folder} PASS"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
docker-compose down -v --remove-orphans
|
docker compose down -v --remove-orphans
|
||||||
cd ..
|
cd ..
|
||||||
|
|
||||||
return $result
|
return $result
|
||||||
|
|||||||
@@ -1,15 +0,0 @@
|
|||||||
version: "3"
|
|
||||||
|
|
||||||
services:
|
|
||||||
mc:
|
|
||||||
restart: "no"
|
|
||||||
image: ${IMAGE_TO_TEST:-itzg/minecraft-server}
|
|
||||||
environment:
|
|
||||||
EULA: "TRUE"
|
|
||||||
SETUP_ONLY: "TRUE"
|
|
||||||
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
|
||||||
WHITELIST: itzg
|
|
||||||
ENFORCE_WHITELIST: "true"
|
|
||||||
OVERRIDE_SERVER_PROPERTIES: "true"
|
|
||||||
volumes:
|
|
||||||
- ./data:/data
|
|
||||||
@@ -1,4 +0,0 @@
|
|||||||
mc-image-helper assert jsonPathEquals --file=whitelist.json --path='$[0].name' --expect=itzg
|
|
||||||
mc-image-helper assert jsonPathEquals --file=whitelist.json --path='$[0].uuid' --expect=5cddfd26-fc86-4981-b52e-c42bb10bfdef
|
|
||||||
mc-image-helper assert propertyEquals --file=server.properties --property=white-list --expect=true
|
|
||||||
mc-image-helper assert propertyEquals --file=server.properties --property=enforce-whitelist --expect=true
|
|
||||||
@@ -1,14 +0,0 @@
|
|||||||
version: "3"
|
|
||||||
|
|
||||||
services:
|
|
||||||
mc:
|
|
||||||
restart: "no"
|
|
||||||
image: ${IMAGE_TO_TEST:-itzg/minecraft-server}
|
|
||||||
environment:
|
|
||||||
EULA: "TRUE"
|
|
||||||
SETUP_ONLY: "TRUE"
|
|
||||||
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
|
||||||
WORLD: /worlds/world-for-testing.tar.bz2
|
|
||||||
volumes:
|
|
||||||
- ./worlds:/worlds:ro
|
|
||||||
- ./data:/data
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
mc-image-helper assert fileExists world/level.dat
|
|
||||||
Binary file not shown.
@@ -1,14 +0,0 @@
|
|||||||
version: "3"
|
|
||||||
|
|
||||||
services:
|
|
||||||
mc:
|
|
||||||
restart: "no"
|
|
||||||
image: ${IMAGE_TO_TEST:-itzg/minecraft-server}
|
|
||||||
environment:
|
|
||||||
EULA: "TRUE"
|
|
||||||
SETUP_ONLY: "TRUE"
|
|
||||||
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
|
||||||
WORLD: /worlds/world-for-testing.tar.gz
|
|
||||||
volumes:
|
|
||||||
- ./worlds:/worlds:ro
|
|
||||||
- ./data:/data
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
mc-image-helper assert fileExists world/level.dat
|
|
||||||
Binary file not shown.
@@ -1,14 +0,0 @@
|
|||||||
version: "3"
|
|
||||||
|
|
||||||
services:
|
|
||||||
mc:
|
|
||||||
restart: "no"
|
|
||||||
image: ${IMAGE_TO_TEST:-itzg/minecraft-server}
|
|
||||||
environment:
|
|
||||||
EULA: "TRUE"
|
|
||||||
SETUP_ONLY: "TRUE"
|
|
||||||
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
|
||||||
WORLD: /worlds/world-for-testing.tar.zst
|
|
||||||
volumes:
|
|
||||||
- ./worlds:/worlds:ro
|
|
||||||
- ./data:/data
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
mc-image-helper assert fileExists world/level.dat
|
|
||||||
Binary file not shown.
@@ -8,7 +8,7 @@ services:
|
|||||||
EULA: "TRUE"
|
EULA: "TRUE"
|
||||||
SETUP_ONLY: "TRUE"
|
SETUP_ONLY: "TRUE"
|
||||||
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
||||||
WORLD: /worlds/world-for-testing.tar
|
WORLD: /worlds/world-for-testing.tgz
|
||||||
volumes:
|
volumes:
|
||||||
- ./worlds:/worlds:ro
|
- ./worlds:/worlds:ro
|
||||||
- ./data:/data
|
- ./data:/data
|
||||||
Reference in New Issue
Block a user