mirror of
https://github.com/itzg/docker-minecraft-server.git
synced 2026-02-18 23:36:24 +00:00
Compare commits
21 Commits
java11-ope
...
2022.2.0
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
de0188de3d | ||
|
|
2b093ad421 | ||
|
|
0ec73b141f | ||
|
|
de0bb14abd | ||
|
|
26809ef1f0 | ||
|
|
dca4f86fa6 | ||
|
|
eb0c30d134 | ||
|
|
c55cce628d | ||
|
|
240238013b | ||
|
|
18f0f0ceee | ||
|
|
c424fe1c7b | ||
|
|
eb694463c5 | ||
|
|
469afb3200 | ||
|
|
8f8acc40f5 | ||
|
|
7dbd8256ea | ||
|
|
66468975e0 | ||
|
|
6d27ce8461 | ||
|
|
b0817f2a83 | ||
|
|
21602a79e7 | ||
|
|
8a42dfe232 | ||
|
|
d02bbb798e |
94
.github/workflows/build-multiarch.yml
vendored
94
.github/workflows/build-multiarch.yml
vendored
@@ -3,29 +3,61 @@ 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]+-*"
|
||||||
- "[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/arm/v7,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
|
||||||
@@ -38,10 +70,13 @@ jobs:
|
|||||||
images: |
|
images: |
|
||||||
itzg/minecraft-server
|
itzg/minecraft-server
|
||||||
tags: |
|
tags: |
|
||||||
type=ref,event=branch
|
type=ref,event=tag,enable=${{ matrix.variant == 'java17' }}
|
||||||
type=ref,event=tag
|
type=ref,event=tag,prefix=${{ matrix.variant }}-
|
||||||
|
type=raw,value=${{ matrix.variant }}
|
||||||
flavor: |
|
flavor: |
|
||||||
latest=${{ github.event_name == 'push' && github.ref == 'refs/heads/master' }}
|
latest=${{ matrix.variant == 'java17' }}
|
||||||
|
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
|
||||||
@@ -56,38 +91,37 @@ jobs:
|
|||||||
password: ${{ secrets.DOCKER_PASSWORD }}
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||||
|
|
||||||
- name: Build for test
|
- name: Build for test
|
||||||
uses: docker/build-push-action@v2.7.0
|
uses: docker/build-push-action@v2.8.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
|
||||||
cache-from: type=gha
|
build-args: |
|
||||||
|
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
|
||||||
# It is assumed that image variants are merged from master and tested there
|
env:
|
||||||
if: github.ref_name == 'master' || startsWith(github.ref_name, 'test/')
|
MINECRAFT_VERSION: ${{ matrix.mcVersion }}
|
||||||
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.7.0
|
uses: docker/build-push-action@v2.8.0
|
||||||
with:
|
with:
|
||||||
context: .
|
platforms: ${{ matrix.platforms }}
|
||||||
platforms: linux/amd64,linux/arm/v7,linux/arm64
|
push: ${{ github.ref_name == 'master' }}
|
||||||
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: |
|
||||||
- name: Image digest
|
BASE_IMAGE=${{ matrix.baseImage }}
|
||||||
run: echo ${{ steps.docker_build.outputs.digest }}
|
cache-from: type=gha,scope=${{ matrix.variant }}
|
||||||
|
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.7.0
|
uses: docker/build-push-action@v2.8.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: sh tests/setuponlytests/test.sh
|
run: bash tests/setuponlytests/test.sh
|
||||||
|
|
||||||
# - name: Run Full Minecraft Service Tests
|
# - name: Run Full Minecraft Service Tests
|
||||||
# run: |
|
# run: |
|
||||||
|
|||||||
12
.github/workflows/issue-label.yml
vendored
12
.github/workflows/issue-label.yml
vendored
@@ -3,7 +3,7 @@ on:
|
|||||||
types: [labeled]
|
types: [labeled]
|
||||||
|
|
||||||
env:
|
env:
|
||||||
DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }}
|
DISCORD_WEBHOOK: ${{ secrets.DISCORD_ISSUES_WEBHOOK }}
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
labelNotify:
|
labelNotify:
|
||||||
@@ -11,7 +11,13 @@ jobs:
|
|||||||
timeout-minutes: 5
|
timeout-minutes: 5
|
||||||
steps:
|
steps:
|
||||||
- name: notify
|
- name: notify
|
||||||
if: github.event.label.name == 'enhancement' || github.event.label.name == 'bug'
|
if: >
|
||||||
|
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.html_url }}>) added `${{ github.event.label.name }}` label"
|
args: "[${{ github.event.issue.title }} (#${{ github.event.issue.number }})](<${{ github.event.issue.html_url }}>) added `${{ github.event.label.name }}` label"
|
||||||
|
|||||||
4
.github/workflows/main.yml
vendored
4
.github/workflows/main.yml
vendored
@@ -53,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.7.0
|
uses: docker/build-push-action@v2.8.0
|
||||||
if: github.ref_name == 'java8'
|
if: github.ref_name == 'java8'
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
@@ -75,7 +75,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Build and push
|
- name: Build and push
|
||||||
id: docker_build
|
id: docker_build
|
||||||
uses: docker/build-push-action@v2.7.0
|
uses: docker/build-push-action@v2.8.0
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
file: ./Dockerfile
|
file: ./Dockerfile
|
||||||
|
|||||||
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.7.0
|
uses: docker/build-push-action@v2.8.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.7.0
|
uses: docker/build-push-action@v2.8.0
|
||||||
with:
|
with:
|
||||||
context: .
|
context: .
|
||||||
platforms: linux/amd64,linux/arm/v7,linux/arm64
|
platforms: linux/amd64,linux/arm/v7,linux/arm64
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
FROM eclipse-temurin:17-jdk
|
ARG BASE_IMAGE=eclipse-temurin:17-jdk
|
||||||
|
FROM ${BASE_IMAGE}
|
||||||
LABEL org.opencontainers.image.authors="Geoff Bourne <itzgeoff@gmail.com>"
|
|
||||||
|
|
||||||
RUN apt-get update \
|
RUN apt-get update \
|
||||||
&& DEBIAN_FRONTEND=noninteractive \
|
&& DEBIAN_FRONTEND=noninteractive \
|
||||||
@@ -20,6 +19,7 @@ RUN apt-get update \
|
|||||||
rsync \
|
rsync \
|
||||||
nano \
|
nano \
|
||||||
unzip \
|
unzip \
|
||||||
|
zstd \
|
||||||
knockd \
|
knockd \
|
||||||
ttf-dejavu \
|
ttf-dejavu \
|
||||||
&& apt-get clean
|
&& apt-get clean
|
||||||
@@ -61,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.0
|
ARG MC_HELPER_VERSION=1.16.3
|
||||||
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 - \
|
||||||
|
|||||||
39
README.md
39
README.md
@@ -69,7 +69,7 @@ By default, the container will download the latest version of the "vanilla" [Min
|
|||||||
* [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)
|
||||||
* [<strong>ForgeAPI</strong> 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 file](#generic-pack-file)
|
* [Generic pack files](#generic-pack-files)
|
||||||
* [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)
|
||||||
@@ -141,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: Mon Jan 24 04:19:37 UTC 2022 -->
|
<!-- Added by: runner, at: Wed Feb 2 02:53:20 UTC 2022 -->
|
||||||
|
|
||||||
<!--te-->
|
<!--te-->
|
||||||
|
|
||||||
@@ -244,6 +244,8 @@ 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
|
||||||
@@ -391,7 +393,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/wiki/) mode by adding a `-e TYPE=FORGE` to your command-line.
|
Enable [Forge server](http://www.minecraftforge.net/) 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`.
|
||||||
|
|
||||||
@@ -756,6 +758,7 @@ 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
|
||||||
@@ -768,7 +771,13 @@ Example of expected forge api project ids, releases, and key:
|
|||||||
MODS_FORGEAPI_KEY: $WRX...
|
MODS_FORGEAPI_KEY: $WRX...
|
||||||
```
|
```
|
||||||
|
|
||||||
Example of expected ForgeAPI file format: **Note**: name is currently unused, but can be used to document each entry.
|
Example of expected ForgeAPI file format.
|
||||||
|
|
||||||
|
**Field Description**:
|
||||||
|
* Name is currently unused, but can be used to document each entry.
|
||||||
|
* Project id is the id found on the CurseForge website for a particular mod
|
||||||
|
* Release 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
|
||||||
[
|
[
|
||||||
@@ -781,15 +790,31 @@ Example of expected ForgeAPI file format: **Note**: name is currently unused, bu
|
|||||||
"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 file
|
### Generic pack files
|
||||||
|
|
||||||
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.
|
To install all of the server content (jars, mods, plugins, configs, etc) from a zip or tgz file, such as a CurseForge modpack that is missing a server start script, then set `GENERIC_PACK` to the container path or URL of the archive file.
|
||||||
|
|
||||||
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.
|
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.
|
||||||
|
|
||||||
|
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`.
|
||||||
|
|
||||||
### Mod/Plugin URL Listing File
|
### Mod/Plugin URL Listing File
|
||||||
|
|
||||||
|
|||||||
@@ -3,12 +3,6 @@
|
|||||||
# 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 {
|
||||||
|
|||||||
@@ -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,9 +66,12 @@ 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 "Fixing PATH to include java"
|
log "ERROR: PATH should not be explicitly passed into the container"
|
||||||
PATH="${PATH}:/opt/java/openjdk/bin"
|
log " Remove configuration of that variable."
|
||||||
|
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
|
||||||
@@ -116,39 +119,30 @@ 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)
|
||||||
if versionLessThan 1.17; then
|
evaluateJavaCompatibilityForForge
|
||||||
log "**********************************************************************"
|
exec "${SCRIPTS:-/}start-deployForge" "$@"
|
||||||
log "WARNING: The image tag itzg/minecraft-server:java8 is recommended"
|
|
||||||
log " since some mods require Java 8"
|
|
||||||
log " Exception traces reporting ClassCastException: class jdk.internal.loader.ClassLoaders\$AppClassLoader"
|
|
||||||
log " can be fixed with java8"
|
|
||||||
log "**********************************************************************"
|
|
||||||
fi
|
|
||||||
exec ${SCRIPTS:-/}start-deployForge "$@"
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
FABRIC)
|
FABRIC)
|
||||||
exec ${SCRIPTS:-/}start-deployFabric "$@"
|
exec "${SCRIPTS:-/}start-deployFabric" "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
FTBA)
|
FTBA)
|
||||||
exec ${SCRIPTS:-/}start-deployFTBA "$@"
|
evaluateJavaCompatibilityForForge
|
||||||
|
exec "${SCRIPTS:-/}start-deployFTBA" "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
FTB|CURSEFORGE)
|
FTB|CURSEFORGE)
|
||||||
log "**********************************************************************"
|
evaluateJavaCompatibilityForForge
|
||||||
log "NOTE: Some mods and modpacks may require Java 8."
|
exec "${SCRIPTS:-/}start-deployCF" "$@"
|
||||||
log " If so, use itzg/minecraft-server:java8"
|
|
||||||
log "**********************************************************************"
|
|
||||||
exec ${SCRIPTS:-/}start-deployCF "$@"
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
VANILLA)
|
VANILLA)
|
||||||
@@ -156,43 +150,47 @@ case "${TYPE^^}" in
|
|||||||
;;
|
;;
|
||||||
|
|
||||||
SPONGEVANILLA)
|
SPONGEVANILLA)
|
||||||
exec ${SCRIPTS:-/}start-deploySpongeVanilla "$@"
|
exec "${SCRIPTS:-/}start-deploySpongeVanilla" "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
CUSTOM)
|
CUSTOM)
|
||||||
exec ${SCRIPTS:-/}start-deployCustom "$@"
|
evaluateJavaCompatibilityForForge
|
||||||
|
exec "${SCRIPTS:-/}start-deployCustom" "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
MAGMA)
|
MAGMA)
|
||||||
exec ${SCRIPTS:-/}start-deployMagma "$@"
|
evaluateJavaCompatibilityForForge
|
||||||
|
exec "${SCRIPTS:-/}start-deployMagma" "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
MOHIST)
|
MOHIST)
|
||||||
exec ${SCRIPTS:-/}start-deployMohist "$@"
|
evaluateJavaCompatibilityForForge
|
||||||
|
exec "${SCRIPTS:-/}start-deployMohist" "$@"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
CATSERVER)
|
CATSERVER)
|
||||||
exec ${SCRIPTS:-/}start-deployCatserver "$@"
|
evaluateJavaCompatibilityForForge
|
||||||
|
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,6 +42,5 @@ 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,6 +127,5 @@ 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 "$@"
|
||||||
|
|||||||
@@ -44,6 +44,5 @@ 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,6 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
. ${SCRIPTS:-/}start-utils
|
# shellcheck source=start-utils
|
||||||
|
. "${SCRIPTS:-/}start-utils"
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
@@ -26,8 +27,6 @@ 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 SKIP_LOG4J_CONFIG=true
|
|
||||||
|
|
||||||
export FAMILY=HYBRID
|
export FAMILY=HYBRID
|
||||||
# Continue to Final Setup
|
|
||||||
exec ${SCRIPTS:-/}start-setupWorld "$@"
|
exec "${SCRIPTS:-/}start-setupWorld" "$@"
|
||||||
|
|||||||
@@ -55,7 +55,6 @@ 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,6 +1,7 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
. ${SCRIPTS:-/}start-utils
|
# shellcheck source=start-utils
|
||||||
|
. "${SCRIPTS:-/}start-utils"
|
||||||
isDebugging && set -x
|
isDebugging && set -x
|
||||||
|
|
||||||
if isURL ${CUSTOM_SERVER}; then
|
if isURL ${CUSTOM_SERVER}; then
|
||||||
@@ -30,6 +31,6 @@ else
|
|||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export SKIP_LOG4J_CONFIG=true
|
|
||||||
export FAMILY=HYBRID
|
export FAMILY=HYBRID
|
||||||
|
|
||||||
exec ${SCRIPTS:-/}start-setupWorld $@
|
exec ${SCRIPTS:-/}start-setupWorld $@
|
||||||
|
|||||||
@@ -2,7 +2,8 @@
|
|||||||
|
|
||||||
ftbInstallMarker=".ftb-installed"
|
ftbInstallMarker=".ftb-installed"
|
||||||
|
|
||||||
. ${SCRIPTS:-/}start-utils
|
# shellcheck source=start-utils
|
||||||
|
. "${SCRIPTS:-/}start-utils"
|
||||||
isDebugging && set -x
|
isDebugging && set -x
|
||||||
set -e
|
set -e
|
||||||
|
|
||||||
@@ -80,4 +81,5 @@ if ! [ -v SERVER ]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
export FAMILY=FORGE
|
export FAMILY=FORGE
|
||||||
|
|
||||||
exec ${SCRIPTS:-/}start-setupWorld $@
|
exec ${SCRIPTS:-/}start-setupWorld $@
|
||||||
|
|||||||
@@ -38,18 +38,23 @@ install() {
|
|||||||
get_installer "$normForgeVersion" "$shortForgeVersion"
|
get_installer "$normForgeVersion" "$shortForgeVersion"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
log "Installing Forge $shortForgeVersion using $FORGE_INSTALLER"
|
log "Installing Forge $shortForgeVersion. This might take a minute or two..."
|
||||||
mkdir -p mods
|
mkdir -p mods
|
||||||
tries=3
|
tries=3
|
||||||
while ((--tries >= 0)); do
|
while true; do
|
||||||
if java -jar "$FORGE_INSTALLER" --installServer; then
|
if ! java -jar "$FORGE_INSTALLER" --installServer &> forge-installer.log; then
|
||||||
break
|
if ((--tries <= 0)); then
|
||||||
|
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
|
||||||
@@ -148,4 +153,5 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
export FAMILY=FORGE
|
export FAMILY=FORGE
|
||||||
|
|
||||||
exec "${SCRIPTS:-/}start-setupWorld" "$@"
|
exec "${SCRIPTS:-/}start-setupWorld" "$@"
|
||||||
|
|||||||
@@ -58,7 +58,5 @@ 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,13 +1,12 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
. ${SCRIPTS:-/}start-utils
|
# shellcheck source=start-utils
|
||||||
export SKIP_LOG4J_CONFIG=true
|
. "${SCRIPTS:-/}start-utils"
|
||||||
|
|
||||||
isDebugging && set -x
|
isDebugging && set -x
|
||||||
|
|
||||||
: ${VANILLA_VERSION?}
|
: "${VANILLA_VERSION?}"
|
||||||
# stable, dev
|
# stable, dev
|
||||||
: ${MAGMA_CHANNEL:=stable}
|
: "${MAGMA_CHANNEL:=stable}"
|
||||||
|
|
||||||
|
|
||||||
magmaDownloadServer() {
|
magmaDownloadServer() {
|
||||||
@@ -90,4 +89,5 @@ else
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
export FAMILY=HYBRID
|
export FAMILY=HYBRID
|
||||||
exec ${SCRIPTS:-/}start-setupWorld "$@"
|
|
||||||
|
exec "${SCRIPTS:-/}start-setupWorld" "$@"
|
||||||
|
|||||||
@@ -38,7 +38,6 @@ if [ ! -f "${SERVER}" ]; then
|
|||||||
get -o "${SERVER}" "${mohistJob}${MOHIST_BUILD}/artifact/${buildRelPath}"
|
get -o "${SERVER}" "${mohistJob}${MOHIST_BUILD}/artifact/${buildRelPath}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
export SKIP_LOG4J_CONFIG=true
|
|
||||||
|
|
||||||
export FAMILY=HYBRID
|
export FAMILY=HYBRID
|
||||||
|
|
||||||
exec "${SCRIPTS:-$(dirname "$0")}/start-setupWorld" "$@"
|
exec "${SCRIPTS:-$(dirname "$0")}/start-setupWorld" "$@"
|
||||||
|
|||||||
@@ -74,6 +74,5 @@ 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,6 +40,5 @@ 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,6 +31,5 @@ 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,97 +1,9 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
. ${SCRIPTS:-/}start-utils
|
# shellcheck source=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..."
|
||||||
@@ -108,13 +20,15 @@ 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"
|
log "ERROR: failed to download corrected log4j config, fallback to JVM flag"
|
||||||
exit 1
|
useFallbackJvmFlag=true
|
||||||
|
return 1
|
||||||
fi
|
fi
|
||||||
JVM_OPTS="-Dlog4j.configurationFile=${file} ${JVM_OPTS}"
|
JVM_OPTS="-Dlog4j.configurationFile=${file} ${JVM_OPTS}"
|
||||||
canUseRollingLogs=false
|
canUseRollingLogs=false
|
||||||
@@ -134,6 +48,10 @@ 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
|
||||||
|
|
||||||
@@ -169,7 +87,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 || ${GUI} = FALSE ]]; then
|
if [[ ${GUI,,} = false ]]; then
|
||||||
EXTRA_ARGS+=" nogui"
|
EXTRA_ARGS+=" nogui"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -331,6 +249,10 @@ 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-finalExec" "$@"
|
exec "${SCRIPTS:-/}start-setupRbac" "$@"
|
||||||
|
|||||||
@@ -7,6 +7,7 @@ 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}"
|
||||||
|
|
||||||
@@ -36,11 +37,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,,}" ]; then
|
if [ "release" = "${releaseType,,}" ] || [ 1 = "${releaseType,,}" ]; then
|
||||||
RELEASE_NUMBER_FILTER=1
|
RELEASE_NUMBER_FILTER=1
|
||||||
elif [ "beta" = "${releaseType,,}" ]; then
|
elif [ "beta" = "${releaseType,,}" ] || [ 2 = "${releaseType,,}" ]; then
|
||||||
RELEASE_NUMBER_FILTER=2
|
RELEASE_NUMBER_FILTER=2
|
||||||
elif [ "alpha" = "${releaseType,,}" ]; then
|
elif [ "alpha" = "${releaseType,,}" ] || [ 3 = "${releaseType,,}" ]; then
|
||||||
RELEASE_NUMBER_FILTER=3
|
RELEASE_NUMBER_FILTER=3
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
@@ -52,12 +53,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"
|
log "ERROR: unable to retrieve version types for ${VERSION_NAME} from ForgeAPI. Check Forge API key or supplied Minecraft version"
|
||||||
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"
|
||||||
@@ -68,6 +69,7 @@ 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.
|
||||||
@@ -100,9 +102,13 @@ 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.
|
||||||
current_project_file=$(jq -n "$project_files" | jq --arg RELEASE_FILTER "$RELEASE_NUMBER_FILTER" -jc '
|
if [ $project_id_file_name ]; then
|
||||||
.data | sort_by(.id) | reverse | map(select(.releaseType<=($RELEASE_FILTER|tonumber))) | .[0]')
|
current_project_file=$(jq -n "$project_files" | jq --arg FILE_NAME "$project_id_file_name" -jc '
|
||||||
|
.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
|
||||||
@@ -143,6 +149,40 @@ 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
|
||||||
@@ -150,18 +190,19 @@ 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.
|
||||||
for project_id in ${MODS_FORGEAPI_PROJECTIDS//,/ }; do
|
jq -n "$required_dependencies" | jq -c '.[]?' | while read current_project; do
|
||||||
current_release_type=$(jq --arg PROJECT_ID "$project_id" -jc '
|
# Per stack overflow we can use //empty to return empty string that works with -z
|
||||||
.[] | select(.projectId==$PROJECT_ID) | .releaseType' "$MODS_FORGEAPI_FILE")
|
project_id=$(jq -n "$current_project" | jq -jc '.projectId // empty' )
|
||||||
modFileByProjectID $project_id $current_release_type
|
current_release_type=$(jq -n "$current_project" | jq -jc '.releaseType // empty' )
|
||||||
downloadModPackfromModFile
|
current_file_name=$(jq -n "$current_project" | jq -jc '.fileName // empty' )
|
||||||
|
|
||||||
|
modFileByProjectID $project_id $current_release_type $current_file_name
|
||||||
|
downloadModPackfromModFile
|
||||||
|
if isTrue "${MODS_FORGEAPI_DOWNLOAD_DEPENDENCIES}"; then
|
||||||
|
downloadDependencies
|
||||||
|
fi
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@@ -170,7 +211,10 @@ 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
|
||||||
|
|
||||||
|
|||||||
@@ -188,13 +188,16 @@ 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 pack in "${packs[@]}"; do
|
for packEntry in "${packs[@]}"; do
|
||||||
if isURL "$pack"; then
|
pack="${GENERIC_PACKS_PREFIX}${packEntry}${GENERIC_PACKS_SUFFIX}"
|
||||||
|
if isURL "${pack}"; then
|
||||||
mkdir -p /data/packs
|
mkdir -p /data/packs
|
||||||
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"
|
||||||
@@ -207,12 +210,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
|
if ! sha1sum -c "${sum_file}" --status 2> /dev/null; then
|
||||||
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}"
|
||||||
unzip -q -d ${base_dir} "${pack}"
|
extract "${pack}" "${base_dir}"
|
||||||
done
|
done
|
||||||
|
|
||||||
# recalculate the actual base directory of content
|
# recalculate the actual base directory of content
|
||||||
@@ -240,7 +243,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
|
||||||
|
|
||||||
sha256sum "${packFiles[@]}" > "${sum_file}"
|
sha1sum "${packFiles[@]}" > "${sum_file}"
|
||||||
isDebugging && cat "$sum_file"
|
isDebugging && cat "$sum_file"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|||||||
98
scripts/start-setupRbac
Normal file
98
scripts/start-setupRbac
Normal file
@@ -0,0 +1,98 @@
|
|||||||
|
#!/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" "$@"
|
||||||
@@ -183,6 +183,7 @@ 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
|
||||||
@@ -190,17 +191,32 @@ 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}")
|
||||||
if [[ $type == application/zip ]]; then
|
case "${type}" in
|
||||||
unzip -q -d "${destDir}" "${src}"
|
application/zip)
|
||||||
elif [[ $type == application/x-tar ]]; then
|
unzip -q -d "${destDir}" "${src}"
|
||||||
tar -C "${destDir}" -xf "${src}"
|
;;
|
||||||
else
|
application/x-tar|application/gzip|application/x-gzip|application/x-bzip2|application/zstd)
|
||||||
log "ERROR: unsupported archive type: $type"
|
tar -C "${destDir}" -xf "${src}"
|
||||||
return 1
|
;;
|
||||||
fi
|
*)
|
||||||
}
|
log "ERROR: unsupported archive type: $type"
|
||||||
|
return 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|||||||
@@ -8,10 +8,11 @@ services:
|
|||||||
EULA: "TRUE"
|
EULA: "TRUE"
|
||||||
SETUP_ONLY: "TRUE"
|
SETUP_ONLY: "TRUE"
|
||||||
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
||||||
MODS_FORGEAPI_FILE: /config/example.json
|
MODS_FORGEAPI_FILE: /config/forgeapi_mods.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:
|
||||||
- ./example.json:/config/example.json:ro
|
- ./forgeapi_mods.json:/config/forgeapi_mods.json:ro
|
||||||
@@ -7,5 +7,11 @@
|
|||||||
"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
tests/setuponlytests/forgeapimods_file/require.sh
Normal file
1
tests/setuponlytests/forgeapimods_file/require.sh
Normal file
@@ -0,0 +1 @@
|
|||||||
|
[[ $MODS_FORGEAPI_KEY ]] || exit 1
|
||||||
@@ -8,7 +8,8 @@ services:
|
|||||||
EULA: "TRUE"
|
EULA: "TRUE"
|
||||||
SETUP_ONLY: "TRUE"
|
SETUP_ONLY: "TRUE"
|
||||||
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
VERSION: ${MINECRAFT_VERSION:-LATEST}
|
||||||
MODS_FORGEAPI_PROJECTIDS: 306612,416089
|
MODS_FORGEAPI_DOWNLOAD_DEPENDENCIES: "TRUE"
|
||||||
|
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
tests/setuponlytests/forgeapimods_projectids/require.sh
Normal file
1
tests/setuponlytests/forgeapimods_projectids/require.sh
Normal file
@@ -0,0 +1 @@
|
|||||||
|
[[ $MODS_FORGEAPI_KEY ]] || exit 1
|
||||||
14
tests/setuponlytests/generic-packs-prefix/docker-compose.yml
Normal file
14
tests/setuponlytests/generic-packs-prefix/docker-compose.yml
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
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
|
||||||
BIN
tests/setuponlytests/generic-packs-prefix/packs/testing.zip
Normal file
BIN
tests/setuponlytests/generic-packs-prefix/packs/testing.zip
Normal file
Binary file not shown.
1
tests/setuponlytests/generic-packs-prefix/verify.sh
Normal file
1
tests/setuponlytests/generic-packs-prefix/verify.sh
Normal file
@@ -0,0 +1 @@
|
|||||||
|
mc-image-helper assert fileExists one.txt mods/two.txt
|
||||||
@@ -1,12 +1,18 @@
|
|||||||
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: https://github.com/itzg/mc-image-helper/releases/download/v1.9.5/mc-image-helper-1.9.5.zip,/packs/testing.zip
|
GENERIC_PACKS: http://web/configs.zip,/packs/testing.zip
|
||||||
volumes:
|
volumes:
|
||||||
- ./packs:/packs
|
- ./packs:/packs
|
||||||
- ./data:/data
|
- ./data:/data
|
||||||
|
|||||||
@@ -1 +1,2 @@
|
|||||||
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
|
||||||
BIN
tests/setuponlytests/generic-packs/web/configs.zip
Normal file
BIN
tests/setuponlytests/generic-packs/web/configs.zip
Normal file
Binary file not shown.
13
tests/setuponlytests/ops_from_scratch/docker-compose.yml
Normal file
13
tests/setuponlytests/ops_from_scratch/docker-compose.yml
Normal file
@@ -0,0 +1,13 @@
|
|||||||
|
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
|
||||||
3
tests/setuponlytests/ops_from_scratch/verify.sh
Normal file
3
tests/setuponlytests/ops_from_scratch/verify.sh
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
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,15 +11,26 @@ setupOnlyMinecraftTest(){
|
|||||||
cd "$folder"
|
cd "$folder"
|
||||||
result=0
|
result=0
|
||||||
|
|
||||||
if ! logs=$(docker compose run --quiet-pull mc 2>&1); then
|
if [ -f require.sh ]; then
|
||||||
echo "${folder} setup FAILED"
|
# require.sh scripts can check for environment variables, etc that are required for the test.
|
||||||
|
# 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}" /verify; 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
|
||||||
echo "${folder} verify FAILED"
|
echo "${folder} verify FAILED"
|
||||||
result=1
|
result=1
|
||||||
else
|
else
|
||||||
@@ -29,7 +40,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
|
||||||
|
|||||||
@@ -0,0 +1,15 @@
|
|||||||
|
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
|
||||||
4
tests/setuponlytests/whitelist_from_scratch/verify.sh
Normal file
4
tests/setuponlytests/whitelist_from_scratch/verify.sh
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
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
|
||||||
@@ -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.tgz
|
WORLD: /worlds/world-for-testing.tar
|
||||||
volumes:
|
volumes:
|
||||||
- ./worlds:/worlds:ro
|
- ./worlds:/worlds:ro
|
||||||
- ./data:/data
|
- ./data:/data
|
||||||
14
tests/setuponlytests/world_from_tarbz2/docker-compose.yml
Normal file
14
tests/setuponlytests/world_from_tarbz2/docker-compose.yml
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
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
tests/setuponlytests/world_from_tarbz2/verify.sh
Normal file
1
tests/setuponlytests/world_from_tarbz2/verify.sh
Normal file
@@ -0,0 +1 @@
|
|||||||
|
mc-image-helper assert fileExists world/level.dat
|
||||||
Binary file not shown.
14
tests/setuponlytests/world_from_targz/docker-compose.yml
Normal file
14
tests/setuponlytests/world_from_targz/docker-compose.yml
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
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
tests/setuponlytests/world_from_targz/verify.sh
Normal file
1
tests/setuponlytests/world_from_targz/verify.sh
Normal file
@@ -0,0 +1 @@
|
|||||||
|
mc-image-helper assert fileExists world/level.dat
|
||||||
Binary file not shown.
14
tests/setuponlytests/world_from_tarzst/docker-compose.yml
Normal file
14
tests/setuponlytests/world_from_tarzst/docker-compose.yml
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
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
tests/setuponlytests/world_from_tarzst/verify.sh
Normal file
1
tests/setuponlytests/world_from_tarzst/verify.sh
Normal file
@@ -0,0 +1 @@
|
|||||||
|
mc-image-helper assert fileExists world/level.dat
|
||||||
Binary file not shown.
Reference in New Issue
Block a user