From 9e243293ba8209cb8d0a3f6bfc02c6df802c08d2 Mon Sep 17 00:00:00 2001 From: Charles Morgan Date: Thu, 17 Jun 2021 20:20:01 -0400 Subject: [PATCH] Add auto update script Add's auto-update option inside entry point if `AUTO_UPDATE` flag is set to 1 Pulled from parkers entrypoint for source debian --- games/source/entrypoint.sh | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/games/source/entrypoint.sh b/games/source/entrypoint.sh index d5cfc60..b04e3c6 100644 --- a/games/source/entrypoint.sh +++ b/games/source/entrypoint.sh @@ -38,6 +38,30 @@ cd /home/container || exit 1 # replacing the values. PARSED=$(echo "${STARTUP}" | sed -e 's/{{/${/g' -e 's/}}/}/g' | eval echo "$(cat -)") +## just in case someone removed the defaults. +if [ "${STEAM_USER}" == "" ]; then + echo -e "steam user is not set.\n" + echo -e "Using anonymous user.\n" + STEAM_USER=anonymous + STEAM_PASS="" + STEAM_AUTH="" +else + echo -e "user set to ${STEAM_USER}" +fi + +## if auto_update is not set or to 1 update +if [ -z ${AUTO_UPDATE} ] || [ "${AUTO_UPDATE}" == "1" ]; then + # Update Source Server + if [ ! -z ${SRCDS_APPID} ]; then + ./steamcmd/steamcmd.sh +login ${STEAM_USER} ${STEAM_PASS} ${STEAM_AUTH} +force_install_dir /home/container +app_update ${SRCDS_APPID} $( [[ -z ${SRCDS_BETAID} ]] || printf %s "-beta ${SRCDS_BETAID}" ) $( [[ -z ${SRCDS_BETAPASS} ]] || printf %s "-betapassword ${SRCDS_BETAPASS}" ) $( [[ -z ${HLDS_GAME} ]] || printf %s "+app_set_config 90 mod ${HLDS_GAME}" ) $( [[ -z ${VALIDATE} ]] || printf %s "validate" ) +quit + else + echo -e "No appid set. Starting Server" + fi + +else + echo -e "Not updating game server as auto update was set to 0. Starting Server" +fi + # Display the command we're running in the output, and then execute it with the env # from the container itself. printf "\033[1m\033[33mcontainer@pterodactyl~ \033[0m%s\n" "$PARSED"