From ca1e4e1af68e9cc8f10edbfda623008e79c70a12 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Wed, 17 Feb 2016 23:08:37 +0000 Subject: [PATCH] check SteamCMD now using functions split this file in to smaller functions and improved the look for the installer --- functions/check_steamcmd.sh | 121 ++++++++++++++++++++++-------------- 1 file changed, 73 insertions(+), 48 deletions(-) diff --git a/functions/check_steamcmd.sh b/functions/check_steamcmd.sh index 7bb6d8140..cd8ab4f39 100644 --- a/functions/check_steamcmd.sh +++ b/functions/check_steamcmd.sh @@ -2,64 +2,89 @@ # LGSM check_steamcmd.sh function # Author: Daniel Gibbs # Website: http://gameservermanagers.com -lgsm_version="281215" +lgsm_version="160316" -# Description: Downloads SteamCMD on install and checks if missing before running functions that require SteamCMD +# Description: Checks SteamCMD is installed and correct. -if [ "${gamename}" == "Unreal Tournament 99" ]||[ "${gamename}" == "Unreal Tournament 2004" ]||[ "${gamename}" == "Mumble" ]||[ "${gamename}" == "Teamspeak 3" ]; then - : # These servers do not require SteamCMD. Check is skipped. +fn_install_steamcmd(){ +echo "Installing steamCMD" +if [ ! -d "${steamcmddir}" ]; then + mkdir -v "${steamcmddir}" +fi +curl=$(curl --fail -o "${steamcmddir}/steamcmd_linux.tar.gz" "http://media.steampowered.com/client/steamcmd_linux.tar.gz" 2>&1) +exitcode=$? +echo -e "downloading steamcmd_linux.tar.gz...\c" +if [ $exitcode -eq 0 ]; then + fn_printokeol else - # Checks steamuser is setup. - if [ "${steamuser}" == "username" ]; then + fn_printfaileol + echo "${curl}" + echo -e "${githuburl}\n" + exit $exitcode +fi +tar --verbose -zxf "${steamcmddir}/steamcmd_linux.tar.gz" -C "${steamcmddir}" +rm -v "${steamcmddir}/steamcmd_linux.tar.gz" +chmod +x "${steamcmddir}/steamcmd.sh" +echo "" +} + + +fn_check_steamcmd_user(){ +# Checks steamuser is setup. +if [ "${steamuser}" == "username" ]; then fn_printfailnl "Steam login not set. Update steamuser." echo " * Change steamuser=\"username\" to a valid steam login." - if [ -d ${scriptlogdir} ]; then + if [ -d "${scriptlogdir}" ]; then fn_scriptlog "edit ${selfname}. change steamuser=\"username\" to a valid steam login." exit 1 fi +fi +# Anonymous user is set if steamuser is missing +if [ -z "${steamuser}" ]; then + fn_printwarnnl "Steam login not set. Using anonymous login." + if [ -d "${scriptlogdir}" ]; then + fn_scriptlog "Steam login not set. Using anonymous login." fi - if [ -z "${steamuser}" ]; then - fn_printwarnnl "Steam login not set. Using anonymous login." - if [ -d "${scriptlogdir}" ]; then - fn_scriptlog "Steam login not set. Using anonymous login." - fi - steamuser="anonymous" - steampass="" - sleep 2 - fi - # Checks if SteamCMD exists when starting or updating a server. - # Re-installs if missing. - steamcmddir="${rootdir}/steamcmd" - if [ ! -f "${steamcmddir}/steamcmd.sh" ]; then + steamuser="anonymous" + steampass="" + sleep 2 +fi +} + +fn_check_steamcmd_sh(){ +# Checks if SteamCMD exists when starting or updating a server. +# Installs if missing. +steamcmddir="${rootdir}/steamcmd" +if [ ! -f "${steamcmddir}/steamcmd.sh" ]; then + if [ "${function_selfname}" == "command_install.sh" ]; then + fn_install_steamcmd + else fn_printwarnnl "SteamCMD is missing" - if [ -d "${scriptlogdir}" ]; then - fn_scriptlog "SteamCMD is missing" - fi + fn_scriptlog "SteamCMD is missing" sleep 1 - if [ ! -d "${steamcmddir}" ]; then - mkdir -v "${steamcmddir}" - fi - curl=$(curl --fail -o "${steamcmddir}/steamcmd_linux.tar.gz" "http://media.steampowered.com/client/steamcmd_linux.tar.gz" 2>&1) - exitcode=$? - echo -e "downloading steamcmd_linux.tar.gz...\c" - if [ $exitcode -eq 0 ]; then - fn_printokeol - else - fn_printfaileol - echo "${curl}" - echo -e "${githuburl}\n" - exit $exitcode - fi - tar --verbose -zxf "${steamcmddir}/steamcmd_linux.tar.gz" -C "${steamcmddir}" - rm -v "${steamcmddir}/steamcmd_linux.tar.gz" - chmod +x "${steamcmddir}/steamcmd.sh" - fi - if [ "${function_selfname}" == "command_update.sh" ]||[ "${function_selfname}" == "command_validate.sh" ]; then - # Checks that steamcmd is working correctly and will prompt Steam Guard if required. - "${steamcmddir}"/steamcmd.sh +login "${steamuser}" "${steampass}" +quit - if [ $? -ne 0 ]; then - fn_printfailurenl "Error running SteamCMD" - fi - fi + fn_install_steamcmd + fi +elif [ "${function_selfname}" == "command_install.sh" ]; then + fn_printinfomation "SteamCMD is already installed..." + fn_printokeol fi +} + +fn_check_steamcmd_guard(){ +if [ "${function_selfname}" == "command_update.sh" ]||[ "${function_selfname}" == "command_validate.sh" ]; then + # Checks that steamcmd is working correctly and will prompt Steam Guard if required. + "${steamcmddir}"/steamcmd.sh +login "${steamuser}" "${steampass}" +quit + if [ $? -ne 0 ]; then + fn_printfailurenl "Error running SteamCMD" + fi +fi +} + +if [ "${gamename}" == "Unreal Tournament 99" ]||[ "${gamename}" == "Unreal Tournament 2004" ]||[ "${gamename}" == "Mumble" ]||[ "${gamename}" == "Teamspeak 3" ]; then + : # These servers do not require SteamCMD. Check is skipped. +else + fn_check_steamcmd_user + fn_check_steamcmd_sh + fn_check_steamcmd_guard +fi \ No newline at end of file