prophunt-garrysmod/lgsm/entrypoint.sh

81 lines
1.4 KiB
Bash
Raw Normal View History

2019-07-21 23:04:00 +02:00
#!/bin/bash
if [ "${DEBUGGING}" = "true" ]; then
set -o xtrace
fi
set -o errexit
2019-07-29 21:53:26 +02:00
set -o nounset
2019-07-21 23:04:00 +02:00
set -o pipefail
echo "[entrypoint.sh]starting entrypoint.sh"
2019-07-21 23:04:00 +02:00
set -e
# --- Install / Update ---
cd "$STEAM_PATH"
2021-11-08 20:10:08 +01:00
if [ -n "$SERVER_EXECUTABLE" ] && [ -e "${STEAM_PATH}/$SERVER_EXECUTABLE" ] && [ -d "$STEAM_CMD" ]; then
echo "[entrypoint.sh]updating..."
2022-02-10 18:53:49 +01:00
if "$LGSM_UPDATE"; then
2023-03-01 17:19:17 +01:00
./"$SERVER_EXECUTABLE" update-lgsm || (
2022-02-10 18:53:49 +01:00
# this sometimes prevent updating, I dont get it why this is an issue
rm -rf "${STEAM_PATH}/lgsm/functions/lgsm"
./"$SERVER_EXECUTABLE" update-lgsm
)
fi
2019-07-21 23:04:00 +02:00
./"$SERVER_EXECUTABLE" update
else
echo "[entrypoint.sh]installing..."
2019-07-21 23:04:00 +02:00
bash linuxgsm.sh "$SERVER_GAME"
./"$SERVER_EXECUTABLE" auto-install
fi
echo "[entrypoint.sh]update / installation done!"
2019-07-21 23:04:00 +02:00
if [ -e "/home/prepareServer.sh" ]; then
cd /home
2019-07-29 21:53:26 +02:00
./prepareServer.sh "$@"
2019-07-21 23:04:00 +02:00
cd "$STEAM_PATH"
fi
# --- Start Server ---
#start server
IS_RUNNING="true"
function stopServer() {
echo "stopping server..."
cd "${STEAM_PATH}"
pid=$(pidof "$SERVER_EXECUTABLE")
kill -2 "$pid" || true
echo "server stopped!"
echo "stopping entrypoint..."
IS_RUNNING="false"
2019-07-29 21:53:26 +02:00
echo "done!"
2019-07-21 23:04:00 +02:00
}
2023-12-04 11:49:27 +01:00
./"$SERVER_EXECUTABLE" start
2019-07-21 23:04:00 +02:00
trap stopServer SIGTERM
#start cron
bash "/home/initCron.sh"
# --- Wait for Shutdown ---
echo "Server is running, waiting for SIGTERM"
2023-12-04 11:49:27 +01:00
tail -f /home/steam/log/console/gmodserver-console.log &
2019-07-21 23:04:00 +02:00
while [ "$IS_RUNNING" = "true" ]
do
sleep 1s
done
echo "entrypoint stopped"
2023-12-04 11:49:27 +01:00
exit 0