2017-11-01 05:42:44 +00:00
|
|
|
#!/bin/bash
|
|
|
|
|
2020-07-19 20:01:19 +00:00
|
|
|
set -e
|
|
|
|
|
2021-10-22 02:52:55 +00:00
|
|
|
# shellcheck source=start-utils
|
|
|
|
. "${SCRIPTS:-/}start-utils"
|
2021-03-14 20:02:40 +00:00
|
|
|
|
|
|
|
loadForgeVars() {
|
|
|
|
cfgFile=${1?}
|
|
|
|
pat='^([^#;][^=]+)=[:space:]*([^;]*)'
|
|
|
|
while read -r line || [[ -n "$line" ]] ; do
|
|
|
|
if [[ $line =~ $pat ]]; then
|
|
|
|
#echo "MATCHED $line"
|
|
|
|
k=${BASH_REMATCH[1]}
|
|
|
|
v=${BASH_REMATCH[2]}
|
|
|
|
case $k in
|
|
|
|
FORGEURL)
|
|
|
|
forgeInstallerUrl="$v"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
fi
|
|
|
|
done < "$cfgFile"
|
|
|
|
}
|
|
|
|
|
2020-08-19 01:44:11 +00:00
|
|
|
isDebugging && set -x
|
2017-11-01 05:42:44 +00:00
|
|
|
|
2023-06-19 00:58:29 +00:00
|
|
|
if [[ ${VERSION^^} == LATEST ]]; then
|
2024-10-22 21:04:38 +00:00
|
|
|
logWarning "For the old TYPE=CURSEFORGE mechanism it is best to set VERSION to a specific value"
|
2023-06-19 00:58:29 +00:00
|
|
|
fi
|
|
|
|
resolveVersion
|
|
|
|
|
2021-10-22 02:52:55 +00:00
|
|
|
: "${FTB_BASE_DIR:=${CF_BASE_DIR:-/data/FeedTheBeast}}"
|
2020-12-31 19:11:26 +00:00
|
|
|
export FTB_BASE_DIR
|
|
|
|
|
2022-08-13 15:49:33 +00:00
|
|
|
legacyJavaFixerUrl=https://files.minecraftforge.net/maven/net/minecraftforge/lex/legacyjavafixer/1.0/legacyjavafixer-1.0.jar
|
2021-04-26 13:19:50 +00:00
|
|
|
export TYPE=CURSEFORGE
|
2017-11-01 05:42:44 +00:00
|
|
|
|
2019-01-22 03:07:38 +00:00
|
|
|
FTB_SERVER_MOD=${FTB_SERVER_MOD:-$CF_SERVER_MOD}
|
|
|
|
|
2020-03-06 15:52:17 +00:00
|
|
|
log "Looking for Feed-The-Beast / CurseForge server modpack."
|
2022-05-27 03:02:26 +00:00
|
|
|
if [[ ! $FTB_SERVER_MOD ]]; then
|
2024-10-22 21:04:38 +00:00
|
|
|
logError "CF_SERVER_MOD or FTB_SERVER_MOD is required to be set"
|
2022-05-27 03:02:26 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
2020-07-19 20:01:19 +00:00
|
|
|
|
2022-01-01 21:23:21 +00:00
|
|
|
downloadModpack() {
|
|
|
|
srv_modpack=${FTB_SERVER_MOD}
|
|
|
|
if isURL "${srv_modpack}"; then
|
|
|
|
log "Downloading modpack from ${srv_modpack}..."
|
2022-11-27 15:19:28 +00:00
|
|
|
if ! srv_modpack=$(get -o /data --output-filename --skip-existing "${srv_modpack}"); then
|
2024-10-22 21:04:38 +00:00
|
|
|
logError "Failed to download modpack"
|
2022-01-01 21:23:21 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
2020-07-19 20:01:19 +00:00
|
|
|
fi
|
2022-01-01 21:23:21 +00:00
|
|
|
if [[ "${srv_modpack:0:5}" == "data/" ]]; then
|
|
|
|
# Prepend with "/"
|
|
|
|
srv_modpack="/${srv_modpack}"
|
|
|
|
fi
|
|
|
|
if [[ ! "${srv_modpack:0:1}" == "/" ]]; then
|
|
|
|
# If not an absolute path, assume file is in "/data"
|
|
|
|
srv_modpack=/data/${srv_modpack}
|
|
|
|
fi
|
|
|
|
if [[ ! -f "${srv_modpack}" ]]; then
|
2024-10-22 21:04:38 +00:00
|
|
|
logError "FTB server modpack: ${srv_modpack} not found."
|
2022-01-01 21:23:21 +00:00
|
|
|
exit 2
|
|
|
|
fi
|
2022-11-27 15:19:28 +00:00
|
|
|
if [[ ! "${srv_modpack: -4}" == ".zip" ]]; then
|
2024-10-22 21:04:38 +00:00
|
|
|
logError "FTB server modpack: ${srv_modpack} is not a zip archive."
|
|
|
|
logError "Please set FTB_SERVER_MOD to a file with a .zip extension."
|
2022-11-27 15:19:28 +00:00
|
|
|
exit 2
|
|
|
|
fi
|
2022-01-01 21:23:21 +00:00
|
|
|
FTB_SERVER_MOD=${srv_modpack}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ! isTrue "${USE_MODPACK_START_SCRIPT:-true}"; then
|
|
|
|
downloadModpack
|
2020-07-19 20:01:19 +00:00
|
|
|
|
2020-07-19 23:10:16 +00:00
|
|
|
needsInstall=true
|
|
|
|
installMarker=/data/.curseforge-installed
|
|
|
|
if [ -f $installMarker ]; then
|
|
|
|
if [ "$(cat $installMarker)" != "${FTB_SERVER_MOD}" ]; then
|
|
|
|
log "Upgrading modpack"
|
|
|
|
|
2022-01-01 17:05:07 +00:00
|
|
|
serverJar=$(find "${FTB_BASE_DIR}" -type f \( -path "*/libraries/*" -o -path "*/mods/*" \) -prune -o -name "forge*.jar" -not -name "forge*installer.jar" -print)
|
2020-07-19 23:10:16 +00:00
|
|
|
if [[ "${serverJar}" ]]; then
|
2021-10-22 02:52:55 +00:00
|
|
|
rm -rf "$(dirname "${serverJar}")"/{mods,*.jar,libraries,resources,scripts,config}
|
2020-07-19 23:10:16 +00:00
|
|
|
fi
|
|
|
|
else
|
|
|
|
needsInstall=false
|
|
|
|
fi
|
2020-07-19 20:01:19 +00:00
|
|
|
fi
|
|
|
|
|
2020-07-19 23:10:16 +00:00
|
|
|
if $needsInstall; then
|
|
|
|
log "Unpacking FTB server modpack ${FTB_SERVER_MOD} ..."
|
2021-10-22 02:52:55 +00:00
|
|
|
mkdir -p "${FTB_BASE_DIR}"
|
|
|
|
unzip -o "${FTB_SERVER_MOD}" -d "${FTB_BASE_DIR}" | awk '{printf "."} END {print ""}'
|
2020-08-19 01:44:11 +00:00
|
|
|
|
2021-10-22 02:52:55 +00:00
|
|
|
serverJar=$(find "${FTB_BASE_DIR}" -type f \( -path "*/libraries/*" -o -path "*/mods/*" \) -prune -o -name "forge*.jar" -not -name "forge*installer.jar" -print)
|
2021-04-30 16:05:56 +00:00
|
|
|
if [[ -z "$serverJar" ]]; then
|
2021-03-14 20:02:40 +00:00
|
|
|
|
|
|
|
if [ -f "${FTB_BASE_DIR}/settings.cfg" ]; then
|
|
|
|
loadForgeVars "${FTB_BASE_DIR}/settings.cfg"
|
|
|
|
|
|
|
|
if [[ $forgeInstallerUrl ]]; then
|
|
|
|
forgeInstallerJar="${FTB_BASE_DIR}/forge-installer.jar"
|
|
|
|
if ! curl -fsSL -o "$forgeInstallerJar" "$forgeInstallerUrl" ; then
|
2024-10-22 21:04:38 +00:00
|
|
|
logError "Failed to download Forge installer from $forgeInstallerUrl"
|
2021-03-14 20:02:40 +00:00
|
|
|
exit 2
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
else
|
2021-03-19 00:56:40 +00:00
|
|
|
forgeInstallerJar=$(find "${FTB_BASE_DIR}" -name "forge*installer.jar")
|
2021-03-14 20:02:40 +00:00
|
|
|
fi
|
|
|
|
|
2020-08-19 01:44:11 +00:00
|
|
|
if [[ -z "${forgeInstallerJar}" ]]; then
|
2024-10-22 21:04:38 +00:00
|
|
|
logError "Unable to find forge installer in modpack"
|
|
|
|
logError " or download using modpack config."
|
|
|
|
logError " Make sure you downloaded the server files."
|
2020-08-19 01:44:11 +00:00
|
|
|
exit 2
|
|
|
|
fi
|
2020-07-19 23:10:16 +00:00
|
|
|
|
2020-08-19 01:44:11 +00:00
|
|
|
log "Installing forge server"
|
2021-06-05 22:46:59 +00:00
|
|
|
dirOfInstaller=$(dirname "${forgeInstallerJar}")
|
2021-10-22 02:52:55 +00:00
|
|
|
(cd "${dirOfInstaller}"; java -jar "$(basename "${forgeInstallerJar}")" --installServer)
|
2020-07-19 23:10:16 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
echo "${FTB_SERVER_MOD}" > $installMarker
|
|
|
|
fi
|
2020-07-19 20:01:19 +00:00
|
|
|
|
2021-10-22 02:52:55 +00:00
|
|
|
SERVER=$(find "${FTB_BASE_DIR}" -maxdepth 2 -type f \( -path "/libraries/*" -o -path "/mods/*" \) -prune -o -name "forge*.jar" -not -name "forge*installer.jar" -print)
|
2020-07-19 20:01:19 +00:00
|
|
|
if [[ -z "${SERVER}" || ! -f "${SERVER}" ]]; then
|
2024-10-22 21:04:38 +00:00
|
|
|
logError "Unable to locate installed forge server jar"
|
2021-10-22 02:52:55 +00:00
|
|
|
isDebugging && find "${FTB_BASE_DIR}" -name "forge*.jar"
|
2020-07-19 20:01:19 +00:00
|
|
|
exit 2
|
|
|
|
fi
|
2021-10-22 02:52:55 +00:00
|
|
|
export SERVER
|
2020-07-19 20:01:19 +00:00
|
|
|
|
2021-10-22 02:52:55 +00:00
|
|
|
FTB_DIR=$(dirname "${SERVER}")
|
|
|
|
export FTB_DIR
|
2020-07-19 20:01:19 +00:00
|
|
|
|
2021-10-22 02:52:55 +00:00
|
|
|
exec "${SCRIPTS:-/}start-setupWorld" "$@"
|
2017-11-01 05:42:44 +00:00
|
|
|
fi
|
|
|
|
|
2022-05-30 13:41:21 +00:00
|
|
|
|
|
|
|
findStartScript() {
|
|
|
|
entryScriptExpr=(
|
|
|
|
-name ServerStart.sh
|
|
|
|
-o -name serverstart.sh
|
|
|
|
-o -name ServerStartLinux.sh
|
|
|
|
-o -name LaunchServer.sh
|
|
|
|
-o -name server-start.sh
|
2022-11-23 14:21:03 +00:00
|
|
|
-o -name SERVER-START.sh
|
2022-05-30 13:41:21 +00:00
|
|
|
-o -name start-server.sh
|
|
|
|
-o -name startserver.sh
|
|
|
|
-o -name StartServer.sh
|
|
|
|
-o -name run.sh
|
2022-07-16 15:01:08 +00:00
|
|
|
-o -name start.sh
|
2022-12-10 00:26:16 +00:00
|
|
|
-o -name launch.sh
|
2022-05-30 13:41:21 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
if [ -d "${FTB_BASE_DIR}" ]; then
|
|
|
|
find "${FTB_BASE_DIR}" \( "${entryScriptExpr[@]}" \) -print -quit
|
2018-08-12 22:25:16 +00:00
|
|
|
fi
|
2022-05-30 13:41:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
startScript=$(findStartScript)
|
2018-08-12 22:25:16 +00:00
|
|
|
|
2018-05-15 01:52:49 +00:00
|
|
|
# only download and install if a mod pack isn't already installed
|
|
|
|
# also check for the start script rather than just the folder
|
|
|
|
# this allows saving just the world separate from the rest of the data directory
|
2022-05-30 13:41:21 +00:00
|
|
|
if [[ ! $startScript ]]; then
|
2022-01-01 21:23:21 +00:00
|
|
|
downloadModpack
|
2018-05-15 01:52:49 +00:00
|
|
|
srv_modpack=${FTB_SERVER_MOD}
|
2022-01-01 21:23:21 +00:00
|
|
|
|
2020-03-06 15:52:17 +00:00
|
|
|
log "Unpacking FTB server modpack ${srv_modpack} ..."
|
2021-10-22 02:52:55 +00:00
|
|
|
mkdir -p "${FTB_BASE_DIR}"
|
|
|
|
unzip -o "${srv_modpack}" -d "${FTB_BASE_DIR}" | awk '{printf "."} END {print ""}'
|
2021-04-11 15:36:17 +00:00
|
|
|
|
2022-05-30 13:41:21 +00:00
|
|
|
installScriptExpr=(
|
|
|
|
-name install.sh
|
|
|
|
-o -name FTBInstall.sh
|
|
|
|
-o -name Install.sh
|
|
|
|
)
|
|
|
|
|
|
|
|
installScript=$(find "${FTB_BASE_DIR}" -maxdepth 2 -type f \( "${installScriptExpr[@]}" \) -print -quit)
|
2021-04-11 15:36:17 +00:00
|
|
|
if [[ "$installScript" ]]; then
|
|
|
|
(
|
|
|
|
cd "$(dirname "${installScript}")"
|
2022-05-30 13:41:21 +00:00
|
|
|
chmod +x "${installScript}"
|
|
|
|
log "Running included $(basename "${installScript}"). This might take a minute or two..."
|
|
|
|
"${installScript}" > install.log
|
2021-04-11 15:36:17 +00:00
|
|
|
)
|
|
|
|
fi
|
2018-05-15 01:52:49 +00:00
|
|
|
|
2022-05-30 13:41:21 +00:00
|
|
|
startScript=$(findStartScript)
|
|
|
|
fi
|
2019-03-11 02:50:42 +00:00
|
|
|
|
2022-05-30 13:41:21 +00:00
|
|
|
# start script provided by unzipped+installed modpack?
|
|
|
|
if [[ ! $startScript ]]; then
|
|
|
|
# no, then look for a forge jar to run
|
|
|
|
|
|
|
|
# Allow up to 2 levels since some modpacks have a top-level directory named for the modpack
|
|
|
|
forgeJar=$(find "${FTB_BASE_DIR}" -maxdepth 2 -type f \( -path "/libraries/*" -o -path "/mods/*" \) -prune -o -name "forge*.jar" -not -name "forge*installer.jar" -print)
|
|
|
|
if [[ "$forgeJar" ]]; then
|
|
|
|
FTB_BASE_DIR=$(dirname "${forgeJar}")
|
|
|
|
export FTB_BASE_DIR
|
|
|
|
log "No entry script found, so building one for ${forgeJar}"
|
|
|
|
cat > "${FTB_BASE_DIR}/ServerStart.sh" <<EOF
|
2019-03-11 02:50:42 +00:00
|
|
|
#!/bin/sh
|
|
|
|
. ./settings-local.sh
|
2019-07-01 23:19:50 +00:00
|
|
|
java \${JAVA_PARAMETERS} -Xmx\${MAX_RAM} -jar $(basename "${forgeJar}") nogui
|
2019-03-11 02:50:42 +00:00
|
|
|
EOF
|
2022-05-30 13:41:21 +00:00
|
|
|
startScript="${FTB_BASE_DIR}/ServerStart.sh"
|
|
|
|
chmod +x "$startScript"
|
|
|
|
else
|
2024-10-22 21:04:38 +00:00
|
|
|
logError "Modpack missing start script and unable to find Forge jar to generate one"
|
2019-06-08 21:47:28 +00:00
|
|
|
exit 2
|
2022-05-30 13:41:21 +00:00
|
|
|
fi
|
2018-09-30 19:39:37 +00:00
|
|
|
fi
|
|
|
|
|
2022-05-30 18:07:25 +00:00
|
|
|
# Modpacks that use https://github.com/BloodyMods/ServerStarter will sometimes specify an
|
|
|
|
# extra subpath where all the server files get installed. Need to transplant EULA file there.
|
|
|
|
serverSetupConfig=$(find "${FTB_BASE_DIR}" -type f -name server-setup-config.yaml)
|
|
|
|
if [[ $serverSetupConfig && $serverSetupConfig != "~" ]]; then
|
|
|
|
if baseInstallPath=$(mc-image-helper yaml-path --file "$serverSetupConfig" ".install.baseInstallPath"); then
|
|
|
|
resolvedBaseInstallPath="$(dirname "$serverSetupConfig")/${baseInstallPath}"
|
|
|
|
mkdir -p "$resolvedBaseInstallPath"
|
|
|
|
|
|
|
|
cp -n /data/eula.txt "${resolvedBaseInstallPath}/eula.txt"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
2022-05-30 13:41:21 +00:00
|
|
|
FTB_SERVER_START="$startScript"
|
2021-10-22 02:52:55 +00:00
|
|
|
export FTB_SERVER_START
|
2019-06-08 21:47:28 +00:00
|
|
|
|
2021-10-22 02:52:55 +00:00
|
|
|
FTB_DIR=$(dirname "${FTB_SERVER_START}")
|
|
|
|
export FTB_DIR
|
2019-06-08 21:47:28 +00:00
|
|
|
chmod a+x "${FTB_SERVER_START}"
|
2020-08-19 01:44:11 +00:00
|
|
|
grep fml.queryResult=confirm "${FTB_SERVER_START}" > /dev/null || \
|
2020-03-29 13:55:53 +00:00
|
|
|
sed -i 's/-jar/-Dfml.queryResult=confirm -jar/' "${FTB_SERVER_START}"
|
2019-06-08 21:47:28 +00:00
|
|
|
sed -i 's/.*read.*Restart now/#\0/' "${FTB_SERVER_START}"
|
|
|
|
legacyJavaFixerPath="${FTB_DIR}/mods/legacyjavafixer.jar"
|
2017-11-01 05:42:44 +00:00
|
|
|
|
2021-10-22 02:52:55 +00:00
|
|
|
if isTrue "${FTB_LEGACYJAVAFIXER}" && [ ! -e "${legacyJavaFixerPath}" ]; then
|
2020-03-06 15:52:17 +00:00
|
|
|
log "Installing legacy java fixer to ${legacyJavaFixerPath}"
|
2021-10-22 02:52:55 +00:00
|
|
|
if ! get -o "${legacyJavaFixerPath}" ${legacyJavaFixerUrl}; then
|
2024-10-22 21:04:38 +00:00
|
|
|
logError "Failed to download legacy java fixer from ${legacyJavaFixerUrl}"
|
2021-10-22 02:52:55 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
2018-01-07 23:18:45 +00:00
|
|
|
fi
|
|
|
|
|
2021-12-11 02:50:40 +00:00
|
|
|
export FAMILY=FORGE
|
2021-10-22 02:52:55 +00:00
|
|
|
exec "${SCRIPTS:-/}start-setupWorld" "$@"
|