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
|
|
|
|
|
2019-10-15 12:38:54 +02:00
|
|
|
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
|
2019-10-15 12:38:54 +02:00
|
|
|
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
|
2019-10-15 12:38:54 +02:00
|
|
|
echo "[entrypoint.sh]installing..."
|
2019-07-21 23:04:00 +02:00
|
|
|
bash linuxgsm.sh "$SERVER_GAME"
|
|
|
|
./"$SERVER_EXECUTABLE" auto-install
|
|
|
|
fi
|
2019-10-15 12:38:54 +02:00
|
|
|
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
|