diff --git a/.gitea/workflows/pipeline.yml b/.gitea/workflows/pipeline.yml index 52da641..18170da 100644 --- a/.gitea/workflows/pipeline.yml +++ b/.gitea/workflows/pipeline.yml @@ -21,7 +21,7 @@ env: IMAGE_REPO_MINECRAFT: minecraft IMAGE_TAG_DEBIAN: bookworm DIGEST_FILE: .cache/debian-base.digest - VERSIONS: vanilla testing-vanilla fabric testing-fabric neoforged testing-neoforged forge testing-forge + VERSIONS: vanilla testing-vanilla fabric testing-fabric neoforged testing-neoforged forge testing-forge bukkit testing-bukkit jobs: poll-debian-base-and-detect-changes: @@ -149,7 +149,7 @@ jobs: needs.poll-debian-base-and-detect-changes.outputs.new_versions != '' strategy: matrix: - version: [vanilla, testing-vanilla, fabric, testing-fabric, neoforged, testing-neoforged, forge, testing-forge] + version: [vanilla, testing-vanilla, fabric, testing-fabric, neoforged, testing-neoforged, forge, testing-forge, bukkit, testing-bukkit] name: Build and Push ${{ matrix.version }} steps: - name: Checkout repo diff --git a/bukkit/install_script.sh b/bukkit/install_script.sh index 5f65bc4..612a246 100644 --- a/bukkit/install_script.sh +++ b/bukkit/install_script.sh @@ -2,33 +2,30 @@ # Copyright (c) 2022 fithwum # All rights reserved -VERSION_CHECK=$(curl -s "https://piston-meta.mojang.com/mc/game/version_manifest_v2.json" | grep -Pom 1 '"url": "\K[^"]*'$MC_VERSION'.json') -MC_SERVER_FILE=$(curl -s $VERSION_CHECK | jq --raw-output '.downloads.server.url') -MC_RUN_FILE=https://gitea.fithwum.tech/fithwum/minecraft/raw/branch/master/vanilla/run.sh +MC_DIR=/MCserver -rm -fr /MCserver/MCserver_*.jar -rm -fr /MCserver/run_*.sh +# Main Install Links +INSTALLER_FILE=https://cdn.getbukkit.org/craftbukkit/craftbukkit-$MC_VERSION.jar +MC_RUN_FILE=https://gitea.fithwum.tech/fithwum/minecraft/raw/branch/master/bukkit/run.sh # Main install (Debian). # Check for server files and download if needed. -if [ -e /MCserver/MCserver-$MC_VERSION.jar ] +if [ -e $MC_DIR/craftbukkit-$MC_VERSION.jar ] then echo " " - echo "INFO ! MCserver-$MC_VERSION.jar found starting now." + echo "INFO ! craftbukkit-$MC_VERSION.jar found starting now." else echo " " - echo "WARNING ! MCserver-$MC_VERSION.jar is out of date/missing ... will download now." + echo "WARNING ! craftbukkit-$MC_VERSION.jar is out of date/missing ... will download now." echo " " echo "INFO ! Cleaning old files." - mkdir /MCserver/old-server-versions/ - mv /MCserver/MCserver-*.jar /MCserver/old-server-versions/ - mv /MCserver/run-*.sh /MCserver/old-server-versions/ - wget --no-cache --show-progress --progress=bar:force:noscroll $MC_SERVER_FILE -O /MCserver/MCserver-$MC_VERSION.jar - chmod +x /MCserver/MCserver-$MC_VERSION.jar + cd $MC_DIR + rm -fr craftbukkit-*.jar run-*.sh + wget --no-cache --show-progress --progress=bar:force:noscroll $INSTALLER_FILE -O craftbukkit-$MC_VERSION.jar + chmod +x craftbukkit-$MC_VERSION.jar + cd .. fi -sleep 1 - # Looking for run-${MC_VERSION}.sh if [ -e /MCserver/run-$MC_VERSION.sh ] then @@ -41,15 +38,13 @@ if [ -e /MCserver/run-$MC_VERSION.sh ] chmod +x /MCserver/run-$MC_VERSION.sh fi -sleep 1 - # Check for EULA -if [ ! -f /MCserver/eula.txt ]; then +if [ ! -f $MC_DIR/eula.txt ]; then : else if [ "$ACCEPT_EULA" == "false" ]; then - if grep -rq 'eula=true' /MCserver/eula.txt; then - sed -i '/eula=true/c\eula=false' /MCserver/eula.txt + if grep -rq 'eula=true' $MC_DIR/eula.txt; then + sed -i '/eula=true/c\eula=false' $MC_DIR/eula.txt fi echo " " echo "WARNING ! EULA not accepted, you must accept the EULA" @@ -58,20 +53,19 @@ else fi fi -sleep 1 - -if [ ! -f /MCserver/eula.txt ]; then +if [ ! -f $MC_DIR/eula.txt ]; then echo " " echo "WARNING ! EULA not found please stand by..." sleep 5 fi if [ "$ACCEPT_EULA" == "true" ]; then - if grep -rq 'eula=false' /MCserver/eula.txt; then - sed -i '/eula=false/c\eula=true' /MCserver/eula.txt + if grep -rq 'eula=false' $MC_DIR/eula.txt; then + sed -i '/eula=false/c\eula=true' $MC_DIR/eula.txt echo " " echo "INFO ! EULA accepted, server restarting, please wait..." sleep 1 - exec /MCserver/run-$MC_VERSION.sh --dataPath=/MCserver + cd $MC_DIR + exec ./run-$MC_VERSION-$FORGE_VERSION.sh nogui exit 0 fi elif [ "$ACCEPT_EULA" == "false" ]; then @@ -84,20 +78,21 @@ else echo "WARNING ! Something went wrong, please check EULA variable" fi -sleep 1 echo "INFO ! Setting game port." -sed -i '/server-port='*'/c\server-port='$GAME_PORT'' /MCserver/server.properties -sleep 1 +if [ -f $MC_DIR/server.properties ]; then + sed -i '/server-port='*'/c\server-port='$GAME_PORT'' $MC_DIR/server.properties +fi # Set permissions. -chown 99:100 -R /MCserver -chmod 777 -R /MCserver +chown 99:100 -R $MC_DIR +chmod 777 -R $MC_DIR sleep 1 # Run Minecraft server. echo " " echo "INFO ! Starting Minecraft Server $MC_VERSION" -exec /MCserver/run-$MC_VERSION.sh --dataPath=/MCserver +cd $MC_DIR +exec ./run-$MC_VERSION.sh nogui exit \ No newline at end of file diff --git a/bukkit/run.sh b/bukkit/run.sh index f294f43..a30b555 100644 --- a/bukkit/run.sh +++ b/bukkit/run.sh @@ -3,7 +3,7 @@ # All rights reserved cd /MCserver -JAR=./MCserver-*.jar +JAR=./craftbukkit-*.jar while [ true ]; do java -Xmx$XMX_SIZE -Xms$XMS_SIZE -Xmn$XMN_SIZE -jar $JAR nogui diff --git a/testing-bukkit/install_script.sh b/testing-bukkit/install_script.sh index db2e4e6..612a246 100644 --- a/testing-bukkit/install_script.sh +++ b/testing-bukkit/install_script.sh @@ -1,38 +1,32 @@ #!/bin/bash -# Copyright (c) 2020 fithwum +# Copyright (c) 2022 fithwum # All rights reserved -# Display setup -#export DISPLAY=0 +MC_DIR=/MCserver -VERSION_CHECK=$(curl -s "https://piston-meta.mojang.com/mc/game/version_manifest_v2.json" | grep -Pom 1 '"url": "\K[^"]*'$MC_VERSION'.json') -MC_SERVER_FILE=$(curl -s $VERSION_CHECK | jq --raw-output '.downloads.server.url') -MC_RUN_FILE=https://gitea.fithwum.tech/fithwum/minecraft/raw/branch/master/testing/run.sh - -rm -fr /MCserver/MCserver_*.jar -rm -fr /MCserver/run_*.sh +# Main Install Links +INSTALLER_FILE=https://cdn.getbukkit.org/craftbukkit/craftbukkit-$MC_VERSION.jar +MC_RUN_FILE=https://gitea.fithwum.tech/fithwum/minecraft/raw/branch/master/bukkit/run.sh # Main install (Debian). -# Check for files in /MCserver and download if needed. -if [ -e /MCserver/MCserver-$MC_VERSION.jar ] +# Check for server files and download if needed. +if [ -e $MC_DIR/craftbukkit-$MC_VERSION.jar ] then echo " " - echo "INFO ! MCserver-$MC_VERSION.jar found starting now." + echo "INFO ! craftbukkit-$MC_VERSION.jar found starting now." else echo " " - echo "WARNING ! MCserver-$MC_VERSION.jar is out of date/missing ... will download now." + echo "WARNING ! craftbukkit-$MC_VERSION.jar is out of date/missing ... will download now." echo " " echo "INFO ! Cleaning old files." - mkdir /MCserver/old-server-versions/ - mv /MCserver/MCserver-*.jar /MCserver/old-server-versions/ - mv /MCserver/run-*.sh /MCserver/old-server-versions/ - wget --no-cache --show-progress --progress=bar:force:noscroll $MC_SERVER_FILE -O /MCserver/MCserver-$MC_VERSION.jar - chmod +x /MCserver/MCserver-$MC_VERSION.jar + cd $MC_DIR + rm -fr craftbukkit-*.jar run-*.sh + wget --no-cache --show-progress --progress=bar:force:noscroll $INSTALLER_FILE -O craftbukkit-$MC_VERSION.jar + chmod +x craftbukkit-$MC_VERSION.jar + cd .. fi -sleep 1 - -# Looking for run.sh +# Looking for run-${MC_VERSION}.sh if [ -e /MCserver/run-$MC_VERSION.sh ] then echo " " @@ -44,15 +38,13 @@ if [ -e /MCserver/run-$MC_VERSION.sh ] chmod +x /MCserver/run-$MC_VERSION.sh fi -sleep 1 - # Check for EULA -if [ ! -f /MCserver/eula.txt ]; then +if [ ! -f $MC_DIR/eula.txt ]; then : else if [ "$ACCEPT_EULA" == "false" ]; then - if grep -rq 'eula=true' /MCserver/eula.txt; then - sed -i '/eula=true/c\eula=false' /MCserver/eula.txt + if grep -rq 'eula=true' $MC_DIR/eula.txt; then + sed -i '/eula=true/c\eula=false' $MC_DIR/eula.txt fi echo " " echo "WARNING ! EULA not accepted, you must accept the EULA" @@ -61,20 +53,19 @@ else fi fi -sleep 1 - -if [ ! -f /MCserver/eula.txt ]; then +if [ ! -f $MC_DIR/eula.txt ]; then echo " " echo "WARNING ! EULA not found please stand by..." sleep 5 fi if [ "$ACCEPT_EULA" == "true" ]; then - if grep -rq 'eula=false' /MCserver/eula.txt; then - sed -i '/eula=false/c\eula=true' /MCserver/eula.txt + if grep -rq 'eula=false' $MC_DIR/eula.txt; then + sed -i '/eula=false/c\eula=true' $MC_DIR/eula.txt echo " " echo "INFO ! EULA accepted, server restarting, please wait..." sleep 1 - exec /MCserver/run-$MC_VERSION.sh --dataPath=/MCserver + cd $MC_DIR + exec ./run-$MC_VERSION-$FORGE_VERSION.sh nogui exit 0 fi elif [ "$ACCEPT_EULA" == "false" ]; then @@ -87,21 +78,21 @@ else echo "WARNING ! Something went wrong, please check EULA variable" fi -sleep 1 echo "INFO ! Setting game port." -sed -i '/server-port='*'/c\server-port='$GAME_PORT'' /MCserver/server.properties -sleep 1 +if [ -f $MC_DIR/server.properties ]; then + sed -i '/server-port='*'/c\server-port='$GAME_PORT'' $MC_DIR/server.properties +fi # Set permissions. -chown 99:100 -R /MCserver -chmod 777 -R /MCserver +chown 99:100 -R $MC_DIR +chmod 777 -R $MC_DIR sleep 1 # Run Minecraft server. echo " " echo "INFO ! Starting Minecraft Server $MC_VERSION" -exec /MCserver/run-$MC_VERSION.sh --dataPath=/MCserver -#screen -dmS mcserver /MCserver/run-$MC_VERSION.sh --dataPath=/MCserver +cd $MC_DIR +exec ./run-$MC_VERSION.sh nogui exit \ No newline at end of file diff --git a/testing-bukkit/run.sh b/testing-bukkit/run.sh index a72d6ff..51230be 100644 --- a/testing-bukkit/run.sh +++ b/testing-bukkit/run.sh @@ -3,7 +3,7 @@ # All rights reserved cd /MCserver -JAR=./MCserver-*.jar +JAR=./craftbukkit-*.jar # # Check if a screen session is already running # if screen -list | grep -q "MCserver"; then