From e9679d2bb5b5e7e8b92ae81ec869ad76a5423473 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Mon, 3 Dec 2018 22:57:19 +0000 Subject: [PATCH 1/7] docs(template): add "Basic info" section prompting user to add detail --- .github/ISSUE_TEMPLATE/bug_report.md | 14 ++++++++++++-- .github/ISSUE_TEMPLATE/feature_request.md | 6 ++++++ .github/ISSUE_TEMPLATE/new-server-request.md | 4 ++-- 3 files changed, 20 insertions(+), 4 deletions(-) diff --git a/.github/ISSUE_TEMPLATE/bug_report.md b/.github/ISSUE_TEMPLATE/bug_report.md index f69856e5f..e3a12cdb0 100644 --- a/.github/ISSUE_TEMPLATE/bug_report.md +++ b/.github/ISSUE_TEMPLATE/bug_report.md @@ -1,6 +1,7 @@ + --- name: Bug report -about: Create a report to help us improve +about: Found a bug? Raise a report --- @@ -8,18 +9,27 @@ Follow **[this guide](https://linuxgsm.com/support/#guide)** to make sure you po For general support visit the **[steam group](https://linuxgsm.com/steam)**. GitHub is **ONLY** for: +``` * LinuxGSM bugs * feature suggestions * code contributions +``` GitHub is **NOT** for: +``` * General support * Specific game server issues (e.g CS:GO, TF2) * Dedicated server issues (e.g Ubuntu, CentOS) * Anything not directly related to LinuxGSM development - +``` Any general support issues on GitHub will be closed. +*Please use the template below* + +**Basic info** +Game: +Distro: + **Describe the bug** A clear and concise description of what the bug is. diff --git a/.github/ISSUE_TEMPLATE/feature_request.md b/.github/ISSUE_TEMPLATE/feature_request.md index 6ba0c2bd2..9e6f49b49 100644 --- a/.github/ISSUE_TEMPLATE/feature_request.md +++ b/.github/ISSUE_TEMPLATE/feature_request.md @@ -20,6 +20,12 @@ GitHub is **NOT** for: Any general support issues on GitHub will be closed. +*Please use the template below* + +**Basic info** +Game: +Distro: + **Is your feature request related to a problem? Please describe.** A clear and concise description of what the problem is. Ex. I'm always frustrated when [...] diff --git a/.github/ISSUE_TEMPLATE/new-server-request.md b/.github/ISSUE_TEMPLATE/new-server-request.md index 6ce2f50d1..f7debe982 100644 --- a/.github/ISSUE_TEMPLATE/new-server-request.md +++ b/.github/ISSUE_TEMPLATE/new-server-request.md @@ -4,13 +4,13 @@ about: Suggest a new game server to be added --- -**What game server Would you like adding?** +**What game server would you like adding?** **Can you link to any tutorials or guides?** Any useful guides will help with development **Is the server on Steam?** -If yes Use SteamDB to get the appid. https://steamdb.info/ +If yes Use SteamDB to get the appid. https://steamdb.info **Is the server supported on Linux?** We only support Linux servers and dont support Wine. From cfbc46066795b5caca5b48685864a404ac394f63 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Tue, 4 Dec 2018 00:29:28 +0000 Subject: [PATCH 2/7] refactor: shortname variable change (#2088) * change `${gamename}` to `${shortname}` * apply shellcheck recommendations --- .github/ISSUE_TEMPLATE/bug_report.md | 2 +- .github/ISSUE_TEMPLATE/new-server-request.md | 4 +- lgsm/functions/check_config.sh | 4 +- lgsm/functions/check_deps.sh | 2 +- lgsm/functions/check_ip.sh | 2 +- lgsm/functions/check_logs.sh | 2 +- lgsm/functions/command_console.sh | 4 +- lgsm/functions/command_details.sh | 2 +- lgsm/functions/command_dev_clear_functions.sh | 4 +- lgsm/functions/command_dev_query_raw.sh | 2 +- lgsm/functions/command_fastdl.sh | 10 +-- lgsm/functions/command_install.sh | 12 ++-- lgsm/functions/command_monitor.sh | 8 +-- lgsm/functions/command_postdetails.sh | 2 +- lgsm/functions/command_start.sh | 2 +- lgsm/functions/command_stop.sh | 20 +++--- lgsm/functions/command_update.sh | 12 ++-- lgsm/functions/command_validate.sh | 8 --- lgsm/functions/command_wipe.sh | 4 +- lgsm/functions/core_getopt.sh | 20 +++--- lgsm/functions/fix.sh | 28 ++++---- lgsm/functions/fix_steamcmd.sh | 6 +- lgsm/functions/info_config.sh | 70 +++++++++---------- lgsm/functions/info_parms.sh | 22 +++--- lgsm/functions/mods_core.sh | 2 +- lgsm/functions/update_ts3.sh | 4 +- 26 files changed, 123 insertions(+), 135 deletions(-) diff --git a/.github/ISSUE_TEMPLATE/bug_report.md b/.github/ISSUE_TEMPLATE/bug_report.md index e3a12cdb0..72eb679f9 100644 --- a/.github/ISSUE_TEMPLATE/bug_report.md +++ b/.github/ISSUE_TEMPLATE/bug_report.md @@ -43,7 +43,7 @@ Steps to reproduce the behaviour: **Expected behaviour** A clear and concise description of what you expected to happen. -** Minimum Information ** +**Minimum Information** The game server you are running (e.g. Rust/CS:GO). The link from `./gameserver postdetails` command. diff --git a/.github/ISSUE_TEMPLATE/new-server-request.md b/.github/ISSUE_TEMPLATE/new-server-request.md index f7debe982..f528da120 100644 --- a/.github/ISSUE_TEMPLATE/new-server-request.md +++ b/.github/ISSUE_TEMPLATE/new-server-request.md @@ -10,7 +10,7 @@ about: Suggest a new game server to be added Any useful guides will help with development **Is the server on Steam?** -If yes Use SteamDB to get the appid. https://steamdb.info +If yes Use SteamDB to get the appid. (https://steamdb.info) **Is the server supported on Linux?** -We only support Linux servers and dont support Wine. +We only support Linux servers and do not support Wine. \ No newline at end of file diff --git a/lgsm/functions/check_config.sh b/lgsm/functions/check_config.sh index d7bc5ae92..dff515742 100644 --- a/lgsm/functions/check_config.sh +++ b/lgsm/functions/check_config.sh @@ -8,7 +8,7 @@ local commandname="CHECK" local function_selfname="$(basename "$(readlink -f "${BASH_SOURCE[0]}")")" if [ ! -e "${servercfgfullpath}" ]; then - if [ "${gamename}" != "Hurtworld" ]&&[ "${shortname}" != "ut3" ]&&[ "${shortname}" != "kf2" ]; then + if [ "${shortname}" != "hw" ]&&[ "${shortname}" != "ut3" ]&&[ "${shortname}" != "kf2" ]; then fn_print_dots "" sleep 0.5 fn_print_warn_nl "Configuration file missing!" @@ -20,7 +20,7 @@ if [ ! -e "${servercfgfullpath}" ]; then fi fi -if [ "${gamename}" == "Rust" ]; then +if [ "${shortname}" == "rust" ]; then if [ -z "${rconpassword}" ]; then fn_print_dots "" sleep 0.5 diff --git a/lgsm/functions/check_deps.sh b/lgsm/functions/check_deps.sh index 410483480..738e24f65 100644 --- a/lgsm/functions/check_deps.sh +++ b/lgsm/functions/check_deps.sh @@ -474,7 +474,7 @@ fn_deps_build_redhat(){ # Brainbread 2, Don't Starve Together & Team Fortress 2 elif [ "${shortname}" == "bb2" ]||[ "${shortname}" == "dst" ]||[ "${shortname}" == "tf2" ]; then array_deps_required+=( libcurl.i686 ) - if [ "${gamename}" == "Team Fortress 2" ]; then + if [ "${shortname}" == "tf2" ]; then array_deps_required+=( gperftools-libs.i686 ) fi # Battlefield: 1942 diff --git a/lgsm/functions/check_ip.sh b/lgsm/functions/check_ip.sh index 992fd0e93..ba0fd6ece 100644 --- a/lgsm/functions/check_ip.sh +++ b/lgsm/functions/check_ip.sh @@ -7,7 +7,7 @@ local commandname="CHECK" -if [ "${gamename}" != "TeamSpeak 3" ]&&[ "${gamename}" != "Mumble" ]&&[ "${travistest}" != "1" ]; then +if [ "${shortname}" != "ts3" ]&&[ "${shortname}" != "mumble" ]&&[ "${travistest}" != "1" ]; then if [ ! -f "/bin/ip" ]; then ipcommand="/sbin/ip" else diff --git a/lgsm/functions/check_logs.sh b/lgsm/functions/check_logs.sh index b842c0de6..717e53ada 100644 --- a/lgsm/functions/check_logs.sh +++ b/lgsm/functions/check_logs.sh @@ -16,7 +16,7 @@ fn_check_logs(){ } # Create directories for the script and console logs -if [ ! -d "${lgsmlogdir}" ]||[ ! -d "${consolelogdir}" ]&&[ "${gamename}" != "TeamSpeak 3" ]; then +if [ ! -d "${lgsmlogdir}" ]||[ ! -d "${consolelogdir}" ]&&[ "${shortname}" != "ts3" ]; then fn_check_logs fi diff --git a/lgsm/functions/command_console.sh b/lgsm/functions/command_console.sh index e7d9a6ac9..410548987 100644 --- a/lgsm/functions/command_console.sh +++ b/lgsm/functions/command_console.sh @@ -10,10 +10,8 @@ local function_selfname="$(basename "$(readlink -f "${BASH_SOURCE[0]}")")" check.sh fn_print_header -if [ "${gamename}" == "Rust" ]||[ "${gamename}" == "Hurtworld" ]||[ "${gamename}" == "ARK: Survival Evolved" ]; then +if [ "${shortname}" == "rust" ]||[ "${shortname}" == "hw" ]||[ "${shortname}" == "ark" ]; then fn_print_information_nl "${gamename} does not produce a verbose output to the console" -fi -if [ "${gamename}" == "Rust" ]||[ "${gamename}" == "Hurtworld" ]||[ "${gamename}" == "ARK: Survival Evolved" ]; then fn_print_information_nl "${gamename} does not allow server commands to be entered in to the console" fi fn_print_information_nl "Press \"CTRL+b\" then \"d\" to exit console." diff --git a/lgsm/functions/command_details.sh b/lgsm/functions/command_details.sh index 3474ae3ac..4b11d0658 100644 --- a/lgsm/functions/command_details.sh +++ b/lgsm/functions/command_details.sh @@ -24,7 +24,7 @@ fn_info_message_gameserver fn_info_message_script fn_info_message_backup # Some game servers do not have parms. -if [ "${gamename}" != "TeamSpeak 3" ]&&[ "${engine}" != "avalanche2.0" ]&&[ "${engine}" != "dontstarve" ]&&[ "${engine}" != "projectzomboid" ]&&[ "${engine}" != "renderware" ]; then +if [ "${shortname}" != "ts3" ]&&[ "${shortname}" != "jc2" ]&&[ "${shortname}" != "dst" ]&&[ "${shortname}" != "pz" ]&&[ "${engine}" != "renderware" ]; then fn_parms fn_info_message_commandlineparms fi diff --git a/lgsm/functions/command_dev_clear_functions.sh b/lgsm/functions/command_dev_clear_functions.sh index 40f781d72..bf026ced5 100644 --- a/lgsm/functions/command_dev_clear_functions.sh +++ b/lgsm/functions/command_dev_clear_functions.sh @@ -9,7 +9,7 @@ echo "Clear Functions" echo "=================================" echo "" if fn_prompt_yn "Do you want to delete all functions?" Y; then - rm -rfv "${functionsdir}"/* - rm -rfv "${configdirdefault}"/* + rm -rfv "${functionsdir:?}/"* + rm -rfv "${configdirdefault:?}/"* fi core_exit.sh \ No newline at end of file diff --git a/lgsm/functions/command_dev_query_raw.sh b/lgsm/functions/command_dev_query_raw.sh index c16d517aa..af0e7de6a 100644 --- a/lgsm/functions/command_dev_query_raw.sh +++ b/lgsm/functions/command_dev_query_raw.sh @@ -24,7 +24,7 @@ info_config.sh info_parms.sh if [ "${engine}" == "idtech3_ql" ]; then local engine="quakelive" -elif [ "${gamename}" == "Killing Floor 2" ]; then +elif [ "${shortname}" == "kf2" ]; then local engine="unreal4" fi diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 630778e59..7eed4813e 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -51,7 +51,7 @@ if [ -d "${fastdldir}" ]; then fi # Garry's Mod Specific -if [ "${gamename}" == "Garry's Mod" ]; then +if [ "${shortname}" == "gmod" ]; then # Prompt for download enforcer, which is using a .lua addfile resource generator if fn_prompt_yn "Force clients to download files?" Y; then luaresource="on" @@ -152,7 +152,7 @@ fn_fastdl_preview(){ echo -e "analysing required files" fn_script_log_info "Analysing required files" # Garry's Mod - if [ "${gamename}" == "Garry's Mod" ]; then + if [ "${shortname}" == "gmod" ]; then cd "${systemdir}" || exit allowed_extentions_array=( "*.ain" "*.bsp" "*.mdl" "*.mp3" "*.ogg" "*.otf" "*.pcf" "*.phy" "*.png" "*.vtf" "*.vmt" "*.vtx" "*.vvd" "*.ttf" "*.wav" ) for allowed_extention in "${allowed_extentions_array[@]}"; do @@ -207,7 +207,7 @@ fn_fastdl_preview(){ sleep 0.5 totalfiles=$(wc -l < "${tmpdir}/fastdl_files_to_compress.txt") # Calculates total file size - while read dufile; do + while read -r dufile; do filesize=$(stat -c %s "${dufile}") filesizetotal=$(( ${filesizetotal} + ${filesize} )) exitcode=$? @@ -358,7 +358,7 @@ fn_fastdl_build(){ # Copy all needed files for FastDL echo -e "copying files to ${fastdldir}" fn_script_log_info "Copying files to ${fastdldir}" - if [ "${gamename}" == "Garry's Mod" ]; then + if [ "${shortname}" == "gmod" ]; then fn_fastdl_gmod fn_fastdl_gmod_dl_enforcer else @@ -387,7 +387,7 @@ fn_fastdl_gmod_dl_enforcer(){ echo -en "creating new download enforcer: ${luafastdlfile}..." touch "${luafastdlfullpath}" # Read all filenames and put them into a lua file at the right path - while read line; do + while read -r line; do echo "resource.AddFile( \"${line}\" )" >> "${luafastdlfullpath}" done < <(find "${fastdldir:?}" \( -type f ! -name "*.bz2" \) -printf '%P\n') exitcode=$? diff --git a/lgsm/functions/command_install.sh b/lgsm/functions/command_install.sh index ba4059649..78b0e5441 100644 --- a/lgsm/functions/command_install.sh +++ b/lgsm/functions/command_install.sh @@ -19,7 +19,7 @@ else check_deps.sh installflag=1 # Download and install - if [ "${gamename}" == "Unreal Tournament 2004" ]; then + if [ "${shortname}" == "ut2k4" ]; then install_server_files.sh install_ut2k4_key.sh elif [ -z "${appid}" ]; then @@ -32,15 +32,15 @@ else # Configuration install_config.sh - if [ "${gamename}" == "BrainBread 2" ]||[ "${gamename}" == "Black Mesa: Deathmatch" ]||[ "${gamename}" == "Counter-Strike: Global Offensive" ]||[ "${gamename}" == "Empires Mod" ]||[ "${gamename}" == "Garry’s Mod" ]||[ "${gamename}" == "No more Room in Hell" ]||[ "${gamename}" == "Team Fortress 2" ]||[ "${gamename}" == "Tower Unite" ]; then + if [ "${shortname}" == "bb2" ]||[ "${shortname}" == "bmdm" ]||[ "${shortname}" == "csgo" ]||[ "${shortname}" == "em" ]||[ "${shortname}" == "gmod" ]||[ "${shortname}" == "nmrih" ]||[ "${shortname}" == "tf2" ]||[ "${shortname}" == "tu" ]; then install_gslt.sh - elif [ "${gamename}" == "Don't Starve Together" ]; then + elif [ "${shortname}" == "dst" ]; then install_dst_token.sh - elif [ "${gamename}" == "Squad" ]; then + elif [ "${shortname}" == "squad" ]; then install_squad_license.sh - elif [ "${gamename}" == "TeamSpeak 3" ]; then + elif [ "${shortname}" == "ts3" ]; then install_ts3db.sh - elif [ "${gamename}" == "Multi Theft Auto" ]; then + elif [ "${shortname}" == "mta" ]; then command_install_resources_mta.sh fi diff --git a/lgsm/functions/command_monitor.sh b/lgsm/functions/command_monitor.sh index c4b9f9a42..2a291cd15 100644 --- a/lgsm/functions/command_monitor.sh +++ b/lgsm/functions/command_monitor.sh @@ -110,9 +110,9 @@ fn_monitor_check_session(){ fn_print_ok_eol_nl fn_script_log_pass "Checking session: OK" else - if [ "${gamename}" == "TeamSpeak 3" ]; then + if [ "${shortname}" == "ts3" ]; then fn_print_error "Checking session: ${ts3error}: " - elif [ "${gamename}" == "Mumble" ]; then + elif [ "${shortname}" == "mumble" ]; then fn_print_error "Checking session: Not listening to port ${queryport}" else fn_print_error "Checking session: " @@ -137,7 +137,7 @@ fn_monitor_query(){ if [ "${allowed_engine}" == "${engine}" ]; then if [ "${engine}" == "idtech3_ql" ]; then local engine="quakelive" - elif [ "${gamename}" == "Killing Floor 2" ]; then + elif [ "${shortname}" == "kf2" ]; then local engine="unreal4" fi @@ -186,7 +186,7 @@ fn_monitor_check_lockfile fn_monitor_check_update fn_monitor_check_session # Query has to be enabled in Starbound config -if [ "${gamename}" == "Starbound" ]; then +if [ "${shortname}" == "sb" ]; then if [ "${queryenabled}" == "true" ]; then fn_monitor_query fi diff --git a/lgsm/functions/command_postdetails.sh b/lgsm/functions/command_postdetails.sh index 1c47f0a64..a4a0b96c4 100644 --- a/lgsm/functions/command_postdetails.sh +++ b/lgsm/functions/command_postdetails.sh @@ -68,7 +68,7 @@ else fn_info_message_script fn_info_message_backup # Some game servers do not have parms. - if [ "${gamename}" != "TeamSpeak 3" ]&&[ "${engine}" != "avalanche2.0" ]&&[ "${engine}" != "avalanche3.0" ]&&[ "${engine}" != "dontstarve" ]&&[ "${engine}" != "projectzomboid" ]&&[ "${engine}" != "renderware" ]; then + if [ "${shortname}" != "ts3" ]&&[ "${shortname}" != "jc2" ]&&[ "${shortname}" != "jc3" ]&&[ "${shortname}" != "dst" ]&&[ "${shortname}" != "pz" ]&&[ "${engine}" != "renderware" ]; then fn_parms fn_info_message_commandlineparms fi diff --git a/lgsm/functions/command_start.sh b/lgsm/functions/command_start.sh index 30c425c51..77c25ee8f 100644 --- a/lgsm/functions/command_start.sh +++ b/lgsm/functions/command_start.sh @@ -214,7 +214,7 @@ if [ "${updateonstart}" == "yes" ]||[ "${updateonstart}" == "1" ]||[ "${updateon command_update.sh fi -if [ "${gamename}" == "TeamSpeak 3" ]; then +if [ "${shortname}" == "ts3" ]; then fn_start_teamspeak3 else fn_start_tmux diff --git a/lgsm/functions/command_stop.sh b/lgsm/functions/command_stop.sh index 72641d2d2..f9042a4a5 100644 --- a/lgsm/functions/command_stop.sh +++ b/lgsm/functions/command_stop.sh @@ -174,22 +174,22 @@ fn_stop_graceful_sdtd(){ } fn_stop_graceful_select(){ - if [ "${gamename}" == "7 Days To Die" ]; then + if [ "${shortname}" == "sdtd" ]; then fn_stop_graceful_sdtd elif [ "${engine}" == "Spark" ]; then fn_stop_graceful_cmd "q" 30 - elif [ "${gamename}" == "Terraria" ]; then + elif [ "${shortname}" == "terraria" ]; then fn_stop_graceful_cmd "exit" 30 - elif [ "${gamename}" == "Minecraft" ]; then + elif [ "${shortname}" == "mc" ]; then fn_stop_graceful_cmd "stop" 30 - elif [ "${gamename}" == "Multi Theft Auto" ]; then + elif [ "${shortname}" == "mta" ]; then # we need a long wait time here as resources are stopped individually and process their own shutdowns fn_stop_graceful_cmd "quit" 120 elif [ "${engine}" == "goldsource" ]; then fn_stop_graceful_goldsource - elif [ "${engine}" == "avalanche2.0" ]||[ "${engine}" == "avalanche3.0" ]||[ "${gamename}" == "Factorio" ]||[ "${engine}" == "unity3d" ]||[ "${engine}" == "unreal4" ]||[ "${engine}" == "unreal3" ]||[ "${engine}" == "unreal2" ]||[ "${engine}" == "unreal" ]||[ "${gamename}" == "Mumble" ]||[ "${shortname}" == "wurm" ]; then + elif [ "${engine}" == "unity3d" ]||[ "${engine}" == "unreal4" ]||[ "${engine}" == "unreal3" ]||[ "${engine}" == "unreal2" ]||[ "${engine}" == "unreal" ]||[ "${shortname}" == "fctr" ]||[ "${shortname}" == "mumble" ]||[ "${shortname}" == "wurm" ]||[ "${shortname}" == "jc2" ]||[ "${shortname}" == "jc3" ]; then fn_stop_graceful_ctrlc - elif [ "${engine}" == "source" ]||[ "${engine}" == "quake" ]||[ "${engine}" == "idtech2" ]||[ "${engine}" == "idtech3" ]||[ "${engine}" == "idtech3_ql" ]||[ "${engine}" == "Just Cause 2" ]||[ "${engine}" == "projectzomboid" ]||[ "${shortname}" == "rw" ]; then + elif [ "${engine}" == "source" ]||[ "${engine}" == "quake" ]||[ "${engine}" == "idtech2" ]||[ "${engine}" == "idtech3" ]||[ "${engine}" == "idtech3_ql" ]||[ "${shortname}" == "jc2" ]||[ "${shortname}" == "pz" ]||[ "${shortname}" == "rw" ]; then fn_stop_graceful_cmd "quit" 30 fi } @@ -212,9 +212,7 @@ fn_stop_ark(){ if [ "${#queryport}" -gt 0 ] ; then for (( pidcheck=0 ; pidcheck < ${maxpiditer} ; pidcheck++ )) ; do - pid=$(netstat -nap 2>/dev/null | grep "^udp[[:space:]]" |\ - grep ":${queryport}[[:space:]]" | rev | awk '{print $1}' |\ - rev | cut -d\/ -f1) + pid=$(netstat -nap 2>/dev/null | grep "^udp[[:space:]]" | grep ":${queryport}[[:space:]]" | rev | awk '{print $1}' | rev | cut -d\/ -f1) # # check for a valid pid pid=${pid//[!0-9]/} @@ -263,7 +261,7 @@ fn_stop_tmux(){ if [ "${status}" == "0" ]; then # ARK doesn't clean up immediately after tmux is killed. # Make certain the ports are cleared before continuing. - if [ "${gamename}" == "ARK: Survival Evolved" ]; then + if [ "${shortname}" == "ark" ]; then fn_stop_ark fi fn_print_ok_nl "${servername}" @@ -280,7 +278,7 @@ fn_stop_pre_check(){ if [ "${status}" == "0" ]; then # $status comes from check_status.sh, which is run by check.sh for this command fn_print_info_nl "${servername} is already stopped" fn_script_log_error "${servername} is already stopped" - elif [ "${gamename}" == "TeamSpeak 3" ]; then + elif [ "${shortname}" == "ts3" ]; then fn_stop_teamspeak3 else fn_stop_graceful_select diff --git a/lgsm/functions/command_update.sh b/lgsm/functions/command_update.sh index de180118a..9c366ae61 100644 --- a/lgsm/functions/command_update.sh +++ b/lgsm/functions/command_update.sh @@ -9,19 +9,19 @@ local commandaction="Update" local function_selfname="$(basename "$(readlink -f "${BASH_SOURCE[0]}")")" fn_print_dots "" -sleep 0.5 +sleep 0.2 check.sh logs.sh -if [ "${gamename}" == "TeamSpeak 3" ]; then +if [ "${shortname}" == "ts3" ]; then update_ts3.sh -elif [ "${engine}" == "lwjgl2" ]; then +elif [ "${shortname}" == "mc" ]; then update_minecraft.sh -elif [ "${gamename}" == "Mumble" ]; then +elif [ "${shortname}" == "mumble" ]; then update_mumble.sh -elif [ "${gamename}" == "Factorio" ]; then +elif [ "${shortname}" == "fctr" ]; then update_factorio.sh -elif [ "${gamename}" == "Multi Theft Auto" ]; then +elif [ "${shortname}" == "mta" ]; then update_mta.sh else update_steamcmd.sh diff --git a/lgsm/functions/command_validate.sh b/lgsm/functions/command_validate.sh index a93d59d66..2e9dab18b 100644 --- a/lgsm/functions/command_validate.sh +++ b/lgsm/functions/command_validate.sh @@ -51,17 +51,9 @@ if [ "${status}" != "0" ]; then exitbypass=1 command_stop.sh fn_validation "${appid}" - # will also check for second appid - if [ "${gamename}" == "Classic Offensive" ]; then - fn_validation "${appid_co}" - fi exitbypass=1 command_start.sh else fn_validation - # will also check for second appid - if [ "${gamename}" == "Classic Offensive" ]; then - fn_validation "${appid_co}" - fi fi core_exit.sh diff --git a/lgsm/functions/command_wipe.sh b/lgsm/functions/command_wipe.sh index 69d0140f3..b476f4da3 100644 --- a/lgsm/functions/command_wipe.sh +++ b/lgsm/functions/command_wipe.sh @@ -43,7 +43,7 @@ fn_wipe_exit_code(){ # Removes files to wipe server fn_wipe_server_remove_files(){ # Rust Wipe - if [ "${gamename}" == "Rust" ]; then + if [ "${shortname}" == "rust" ]; then # Wipe pocedural map if [ -n "$(find "${serveridentitydir}" -type f -name "proceduralmap.*.map")" ]; then currentaction="Removing map file(s): ${serveridentitydir}/proceduralmap.*.map" @@ -188,7 +188,7 @@ fn_wipe_server_remove_files(){ # Check if there is something to wipe, prompt the user, and call appropriate functions # Rust Wipe -if [ "${gamename}" == "Rust" ]; then +if [ "${shortname}" == "rust" ]; then if [ -d "${serveridentitydir}/storage" ]||[ -d "${serveridentitydir}/user" ]||[ -n "$(find "${serveridentitydir}" -type f -name "proceduralmap*.sav")" ]||[ -n "$(find "${serveridentitydir}" -type f -name "barren*.sav")" ]||[ -n "$(find "${serveridentitydir}" -type f -name "Log.*.txt")" ]||[ -n "$(find "${serveridentitydir}" -type f -name "player.deaths.*.db")" ]||[ -n "$(find "${serveridentitydir}" -type f -name "player.blueprints.*.db")" ]||[ -n "$(find "${serveridentitydir}" -type f -name "sv.files.*.db")" ]; then fn_print_warning_nl "Any user, storage, log and map data from ${serveridentitydir} will be erased." if ! fn_prompt_yn "Continue?" Y; then diff --git a/lgsm/functions/core_getopt.sh b/lgsm/functions/core_getopt.sh index 4766fabe9..7be0f8d66 100644 --- a/lgsm/functions/core_getopt.sh +++ b/lgsm/functions/core_getopt.sh @@ -61,10 +61,10 @@ currentopt=( "${cmd_start[@]}" "${cmd_stop[@]}" "${cmd_restart[@]}" "${cmd_monit currentopt+=( "${cmd_update_linuxgsm[@]}" ) # Exclude noupdate games here -if [ "${gamename}" != "Battlefield: 1942" ]&&[ "${engine}" != "quake" ]&&[ "${engine}" != "idtech2" ]&&[ "${engine}" != "idtech3" ]&&[ "${engine}" != "iw2.0" ]&&[ "${engine}" != "iw3.0" ]&&[ "${gamename}" != "San Andreas Multiplayer" ]; then +if [ "${engine}" != "quake" ]&&[ "${engine}" != "idtech2" ]&&[ "${engine}" != "idtech3" ]&&[ "${engine}" != "iw2.0" ]&&[ "${engine}" != "iw3.0" ]&&[ "${shortname}" != "bf1942" ]&&[ "${shortname}" != "samp" ]; then currentopt+=( "${cmd_update[@]}" ) # force update for SteamCMD only or MTA - if [ -n "${appid}" ]||[ "${gamename}" == "Multi Theft Auto" ]; then + if [ -n "${appid}" ]||[ "${shortname}" == "mta" ]; then currentopt+=( "${cmd_force_update[@]}" ) fi fi @@ -78,7 +78,7 @@ fi currentopt+=( "${cmd_backup[@]}" ) # Exclude games without a console -if [ "${gamename}" != "TeamSpeak 3" ]; then +if [ "${shortname}" != "ts3" ]; then currentopt+=( "${cmd_console[@]}" "${cmd_debug[@]}" ) fi @@ -90,16 +90,16 @@ if [ "${engine}" == "source" ]; then fi # TeamSpeak exclusive -if [ "${gamename}" == "TeamSpeak 3" ]; then +if [ "${shortname}" != "ts3" ]; then currentopt+=( "${cmd_change_password[@]}" ) fi # Unreal exclusive -if [ "${gamename}" == "Rust" ]; then +if [ "${shortname}" == "rust" ]; then currentopt+=( "${cmd_wipe[@]}" "${cmd_wipeall[@]}" ) fi if [ "${engine}" == "unreal2" ]; then - if [ "${gamename}" == "Unreal Tournament 2004" ]; then + if [ "${shortname}" == "ut2k4" ]; then currentopt+=( "${cmd_install_cdkey[@]}" "${cmd_map_compressor_u2[@]}" ) else currentopt+=( "${cmd_map_compressor_u2[@]}" ) @@ -110,22 +110,22 @@ if [ "${engine}" == "unreal" ]; then fi # DST exclusive -if [ "${gamename}" == "Don't Starve Together" ]; then +if [ "${shortname}" == "dst" ]; then currentopt+=( "${cmd_install_dst_token[@]}" ) fi # MTA exclusive -if [ "${gamename}" == "Multi Theft Auto" ]; then +if [ "${shortname}" == "mta" ]; then currentopt+=( "${cmd_install_default_resources[@]}" ) fi # Squad license exclusive -if [ "${gamename}" == "Squad" ]; then +if [ "${shortname}" == "squad" ]; then currentopt+=( "${cmd_install_squad_license[@]}" ) fi ## Mods commands -if [ "${engine}" == "source" ]||[ "${gamename}" == "Rust" ]||[ "${gamename}" == "Hurtworld" ]||[ "${gamename}" == "7 Days To Die" ]; then +if [ "${engine}" == "source" ]||[ "${shortname}" == "rust" ]||[ "${shortname}" == "hq" ]||[ "${shortname}" == "sdtd" ]; then currentopt+=( "${cmd_mods_install[@]}" "${cmd_mods_remove[@]}" "${cmd_mods_update[@]}" ) fi diff --git a/lgsm/functions/fix.sh b/lgsm/functions/fix.sh index 0653dcaad..dfa9fde78 100644 --- a/lgsm/functions/fix.sh +++ b/lgsm/functions/fix.sh @@ -42,25 +42,25 @@ if [ "${function_selfname}" != "command_install.sh" ]&&[ -z "${fixbypass}" ]; th fix_steamcmd.sh fi - if [ "${gamename}" == "ARMA 3" ]; then + if [ "${shortname}" == "arma3" ]; then fix_arma3.sh elif [ "${shortname}" == "ark" ]; then fix_ark.sh - elif [ "${gamename}" == "Counter-Strike: Global Offensive" ]; then + elif [ "${shortname}" == "csgo" ]; then fix_csgo.sh - elif [ "${gamename}" == "Don't Starve Together" ]; then + elif [ "${shortname}" == "dst" ]; then fix_dst.sh - elif [ "${gamename}" == "GoldenEye: Source" ]; then + elif [ "${shortname}" == "ges" ]; then fix_ges.sh - elif [ "${gamename}" == "Insurgency" ]; then + elif [ "${shortname}" == "ins" ]; then fix_ins.sh - elif [ "${gamename}" == "Rust" ]; then + elif [ "${shortname}" == "rust" ]; then fix_rust.sh elif [ "${shortname}" == "rw" ]; then fix_rw.sh elif [ "${shortname}" == "ss3" ]; then fix_ss3.sh - elif [ "${gamename}" == "Multi Theft Auto" ]; then + elif [ "${shortname}" == "mta" ]; then fix_mta.sh elif [ "${shortname}" == "wurm" ]; then fix_wurm.sh @@ -73,19 +73,19 @@ if [ "${function_selfname}" == "command_install.sh" ]; then echo "Applying Post-Install Fixes" echo "=================================" sleep 0.5 - if [ "${gamename}" == "Killing Floor" ]; then + if [ "${shortname}" == "kf" ]; then fix_kf.sh - elif [ "${gamename}" == "Killing Floor 2" ]; then + elif [ "${shortname}" == "kf2" ]; then fix_kf2.sh - elif [ "${gamename}" == "Red Orchestra: Ostfront 41-45" ]; then + elif [ "${shortname}" == "ro" ]; then fix_ro.sh - elif [ "${gamename}" == "Unreal Tournament 2004" ]; then + elif [ "${shortname}" == "ut2k4" ]; then fix_ut2k4.sh - elif [ "${gamename}" == "Unreal Tournament" ]; then + elif [ "${shortname}" == "ut" ]; then fix_ut.sh - elif [ "${gamename}" == "Unreal Tournament 3" ]; then + elif [ "${shortname}" == "ut3" ]; then fix_ut3.sh - elif [ "${gamename}" == "Team Fortress 2" ]; then + elif [ "${shortname}" == "tf2" ]; then fix_tf2.sh else fn_print_information_nl "No fixes required." diff --git a/lgsm/functions/fix_steamcmd.sh b/lgsm/functions/fix_steamcmd.sh index 3a63b1505..9802c702f 100644 --- a/lgsm/functions/fix_steamcmd.sh +++ b/lgsm/functions/fix_steamcmd.sh @@ -17,7 +17,7 @@ if [ ! -f "${HOME}/.steam/sdk32/steamclient.so" ]; then fn_fix_msg_end fi -if [ "${gamename}" == "Serious Sam 3: BFE" ]; then +if [ "${shortname}" == "ss3" ]; then # Fixes: .steam/bin32/libsteam.so: cannot open shared object file: No such file or directory if [ ! -f "${HOME}/.steam/bin32/libsteam.so" ]; then fixname="libsteam.so" @@ -26,7 +26,7 @@ if [ "${gamename}" == "Serious Sam 3: BFE" ]; then cp -v "${serverfiles}/Bin/libsteam.so" "${HOME}/.steam/bin32/libsteam.so" >> "${lgsmlog}" fn_fix_msg_end fi -elif [ "${gamename}" == "Hurtworld" ]; then +elif [ "${shortname}" == "hw" ]; then # Fixes: [S_API FAIL] SteamAPI_Init() failed; unable to locate a running instance of Steam, or a local steamclient.so. if [ ! -f "${serverfiles}/Hurtworld_Data/Plugins/x86/steamclient.so" ]; then fixname="steamclient.so x86" @@ -40,7 +40,7 @@ elif [ "${gamename}" == "Hurtworld" ]; then cp -v "${steamcmddir}/linux32/steamclient.so" "${serverfiles}/Hurtworld_Data/Plugins/x86_64/steamclient.so" >> "${lgsmlog}" fn_fix_msg_end fi -elif [ "${gamename}" == "Tower Unite" ]; then +elif [ "${shortname}" == "tu" ]; then # Fixes: [S_API FAIL] SteamAPI_Init() failed; unable to locate a running instance of Steam, or a local steamclient.so. if [ ! -f "${executabledir}/steamclient.so" ]; then fixname="steamclient.so" diff --git a/lgsm/functions/info_config.sh b/lgsm/functions/info_config.sh index 632dc44ea..93912c529 100644 --- a/lgsm/functions/info_config.sh +++ b/lgsm/functions/info_config.sh @@ -1112,106 +1112,106 @@ fn_info_config_stationeers(){ } # ARK: Survival Evolved -if [ "${gamename}" == "ARK: Survivial Evolved" ]; then +if [ "${shortname}" == "ark" ]; then fn_info_config_ark # Ballistic Overkill -elif [ "${gamename}" == "Ballistic Overkill" ]; then +elif [ "${shortname}" == "bo" ]; then fn_info_config_ballistic_overkill # Battalion 1944 -elif [ "${gamename}" == "Battalion 1944" ]; then +elif [ "${shortname}" == "bt1944" ]; then fn_info_config_battalion1944 # Battlefield: 1942 -elif [ "${gamename}" == "Battlefield: 1942" ]; then +elif [ "${shortname}" == "bf1942" ]; then fn_info_config_bf1942 # Call of Duty -elif [ "${gamename}" == "Call of Duty" ]||[ "${gamename}" == "Call of Duty: United Offensive" ]; then +elif [ "${shortname}" == "cod" ]||[ "${shortname}" == "coduo" ]; then fn_info_config_cod # Call of Duty 2 -elif [ "${gamename}" == "Call of Duty 2" ]; then +elif [ "${shortname}" == "cod2" ]; then fn_info_config_cod2 # Call of Duty 4 -elif [ "${gamename}" == "Call of Duty 4" ]; then +elif [ "${shortname}" == "cod4" ]; then fn_info_config_cod4 # Call of Duty: World at War -elif [ "${gamename}" == "Call of Duty: World at War" ]; then +elif [ "${shortname}" == "codwaw" ]; then fn_info_config_codwaw # Dont Starve Together -elif [ "${engine}" == "dontstarve" ]; then +elif [ "${shortname}" == "dst" ]; then fn_info_config_dontstarve # Eco elif [ "${shortname}" == "eco" ]; then fn_info_config_eco # Factorio -elif [ "${gamename}" == "Factorio" ]; then +elif [ "${shortname}" == "fctr" ]; then fn_info_config_factorio # Insurgency: Sandstorm elif [ "${shortname}" == "inss" ]; then fn_info_config_inss # Just Cause 2 -elif [ "${gamename}" == "Just Cause 2" ]; then +elif [ "${shortname}" == "jc2" ]; then fn_info_config_justcause2 # Just Cause 3 -elif [ "${gamename}" == "Just Cause 3" ]; then +elif [ "${shortname}" == "jc3" ]; then fn_info_config_justcause3 # Killing Floor 2 elif [ "${shortname}" == "kf2" ]; then fn_info_config_kf2 # QuakeWorld -elif [ "${gamename}" == "QuakeWorld" ]; then +elif [ "${shortname}" == "qw" ]; then fn_info_config_quakeworld # Quake 2 -elif [ "${gamename}" == "Quake 2" ]; then +elif [ "${shortname}" == "q2" ]; then fn_info_config_quake2 # Quake 3 -elif [ "${gamename}" == "Quake 3: Arena" ]; then +elif [ "${shortname}" == "q3" ]; then fn_info_config_quake3 # Quake Live -elif [ "${gamename}" == "Quake Live" ]; then +elif [ "${shortname}" == "ql" ]; then fn_info_config_quakelive # Minecraft -elif [ "${engine}" == "lwjgl2" ]; then +elif [ "${shortname}" == "mc" ]; then fn_info_config_minecraft # Post Scriptum: The Bloody Seventh elif [ "${shortname}" == "pstbs" ]; then fn_info_config_pstbs # Project Cars -elif [ "${gamename}" == "Project Cars" ]; then +elif [ "${shortname}" == "pc" ]; then fn_info_config_projectcars # Project Zomboid -elif [ "${engine}" == "projectzomboid" ]; then +elif [ "${shortname}" == "pz" ]; then fn_info_config_projectzomboid # ARMA 3 -elif [ "${engine}" == "realvirtuality" ]; then +elif [ "${shortname}" == "arma3" ]; then fn_info_config_realvirtuality # Rising World elif [ "${shortname}" == "rw" ]; then fn_info_config_risingworld # Serious Sam -elif [ "${engine}" == "seriousengine35" ]; then +elif [ "${shortname}" == "ss3" ]; then fn_info_config_seriousengine35 # Source Engine Games elif [ "${engine}" == "source" ]||[ "${engine}" == "goldsource" ]; then fn_info_config_source # Starbound -elif [ "${engine}" == "starbound" ]; then +elif [ "${shortname}" == "sb" ]; then fn_info_config_starbound # TeamSpeak 3 -elif [ "${gamename}" == "TeamSpeak 3" ]; then +elif [ "${shortname}" == "ts3" ]; then fn_info_config_teamspeak3 # Mumble -elif [ "${gamename}" == "Mumble" ]; then +elif [ "${shortname}" == "mumble" ]; then fn_info_config_mumble # San Andreas Multiplayer -elif [ "${gamename}" == "San Andreas Multiplayer" ]; then +elif [ "${shortname}" == "samp" ]; then fn_info_config_samp # Teeworlds -elif [ "${engine}" == "teeworlds" ]; then +elif [ "${shortname}" == "tw" ]; then fn_info_config_teeworlds # Terraria -elif [ "${engine}" == "terraria" ]; then +elif [ "${shortname}" == "terraria" ]; then fn_info_config_terraria # Tower Unite -elif [ "${gamename}" == "Tower Unite" ]; then +elif [ "${shortname}" == "tu" ]; then fn_info_config_towerunite # Unreal/Unreal 2 engine elif [ "${engine}" == "unreal" ]||[ "${engine}" == "unreal2" ]; then @@ -1220,19 +1220,19 @@ elif [ "${engine}" == "unreal" ]||[ "${engine}" == "unreal2" ]; then elif [ "${engine}" == "unreal3" ]; then fn_info_config_unreal3 # 7 Day To Die (unity3d) -elif [ "${gamename}" == "7 Days To Die" ]; then +elif [ "${shortname}" == "sdtd" ]; then fn_info_config_sdtd -elif [ "${gamename}" == "Wolfenstein: Enemy Territory" ]; then +elif [ "${shortname}" == "wet" ]; then fn_info_config_wolfensteinenemyterritory -elif [ "${gamename}" == "ET: Legacy" ]; then +elif [ "${shortname}" == "etl" ]; then fn_info_config_etlegacy -elif [ "${gamename}" == "Wurm Unlimited" ]; then +elif [ "${shortname}" == "wurm" ]; then fn_info_config_wurmunlimited -elif [ "${gamename}" == "Multi Theft Auto" ]; then +elif [ "${shortname}" == "mta" ]; then fn_info_config_mta -elif [ "${gamename}" == "Squad" ]; then +elif [ "${shortname}" == "squad" ]; then fn_info_config_squad # Stationeers -elif [ "${gamename}" == "Stationeers" ]; then +elif [ "${shortname}" == "st" ]; then fn_info_config_stationeers fi \ No newline at end of file diff --git a/lgsm/functions/info_parms.sh b/lgsm/functions/info_parms.sh index 2345f5864..ced392bc6 100644 --- a/lgsm/functions/info_parms.sh +++ b/lgsm/functions/info_parms.sh @@ -154,46 +154,46 @@ fn_info_parms_kf2(){ } # ARK: Survival Evolved -if [ "${gamename}" == "ARK: Survival Evolved" ]; then +if [ "${shortname}" == "ark" ]; then fn_info_parms_ark # ARMA 3 -elif [ "${engine}" == "realvirtuality" ]; then +elif [ "${shortname}" == "arma3" ]; then fn_info_parms_realvirtuality # Call of Duty -elif [ "${gamename}" == "Call of Duty" ]||[ "${gamename}" == "Call of Duty: United Offensive" ]||[ "${engine}" == "iw2.0" ]||[ "${engine}" == "iw3.0" ]; then +elif [ "${shortname}" == "cod" ]||[ "${shortname}" == "coduo" ]||[ "${engine}" == "iw2.0" ]||[ "${engine}" == "iw3.0" ]; then fn_info_parms_cod # Eco -elif [ "${gamename}" == "Eco" ]; then +elif [ "${shortname}" == "eco" ]; then fn_info_parms_eco # Factorio -elif [ "${gamename}" == "Factorio" ]; then +elif [ "${shortname}" == "fctr" ]; then fn_info_parms_factorio elif [ "${shortname}" == "inss" ]; then fn_info_parms_inss elif [ "${shortname}" == "kf2" ]; then fn_info_parms_kf2 # Project Zomboid -elif [ "${engine}" == "projectzomboid" ]; then +elif [ "${shortname}" == "pz" ]; then fn_info_parms_projectzomboid -elif [ "${gamename}" == "QuakeWorld" ]; then +elif [ "${shortname}" == "qw" ]; then fn_info_parms_quakeworld -elif [ "${gamename}" == "Quake 2" ]||[ "${gamename}" == "Quake 3: Arena" ]; then +elif [ "${shortname}" == "q2" ]||[ "${shortname}" == "q3" ]; then fn_info_parms_quake2 # Rust -elif [ "${gamename}" == "Rust" ]; then +elif [ "${shortname}" == "rust" ]; then fn_info_parms_rust # Rising World elif [ "${shortname}" == "rw" ]; then fn_info_parms_risingworld # Serious Sam -elif [ "${engine}" == "seriousengine35" ]; then +elif [ "${shortname}" == "ss3" ]; then fn_info_config_seriousengine35 elif [ "${engine}" == "source" ]||[ "${engine}" == "goldsource" ]; then fn_info_parms_source # Spark elif [ "${engine}" == "spark" ]; then fn_info_parms_spark -elif [ "${gamename}" == "Tower Unite" ]; then +elif [ "${shortname}" == "tu" ]; then fn_info_config_towerunite # Unreal/Unreal 2 engine elif [ "${engine}" == "unreal" ]||[ "${engine}" == "unreal2" ]; then diff --git a/lgsm/functions/mods_core.sh b/lgsm/functions/mods_core.sh index 5fd39970f..8690b3b19 100644 --- a/lgsm/functions/mods_core.sh +++ b/lgsm/functions/mods_core.sh @@ -43,7 +43,7 @@ fn_mod_lowercase(){ fileswc=$(find "${extractdir}" -depth | wc -l) echo -en "\r" while read -r src; do - dst=$(dirname "${src}"`/`basename "${src}" | tr '[A-Z]' '[a-z]') + dst=$(dirname "${src}"$(/)basename "${src}" | tr 'A-Z' 'a-z') if [ "${src}" != "${dst}" ] then [ ! -e "${dst}" ] && mv -T "${src}" "${dst}" || echo "${src} was not renamed" diff --git a/lgsm/functions/update_ts3.sh b/lgsm/functions/update_ts3.sh index 44f463a61..5ff6d33f8 100644 --- a/lgsm/functions/update_ts3.sh +++ b/lgsm/functions/update_ts3.sh @@ -63,7 +63,7 @@ fn_update_ts3_currentbuild(){ fi # Get current build from logs - currentbuild=$(cat $(find ./* -name 'ts3server*_0.log' 2> /dev/null | sort | grep -Ev '${rootdir}/.ts3version' | tail -1) | grep -Eo 'TeamSpeak 3 Server ((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}' | grep -Eo '((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}' | sort -V | tail -1) + currentbuild=$(cat $(find ./* -name "ts3server*_0.log" 2> /dev/null | sort | grep -Ev "${rootdir}/.ts3version" | tail -1) | grep -Eo "TeamSpeak 3 Server ((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}" | grep -Eo "((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}" | sort -V | tail -1) if [ -z "${currentbuild}" ]; then fn_print_error_nl "Checking for update: teamspeak.com: Current build version not found" fn_script_log_error "Checking for update: teamspeak.com: Current build version not found" @@ -74,7 +74,7 @@ fn_update_ts3_currentbuild(){ command_stop.sh exitbypass=1 command_start.sh - currentbuild=$(cat $(find ./* -name 'ts3server*_0.log' 2> /dev/null | sort | grep -Ev '${rootdir}/.ts3version' | tail -1) | grep -Eo 'TeamSpeak 3 Server ((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}' | grep -Eo '((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}') + currentbuild=$(cat $(find ./* -name "ts3server*_0.log" 2> /dev/null | sort | grep -Ev "${rootdir}/.ts3version" | tail -1) | grep -Eo "TeamSpeak 3 Server ((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}" | grep -Eo "((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}") if [ -z "${currentbuild}" ]; then fn_print_fail_nl "Checking for update: teamspeak.com: Current build version still not found" fn_script_log_fatal "Checking for update: teamspeak.com: Current build version still not found" From a3f411fa43c86e22adad626a3c9a5cf742117920 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Fri, 7 Dec 2018 21:28:15 +0000 Subject: [PATCH 3/7] feat (game server): StickyBots Server (#2096) --- .../config-lgsm/pstbsserver/_default.cfg | 1 - .../config-lgsm/sbotsserver/_default.cfg | 127 ++++++++++++++++++ .../config-lgsm/squadserver/_default.cfg | 2 +- lgsm/data/serverlist.csv | 1 + lgsm/functions/info_config.sh | 18 +++ lgsm/functions/info_glibc.sh | 3 + lgsm/functions/info_messages.sh | 21 ++- lgsm/functions/info_parms.sh | 12 ++ lgsm/functions/query_gamedig.sh | 12 +- 9 files changed, 186 insertions(+), 11 deletions(-) create mode 100644 lgsm/config-default/config-lgsm/sbotsserver/_default.cfg diff --git a/lgsm/config-default/config-lgsm/pstbsserver/_default.cfg b/lgsm/config-default/config-lgsm/pstbsserver/_default.cfg index 7d1fb6b97..19845ee25 100644 --- a/lgsm/config-default/config-lgsm/pstbsserver/_default.cfg +++ b/lgsm/config-default/config-lgsm/pstbsserver/_default.cfg @@ -9,7 +9,6 @@ #### Server Settings #### ## Server Start Settings | https://github.com/GameServerManagers/LinuxGSM/wiki/Start-Parameters - ip="0.0.0.0" randommap="ALWAYS" port="10027" diff --git a/lgsm/config-default/config-lgsm/sbotsserver/_default.cfg b/lgsm/config-default/config-lgsm/sbotsserver/_default.cfg new file mode 100644 index 000000000..fd3da3143 --- /dev/null +++ b/lgsm/config-default/config-lgsm/sbotsserver/_default.cfg @@ -0,0 +1,127 @@ +################################## +######## Default Settings ######## +################################## +# DO NOT EDIT WILL BE OVERWRITTEN! +# Copy settings from here and use them in either +# common.cfg - applies settings to every instance +# [instance].cfg - applies settings to a specific instance + +#### Server Settings #### + +## Server Start Settings | https://github.com/GameServerManagers/LinuxGSM/wiki/Start-Parameters +port="7777" +queryport="27015" +defaultmap="StationKappa" +servername="LinuxGSM Server" +serverpassword="NOT SET" # Can't be adjusted currently +maxplayers="8" # Can't be adjusted currently + +## Server Start Command | https://github.com/GameServerManagers/LinuxGSM/wiki/Start-Parameters#additional-parameters +fn_parms(){ +parms="Port=${port}?QueryPort=${queryport} -startup_map ${defaultmap} -server_name \"${servername}\"" +} + +#### LinuxGSM Settings #### + +## Notification Alerts +# (on|off) + +# More info | https://github.com/GameServerManagers/LinuxGSM/wiki/Alerts#more-info +postalert="off" +postdays="7" +posttarget="https://hastebin.com" + +# Discord Alerts | https://github.com/GameServerManagers/LinuxGSM/wiki/Discord +discordalert="off" +discordwebhook="webhook" + +# Email Alerts | https://github.com/GameServerManagers/LinuxGSM/wiki/Email +emailalert="off" +email="email@example.com" +emailfrom="" + +# IFTTT Alerts | https://github.com/GameServerManagers/LinuxGSM/wiki/IFTTT +iftttalert="off" +ifttttoken="accesstoken" +iftttevent="linuxgsm_alert" + +# Mailgun Email Alerts | https://github.com/GameServerManagers/LinuxGSM/wiki/mailgun +mailgunalert="off" +mailguntoken="accesstoken" +mailgundomain="example.com" +mailgunemailfrom="alert@example.com" +mailgunemail="email@myemail.com" + +# Pushbullet Alerts | https://github.com/GameServerManagers/LinuxGSM/wiki/Pushbullet +pushbulletalert="off" +pushbullettoken="accesstoken" +channeltag="" + +# Pushover Alerts | https://github.com/GameServerManagers/LinuxGSM/wiki/Pushover +pushoveralert="off" +pushovertoken="accesstoken" + +# Telegram Alerts | https://github.com/GameServerManagers/LinuxGSM/wiki/Telegram +# You can add a custom cURL string eg proxy (useful in Russia) or else in "curlcustomstring". +# like a "--socks5 ipaddr:port" for socks5 proxy see more in "curl --help", if you not need +# any custom string in curl - simple ignore this parameter. +telegramalert="off" +telegramtoken="accesstoken" +telegramchatid="" +curlcustomstring="" + +## Backup | https://github.com/GameServerManagers/LinuxGSM/wiki/Backup +maxbackups="4" +maxbackupdays="30" +stoponbackup="on" + +## Logging | https://github.com/GameServerManagers/LinuxGSM/wiki/Logging +consolelogging="on" +logdays="7" + +#### LinuxGSM Advanced Settings #### + +# ANSI Colors +ansi="on" + +## SteamCMD Settings +# Server appid +appid="974130" +# Steam App Branch Select +# Allows to opt into the various Steam app branches. Default branch is "". +# Example: "-beta latest_experimental" +branch="" + +## LinuxGSM Server Details +# Do not edit +gamename="StickyBots" +engine="unreal4" + +#### Directories #### +# Edit with care + +## Server Specific Directories +systemdir="${serverfiles}" +executabledir="${systemdir}/blank1/Binaries/Linux" +executable="./blank1Server-Linux-Shipping" +servercfg="Game.ini" +servercfgdefault="Game.ini" +servercfgdir="${systemdir}/blank1/Saved/Config/Windows" +servercfgfullpath="${servercfgdir}/${servercfg}" + +## Backup Directory +backupdir="${rootdir}/backups" + +## Logging Directories +logdir="${rootdir}/log" +gamelogdir="${serverfiles}/Logs" +lgsmlogdir="${logdir}/script" +consolelogdir="${logdir}/console" +lgsmlog="${lgsmlogdir}/${servicename}-script.log" +consolelog="${consolelogdir}/${servicename}-console.log" +alertlog="${lgsmlogdir}/${servicename}-alert.log" +postdetailslog="${lgsmlogdir}/${servicename}-postdetails.log" + +## Logs Naming +lgsmlogdate="${lgsmlogdir}/${servicename}-script-$(date '+%Y-%m-%d-%H:%M:%S').log" +consolelogdate="${consolelogdir}/${servicename}-console-$(date '+%Y-%m-%d-%H:%M:%S').log" \ No newline at end of file diff --git a/lgsm/config-default/config-lgsm/squadserver/_default.cfg b/lgsm/config-default/config-lgsm/squadserver/_default.cfg index f2ef9badf..60284ca6f 100644 --- a/lgsm/config-default/config-lgsm/squadserver/_default.cfg +++ b/lgsm/config-default/config-lgsm/squadserver/_default.cfg @@ -9,10 +9,10 @@ #### Server Settings #### ## Server Start Settings | https://github.com/GameServerManagers/LinuxGSM/wiki/Start-Parameters +ip="0.0.0.0" port="7787" queryport="27165" randommap="ALWAYS" -ip="0.0.0.0" ## Server Start Command | https://github.com/GameServerManagers/LinuxGSM/wiki/Start-Parameters#additional-parameters fn_parms(){ diff --git a/lgsm/data/serverlist.csv b/lgsm/data/serverlist.csv index 2a55c4122..497f37c8d 100644 --- a/lgsm/data/serverlist.csv +++ b/lgsm/data/serverlist.csv @@ -64,6 +64,7 @@ ricochet,ricochetserver,Ricochet rust,rustserver,Rust rw,rwserver, Rising World samp,sampserver,San Andreas Multiplayer +sbot,sbotserver, StickyBots ss3,ss3server,Serious Sam 3: BFE sb,sbserver,Starbound st,stserver,Stationeers diff --git a/lgsm/functions/info_config.sh b/lgsm/functions/info_config.sh index 93912c529..6116fa144 100644 --- a/lgsm/functions/info_config.sh +++ b/lgsm/functions/info_config.sh @@ -612,6 +612,21 @@ fn_info_config_seriousengine35(){ fi } +#StickyBots +fn_info_config_sbots(){ + if [ ! -f "${servercfgfullpath}" ]; then + servername="${unavailable}" + maxplayers="${unavailable}" + else + servername="$(grep "ServerName=" "${servercfgfullpath}" | sed -e 's/^[ \t]//g' -e '/^#/d' -e 's/ServerName//g' | tr -d '=";,:' | sed -e 's/^[ \t]//' -e 's/[ \t]*$//')" + maxplayers="$(grep "MaxPlayers=" "${servercfgfullpath}" | tr -cd '[:digit:]')" + fi + + servername=${servername:-"NOT SET"} + serverpassword=${serverpassword:-"NOT SET"} + maxplayers=${maxplayers:-"0"} +} + fn_info_config_source(){ if [ ! -f "${servercfgfullpath}" ]; then servername="${unavailable}" @@ -1204,6 +1219,9 @@ elif [ "${shortname}" == "mumble" ]; then # San Andreas Multiplayer elif [ "${shortname}" == "samp" ]; then fn_info_config_samp +# StickyBots +elif [ "${shortname}" == "pstbs" ]; then + fn_info_config_sbots # Teeworlds elif [ "${shortname}" == "tw" ]; then fn_info_config_teeworlds diff --git a/lgsm/functions/info_glibc.sh b/lgsm/functions/info_glibc.sh index 015c1e169..d383daab6 100644 --- a/lgsm/functions/info_glibc.sh +++ b/lgsm/functions/info_glibc.sh @@ -114,6 +114,9 @@ elif [ "${gamename}" == "Squad" ]; then elif [ "${gamename}" == "Sven Co-op" ]; then glibcrequired="2.18" glibcfix="no" +elif [ "${shortname}" == "sbots" ]; then + glibcrequired="2.17" + glibcfix="no" elif [ "${gamename}" == "Team Fortress 2" ]; then glibcrequired="2.15" glibcfix="yes" diff --git a/lgsm/functions/info_messages.sh b/lgsm/functions/info_messages.sh index 03ebcda49..24821c9cd 100644 --- a/lgsm/functions/info_messages.sh +++ b/lgsm/functions/info_messages.sh @@ -231,7 +231,10 @@ fn_info_message_gameserver(){ echo -e "${blue}Current Scenario:\t${default}${gdgamemode}" fi else - echo -e "${blue}Current Game Mode:\t${default}${gdgamemode}" + # Current Scenario + if [ -n "${gdgamemode}" ]; then + echo -e "${blue}Current Game Mode:\t${default}${gdgamemode}" + fi fi # Default Map @@ -746,7 +749,7 @@ fn_info_message_mumble(){ echo -e "> ServerQuery\tINBOUND\t${port}\ttcp" } | column -s $'\t' -t } -fn_info_Message_pstbs(){ +fn_info_message_pstbs(){ echo -e "netstat -atunp | grep PostScriptum" echo -e "" { @@ -889,6 +892,16 @@ fn_info_message_seriousengine35(){ } | column -s $'\t' -t } +fn_info_message_sbots(){ + echo -e "netstat -atunp | grep blank1" + echo -e "" + { + echo -e "DESCRIPTION\tDIRECTION\tPORT\tPROTOCOL" + echo -e "> Game\tINBOUND\t${port}\tudp" + echo -e "> Query\tINBOUND\t${queryport}\tudp" + } | column -s $'\t' -t +} + fn_info_message_sdtd(){ fn_info_message_password_strip echo -e "netstat -atunp | grep 7DaysToDie" @@ -1182,7 +1195,7 @@ fn_info_message_select_engine(){ elif [ "${shortname}" == "kf2" ]; then fn_info_message_kf2 elif [ "${shortname}" == "pstbs" ]; then - fn_info_Message_pstbs + fn_info_message_pstbs elif [ "${gamename}" == "Project Cars" ]; then fn_info_message_projectcars elif [ "${gamename}" == "QuakeWorld" ]; then @@ -1199,6 +1212,8 @@ fn_info_message_select_engine(){ fn_info_message_squad elif [ "${gamename}" == "Stationeers" ]; then fn_info_message_stationeers + elif [ "${shortname}" == "sbots" ]; then + fn_info_message_sbots elif [ "${gamename}" == "TeamSpeak 3" ]; then fn_info_message_teamspeak3 elif [ "${gamename}" == "Tower Unite" ]; then diff --git a/lgsm/functions/info_parms.sh b/lgsm/functions/info_parms.sh index ced392bc6..133365fd8 100644 --- a/lgsm/functions/info_parms.sh +++ b/lgsm/functions/info_parms.sh @@ -125,6 +125,15 @@ fn_info_parms_spark(){ mods=${mods:-"NOT SET"} } +fn_info_parms_stickybots(){ + port=${port:-"0"} + queryport=${queryport:-"0"} + servername=${servername:-"NOT SET"} + serverpassword=${serverpassword:-"NOT SET"} + defaultmap=${defaultmap:-"NOT SET"} + maxplayers=${maxplayers:-"0"} +} + fn_info_config_towerunite(){ port=${port:-"0"} queryport=${queryport:-"0"} @@ -185,6 +194,9 @@ elif [ "${shortname}" == "rust" ]; then # Rising World elif [ "${shortname}" == "rw" ]; then fn_info_parms_risingworld +# Sticky Bots +elif [ "${shortname}" == "sbots" ]; then + fn_info_parms_stickybots # Serious Sam elif [ "${shortname}" == "ss3" ]; then fn_info_config_seriousengine35 diff --git a/lgsm/functions/query_gamedig.sh b/lgsm/functions/query_gamedig.sh index 1bdce107a..21e0ed091 100644 --- a/lgsm/functions/query_gamedig.sh +++ b/lgsm/functions/query_gamedig.sh @@ -89,37 +89,37 @@ if [ "$(command -v gamedig 2>/dev/null)" ]&&[ "$(command -v jq 2>/dev/null)" ]; # server name gdname=$(echo "${gamedigraw}" | jq -re '.name') if [ "${gdname}" == "null" ]; then - gdname= + unset gdname fi # numplayers gdplayers=$(echo "${gamedigraw}" | jq -re '.players|length') if [ "${gdplayers}" == "null" ]; then - gdplayers= + unset gdplayers fi # maxplayers gdmaxplayers=$(echo "${gamedigraw}" | jq -re '.maxplayers|length') if [ "${gdmaxplayers}" == "null" ]; then - maxplayers= + unset maxplayers fi # current map gdmap=$(echo "${gamedigraw}" | jq -re '.map') if [ "${gdmap}" == "null" ]; then - gdmap= + unset gdmap fi # current gamemode gdgamemode=$(echo "${gamedigraw}" | jq -re '.raw.rules.GameMode_s') if [ "${gdgamemode}" == "null" ]; then - gdgamemode= + unset gdgamemode fi # numbots gdbots=$(echo "${gamedigraw}" | jq -re '.raw.numbots') if [ "${gdbots}" == "null" ]; then - gdbots= + unset gdbots fi fi fi \ No newline at end of file From 5cdd4031da393c81ee366c1651d7290637b18da5 Mon Sep 17 00:00:00 2001 From: Kaotic Date: Fri, 7 Dec 2018 22:32:41 +0100 Subject: [PATCH 4/7] feat (csgoserver): add Danger Zone game mode example (#2095) --- .../config-lgsm/csgoserver/_default.cfg | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) diff --git a/lgsm/config-default/config-lgsm/csgoserver/_default.cfg b/lgsm/config-default/config-lgsm/csgoserver/_default.cfg index 7cbdb93f6..baa2f81d0 100644 --- a/lgsm/config-default/config-lgsm/csgoserver/_default.cfg +++ b/lgsm/config-default/config-lgsm/csgoserver/_default.cfg @@ -10,14 +10,15 @@ ## Server Start Settings | https://github.com/GameServerManagers/LinuxGSM/wiki/Start-Parameters # https://developer.valvesoftware.com/wiki/Counter-Strike:_Global_Offensive_Dedicated_Servers#Starting_the_Server -# [Game Modes] gametype gamemode mapgroup (you can mix these across Game Modes, but use only one) -# Arms Race 1 0 mg_armsrace -# Classic Casual 0 0 mg_casualsigma, mg_casualdelta -# Classic Competitive 0 1 mg_active, mg_reserves, mg_hostage, mg_de_dust2 -# Custom 3 0 -# Deathmatch 1 2 mg_deathmatch -# Demolition 1 1 mg_demolition -# Wingman 0 2 +# [Game Modes] gametype gamemode mapgroup (you can mix these across Game Modes, but use only one) +# Arms Race 1 0 mg_armsrace +# Classic Casual 0 0 mg_casualsigma, mg_casualdelta +# Classic Competitive 0 1 mg_active, mg_reserves, mg_hostage, mg_de_dust2 +# Custom 3 0 +# Deathmatch 1 2 mg_deathmatch +# Demolition 1 1 mg_demolition +# Wingman 0 2 +# Danger Zone (FreeForAll) 6 0 mg_dz_blacksite gametype="0" gamemode="0" mapgroup="mg_active" From 50f1c08321c19b6bdff74b86b69baa5750c76b71 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Fri, 7 Dec 2018 21:51:11 +0000 Subject: [PATCH 5/7] Create CODE_OF_CONDUCT.md (#2091) docs: create CODE_OF_CONDUCT.md --- CODE_OF_CONDUCT.md | 73 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 73 insertions(+) create mode 100644 CODE_OF_CONDUCT.md diff --git a/CODE_OF_CONDUCT.md b/CODE_OF_CONDUCT.md new file mode 100644 index 000000000..7fe220357 --- /dev/null +++ b/CODE_OF_CONDUCT.md @@ -0,0 +1,73 @@ +# Contributor Covenant Code of Conduct + +## Our Pledge + +In the interest of fostering an open and welcoming environment, we as +contributors and maintainers pledge to making participation in our project and +our community a harassment-free experience for everyone, regardless of age, body +size, disability, ethnicity, sex characteristics, gender identity and expression, +level of experience, education, socio-economic status, nationality, personal +appearance, race, religion, or sexual identity and orientation. + +## Our Standards + +Examples of behavior that contributes to creating a positive environment +include: + +* Using welcoming and inclusive language +* Being respectful of differing viewpoints and experiences +* Gracefully accepting constructive criticism +* Focusing on what is best for the community +* Showing empathy towards other community members + +Examples of unacceptable behavior by participants include: + +* The use of sexualized language or imagery and unwelcome sexual attention or advances +* Trolling, insulting/derogatory comments, and personal or political attacks +* Public or private harassment +* Publishing others' private information, such as a physical or electronic address, without explicit permission +* Other conduct which could reasonably be considered inappropriate in a professional setting + +## Our Responsibilities + +Project maintainers are responsible for clarifying the standards of acceptable +behavior and are expected to take appropriate and fair corrective action in +response to any instances of unacceptable behavior. + +Project maintainers have the right and responsibility to remove, edit, or +reject comments, commits, code, wiki edits, issues, and other contributions +that are not aligned to this Code of Conduct, or to ban temporarily or +permanently any contributor for other behaviors that they deem inappropriate, +threatening, offensive, or harmful. + +## Scope + +This Code of Conduct applies both within project spaces and in public spaces +when an individual is representing the project or its community. Examples of +representing a project or community include using an official project e-mail +address, posting via an official social media account, or acting as an appointed +representative at an online or offline event. Representation of a project may be +further defined and clarified by project maintainers. + +## Enforcement + +Instances of abusive, harassing, or otherwise unacceptable behavior may be +reported by contacting the project team at me@danielgibbs.co.uk. All +complaints will be reviewed and investigated and will result in a response that +is deemed necessary and appropriate to the circumstances. The project team is +obligated to maintain confidentiality with regard to the reporter of an incident. +Further details of specific enforcement policies may be posted separately. + +Project maintainers who do not follow or enforce the Code of Conduct in good +faith may face temporary or permanent repercussions as determined by other +members of the project's leadership. + +## Attribution + +This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, +available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html + +[homepage]: https://www.contributor-covenant.org + +For answers to common questions about this code of conduct, see +https://www.contributor-covenant.org/faq From f2dbb9bd49f4eb6be936f9b0873c36dbfe8404f4 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Fri, 7 Dec 2018 22:53:35 +0000 Subject: [PATCH 6/7] fix (sbotsserver): corrected servercfgdir location (#2098) --- lgsm/config-default/config-lgsm/sbotsserver/_default.cfg | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lgsm/config-default/config-lgsm/sbotsserver/_default.cfg b/lgsm/config-default/config-lgsm/sbotsserver/_default.cfg index fd3da3143..98d96a89d 100644 --- a/lgsm/config-default/config-lgsm/sbotsserver/_default.cfg +++ b/lgsm/config-default/config-lgsm/sbotsserver/_default.cfg @@ -106,7 +106,7 @@ executabledir="${systemdir}/blank1/Binaries/Linux" executable="./blank1Server-Linux-Shipping" servercfg="Game.ini" servercfgdefault="Game.ini" -servercfgdir="${systemdir}/blank1/Saved/Config/Windows" +servercfgdir="${systemdir}/blank1/Saved/Config/LinuxServer" servercfgfullpath="${servercfgdir}/${servercfg}" ## Backup Directory From 8a7d2a4760dd82bcd8a9dfd7c38923687ba50afb Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Tue, 11 Dec 2018 22:12:32 +0000 Subject: [PATCH 7/7] docs: repaired LinuxGSM Logo --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 5ba974010..5e1f5cea4 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,4 @@ -linux Game Server Managers +linux Game Server Managers [![LinuxGSM](https://img.shields.io/badge/-LinuxGSM-2b2b2b.svg?logo=data%3Aimage%2Fpng%3Bbase64%2CiVBORw0KGgoAAAANSUhEUgAAACsAAABACAYAAACDbo5ZAAAGD0lEQVR4AcWYa2wUVRvHz75c2vJ2disXoUBEVIioRAx%2BMIFA1IRwUS6KCCiIKBrvhEYiiGm5iBgk8QOGEgUUDYTttmVZWFr2UmwURS6iYAoCtmisElSsdHdbkT7%2BTzoNy%2BGc2dm54C%2F5Rdkz85x%2FZ86ZOXOYXYhIg3Phx%2FA4PAcv6f%2Btg5vhHJjP3EcZsgsshufJHH%2FAJbDztQ7aG35J1vgCXn%2BtgvrgEbLHYei9FmE3kDOUuh10OGwjZ7gEh7kZ9gNyllK3gnrg7%2BQs56DHjbCDyB0GuRF2ArnDeDfCziF3mO1G2FfJHRa4EXYpuUOxG2GXkzuUuBH2TXKH5W6ELSV3eM%2BNsOUk5yQcAY8p2uvgSPitor3MjbB1UOQXOFBvHwpbhPYWOExvL4SNUOQ7p4P2JTlzhOPmCu0vCu1PQpE2WOhk2MdJjk9y7HNwP1wEPUJbAcmZ6WTYrYolnifbxZBiibnFySHQCkUaLdY7C0V4%2FT5OhF1JcuIW6%2B0lOcvsBi2Ezao3j8Ov7Quwj52w60jNKIs1R5GatVaDDoEXSU4D7GSxbidYT3IuwjusFK0mNUVMwaZNNbl%2B%2F87hoVCom0HthaQmnG3QB0lNPcxlCvz%2B0GtlZTuorCxYYlA%2FDzbY%2FnrAgV3hCVLzCDMgEAi9wMMi9IIM%2FUwnNXWwi5mwRaSmmmXA798xq%2F3Khp420VeE1LyS6eQeBhttSXgzywCCToIUCOyYZvKLOWWwkdfd6ORVpGYJM0F5efDe9mEQHGty2BWTmhVGO4PNBmOoKzMBxmo%2FhD25dWvljSbD5hjMkb9gT9lJq63Mzi1bKkbjloc7xBWtwiRrDASCVRi%2FRxA8if%2BvrawMTzYI%2FACpeUv2KFFtDcUyTKilCHcis8G1Ga7wHpLzG8wVFs1K7jaeUKHZfIxmkj9%2FM4S9x9RGiMEudo0QbCVu9Xqn5PWEwLUk5%2FP0iaXac53I0kAH9Sau4m54lo%2FdTMfyekLYKQZ7ub34AbMMlmw5irC2VYTN0fuVMYMf8JHxJ7L7YYXAlSRnI2%2F8RtH4siTsDMz%2BZ5yS15OEXUxyDjGD1%2BvEq8MG16CDzY6JepKwT6geYbzxb0XjGMl7vwGSgzZIwo4nOa1M8Yr9Afb%2Fj8L21%2FsXaeaNZ2A6KTiEASph%2F0vF80cn4tokqu79fzfCUk2vfF4%2FFdFGEjGPHvg2yWrsDG%2F4%2BqpZB8jPOiXjWk0y5iXdM3XhKUvxBTA9UvHuvNPh%2Bzb%2BWj10z6nwuHWBbQFMvNCjKnn7qd1jS%2Fnx9VX3b6jC%2BbwOr5eMe3%2B83IcW4%2F3qgT%2BUTbA9srGaiHsn8AKiF6Ld%2FxF%2FOx6eeAJXabvK78MTTornNMd6XJTVR7%2Fj9bBjhFxV%2FMc1kJOAy2AeA%2FgrV4mFVDZFCqm8rEJ6qysCAWqK9iaztRJRbWXa4moFTELOav7jY%2FqAvoXp0Gc9NX7bIZl17%2FZl0rC1wRLeno0NvP%2B0CTcYNnS8wW6CtzNANaxzKqo9hRNOQ8rGo7tmSsMe2zWdt2frqVRcm5s2fofCgawDNHRNxnyfqgsYez4y4ADCjRM9H73hsNWafILTQdaFiSTj%2BQ%2FxA6yH7d%2BCmR8XbYr0a7VTF2N4siSsb5qdos3R6%2FjGxpULFfw7EfORnbrI9TAToX0sD40%2F2ylcGdh2Rdhg%2BSf2gka9jRTqK9%2BGwgHz7RTfVbHxirDhivdthYUvMRX8aYAD9lstvi%2B0aDL2DUZ0eCBUNNVG0IP65FLTWqPdiqdC0koHTVXe7iyNRG23QotBEy1RbTAzQyrmnYUT2rLsoA13JpcB4eVC2daBM1g2JGLekmwf5On7EJfngfZTNnVSce8bFjaTmQdvs%2FXmO%2FJVpoXdx3RSUe9O00Fj3nUdy0RLgRHiHXOPGW1h2uKZ07c9rG%2Bxyefp23pQeyBIEQoavYlakrG8fnrY5yHn2fbxXzAgw7m8bT5zkkSk4C7cpmOK21esB%2FXAQ5DzFfTo43%2BF%2FDzf0eZ4wZ3MDSjMcvD6nIeOahGgia%2FyU3HforTPkWkwnakdn0cI9jqfbPjD%2FuQLJr6644snlgX%2FApOMoyd1R5%2FxAAAAAElFTkSuQmCC)](https://linuxgsm.com) [![Build Status](https://travis-ci.org/GameServerManagers/LinuxGSM.svg?branch=master)](https://travis-ci.org/GameServerManagers/LinuxGSM)