2017-11-01 06:42:44 +01:00
|
|
|
#!/bin/bash
|
|
|
|
|
2023-07-29 20:09:54 -05:00
|
|
|
: "${FTB_FORCE_REINSTALL:=false}"
|
|
|
|
|
2020-11-26 08:45:51 -06:00
|
|
|
ftbInstallMarker=".ftb-installed"
|
|
|
|
|
2022-01-29 14:53:34 -06:00
|
|
|
# shellcheck source=start-utils
|
|
|
|
. "${SCRIPTS:-/}start-utils"
|
2020-05-31 18:18:54 -05:00
|
|
|
isDebugging && set -x
|
|
|
|
set -e
|
2019-01-21 21:07:38 -06:00
|
|
|
|
2022-08-05 21:42:58 -05:00
|
|
|
if [[ $(getDistro) = alpine ]]; then
|
|
|
|
log "ERROR: the FTBA installer is not supported on Alpine. Use the java8-multiarch image tag instead."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2020-05-31 18:18:54 -05:00
|
|
|
if ! [[ -v FTB_MODPACK_ID ]]; then
|
|
|
|
log "ERROR FTB_MODPACK_ID is required with TYPE=FTB"
|
|
|
|
exit 1
|
2017-11-01 06:42:44 +01:00
|
|
|
fi
|
|
|
|
|
2020-05-31 18:18:54 -05:00
|
|
|
if ! [[ ${FTB_MODPACK_ID} =~ [0-9]+ ]]; then
|
|
|
|
log "ERROR FTB_MODPACK_ID needs to be numeric"
|
|
|
|
exit 1
|
2018-08-12 17:25:16 -05:00
|
|
|
fi
|
|
|
|
|
2021-10-23 09:40:36 -05:00
|
|
|
if [[ ! $FTB_MODPACK_VERSION_ID ]]; then
|
2020-05-31 18:18:54 -05:00
|
|
|
if ! FTB_MODPACK_VERSION_ID=$(curl -fsSL https://api.modpacks.ch/public/modpack/${FTB_MODPACK_ID} | jq -r '.versions | sort_by(.updated)[-1].id'); then
|
|
|
|
log "ERROR unable to resolve latest modpack version ID for modpack ${FTB_MODPACK_ID}"
|
|
|
|
exit 1
|
2018-05-14 18:52:49 -07:00
|
|
|
fi
|
2020-05-31 18:18:54 -05:00
|
|
|
elif ! [[ ${FTB_MODPACK_VERSION_ID} =~ [0-9]+ ]]; then
|
|
|
|
log "ERROR FTB_MODPACK_VERSION_ID needs to be numeric"
|
|
|
|
exit 1
|
2018-08-14 17:45:51 +02:00
|
|
|
fi
|
|
|
|
|
2023-07-29 20:09:54 -05:00
|
|
|
if isTrue "$FTB_FORCE_REINSTALL" || ! [ -f "${ftbInstallMarker}" ] || [ "$(cat "${ftbInstallMarker}")" != "${FTB_MODPACK_ID}=${FTB_MODPACK_VERSION_ID}" ]; then
|
2020-11-26 08:45:51 -06:00
|
|
|
ftbInstaller=/data/ftb-installer
|
|
|
|
if ! [[ -f "${ftbInstaller}" ]]; then
|
|
|
|
log "Downloading FTB installer"
|
2021-08-11 03:53:01 +10:00
|
|
|
if [ "$(uname -m)" == "aarch64" ]; then
|
|
|
|
log "Downloading ARM installer"
|
|
|
|
curl -fsSL https://api.modpacks.ch/public/modpack/1/1/server/arm/linux -o "${ftbInstaller}"
|
|
|
|
else
|
|
|
|
log "Downloading x86 installer"
|
|
|
|
curl -fsSL https://api.modpacks.ch/public/modpack/1/1/server/linux -o "${ftbInstaller}"
|
|
|
|
fi
|
2020-11-26 08:45:51 -06:00
|
|
|
chmod +x "${ftbInstaller}"
|
|
|
|
fi
|
|
|
|
|
2020-05-31 18:18:54 -05:00
|
|
|
log "Installing modpack ID ${FTB_MODPACK_ID}, version ID ${FTB_MODPACK_VERSION_ID}"
|
2022-12-01 07:52:14 -06:00
|
|
|
log "This could take a while..."
|
|
|
|
${ftbInstaller} "${FTB_MODPACK_ID}" "${FTB_MODPACK_VERSION_ID}" --noscript --auto > ftb-installer.log
|
2020-05-31 18:18:54 -05:00
|
|
|
rm -f forge*installer.jar
|
2017-11-01 06:42:44 +01:00
|
|
|
|
2020-05-31 18:18:54 -05:00
|
|
|
echo "${FTB_MODPACK_ID}=${FTB_MODPACK_VERSION_ID}" > ${ftbInstallMarker}
|
2020-07-26 13:50:57 -05:00
|
|
|
|
|
|
|
writeEula
|
2021-02-27 16:58:25 -06:00
|
|
|
|
|
|
|
# some modpacks result in --w----r-- permissions
|
|
|
|
chmod a+r version.json
|
2020-05-31 18:18:54 -05:00
|
|
|
else
|
|
|
|
log "FTB modpack ID ${FTB_MODPACK_ID}, version ID ${FTB_MODPACK_VERSION_ID} is ready to go"
|
2018-01-07 17:18:45 -06:00
|
|
|
fi
|
|
|
|
|
2020-12-26 12:44:37 -08:00
|
|
|
forgeVersion=$(jq -r '.targets|unique[] | select(.name == "forge") | .version' version.json)
|
2021-06-20 10:27:18 -07:00
|
|
|
fabricVersion=$(jq -r '.targets|unique[] | select(.name == "fabric") | .version' version.json)
|
2020-12-26 12:44:37 -08:00
|
|
|
mcVersion=$(jq -r '.targets|unique[] | select(.name == "minecraft") | .version' version.json)
|
2023-07-06 20:05:15 -05:00
|
|
|
VERSION="$mcVersion"
|
|
|
|
export VERSION
|
2020-05-31 18:18:54 -05:00
|
|
|
|
|
|
|
variants=(
|
2022-08-06 16:24:47 -05:00
|
|
|
"forge-${mcVersion}-${forgeVersion}.jar"
|
|
|
|
"forge-${mcVersion}-${forgeVersion}-universal.jar"
|
|
|
|
"forge-${mcVersion}-${forgeVersion}-${mcVersion}-universal.jar"
|
|
|
|
"fabric-${mcVersion}-${fabricVersion}-server-launch.jar"
|
2022-05-19 08:29:52 -04:00
|
|
|
run.sh
|
2020-05-31 18:18:54 -05:00
|
|
|
)
|
2021-11-24 14:30:20 -06:00
|
|
|
for f in "${variants[@]}"; do
|
2020-05-31 18:18:54 -05:00
|
|
|
if [ -f $f ]; then
|
|
|
|
export SERVER=$f
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
if ! [ -v SERVER ]; then
|
2021-06-20 10:27:18 -07:00
|
|
|
log "ERROR unable to locate the installed FTB server jar"
|
2022-08-06 16:24:47 -05:00
|
|
|
log " Tried looking for ${variants[*]}"
|
2020-05-31 18:18:54 -05:00
|
|
|
exit 2
|
2018-07-13 22:33:55 -05:00
|
|
|
fi
|
|
|
|
|
2021-12-10 20:50:40 -06:00
|
|
|
export FAMILY=FORGE
|
2022-01-29 14:53:34 -06:00
|
|
|
|
2022-08-06 16:24:47 -05:00
|
|
|
exec "${SCRIPTS:-/}start-setupWorld" "$@"
|