From fca87cde2d65b3ffbc360b58697f78fb83ced75e Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sat, 25 Feb 2017 14:11:51 +0000 Subject: [PATCH 01/33] Changed noupdate servers to use engines shortens the if statement --- lgsm/functions/core_getopt.sh | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/lgsm/functions/core_getopt.sh b/lgsm/functions/core_getopt.sh index 78b097398..0889dbd19 100644 --- a/lgsm/functions/core_getopt.sh +++ b/lgsm/functions/core_getopt.sh @@ -34,7 +34,7 @@ cmd_mods_remove=( "mr;mods-remove" "command_mods_remove.sh" "View and remove an cmd_mods_update=( "mu;mods-update" "command_mods_update.sh" "Update installed mods/addons." ) # Server specific cmd_change_password=( "pw;change-password" "command_ts3_server_pass.sh" "Change TS3 serveradmin password." ) -cmd_install_default_ressources=( "ir;install-default-ressources" "command_install_resources_mta.sh" "Install the MTA default resources." ) +cmd_install_default_resources=( "ir;install-default-resources" "command_install_resources_mta.sh" "Install the MTA default resources." ) cmd_wipe=( "wi;wipe" "command_wipe.sh" "Wipe your server data." ) cmd_map_compressor_u99=( "mc;map-compressor" "compress_ut99_maps.sh" "Compresses all ${gamename} server maps." ) cmd_map_compressor_u2=( "mc;map-compressor" "compress_unreal2_maps.sh" "Compresses all ${gamename} server maps." ) @@ -61,7 +61,7 @@ if [ "${gamename}" != "TeamSpeak 3" ]; then currentopt+=( "${cmd_console[@]}" "${cmd_debug[@]}" ) fi # Exclude noupdated games here -if [ "${gamename}" != "Battlefield: 1942" ]&&[ "${gamename}" != "Call of Duty" ]&&[ "${gamename}" != "Call of Duty: United Offensive" ]&&[ "${gamename}" != "Call of Duty 2" ]&&[ "${gamename}" != "Call of Duty 4" ]&&[ "${gamename}" != "Call of Duty: World at War" ]&&[ "${gamename}" != "QuakeWorld" ]&&[ "${gamename}" != "Quake 2" ]&&[ "${gamename}" != "Quake 3: Arena" ]&&[ "${gamename}" != "Wolfenstein: Enemy Territory" ]; then +if [ "${gamename}" != "Battlefield: 1942" ]&&[ "${engine}" != "quake" ]&&[ "${engine}" != "idtech2" ]&&[ "${engine}" != "idtech3" ]&&[ "${engine}" != "iw2.0" ]&&[ "${engine}" != "iw3.0" ]&&; then currentopt+=( "${cmd_update[@]}" "${cmd_force_update[@]}") fi @@ -79,7 +79,7 @@ if [ "${gamename}" == "Rust" ]; then currentopt+=( "${cmd_wipe[@]}" ) fi # Mods commands -if [ "${engine}" == "source" ]||[ "${gamename}" == "Rust" ]|[ "${gamename}" == "Hurtworld" ]|[ "${gamename}" == "7 Days To Die" ]; then +if [ "${engine}" == "source" ]||[ "${gamename}" == "Rust" ]||[ "${gamename}" == "Hurtworld" ]||[ "${gamename}" == "7 Days To Die" ]; then currentopt+=( "${cmd_mods_install[@]}" "${cmd_mods_remove[@]}" "${cmd_mods_update[@]}" ) fi @@ -105,7 +105,7 @@ if [ "${gamename}" == "Don't Starve Together" ]; then fi # MTA exclusive if [ "${gamename}" == "Multi Theft Auto" ]; then - currentopt+=( "${cmd_install_default_ressources[@]}" ) + currentopt+=( "${cmd_install_default_resources[@]}" ) fi ## Developer commands @@ -160,7 +160,7 @@ for i in "${optcommands[@]}"; do ${currentopt[index+1]} break fi - done + done done break core_exit.sh From 8ee9fdbb3cdb49b4707fbba0ba09734229d27115 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sat, 25 Feb 2017 14:33:56 +0000 Subject: [PATCH 02/33] stray && --- lgsm/functions/core_getopt.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lgsm/functions/core_getopt.sh b/lgsm/functions/core_getopt.sh index 0889dbd19..e853ea890 100644 --- a/lgsm/functions/core_getopt.sh +++ b/lgsm/functions/core_getopt.sh @@ -61,7 +61,7 @@ if [ "${gamename}" != "TeamSpeak 3" ]; then currentopt+=( "${cmd_console[@]}" "${cmd_debug[@]}" ) fi # Exclude noupdated games here -if [ "${gamename}" != "Battlefield: 1942" ]&&[ "${engine}" != "quake" ]&&[ "${engine}" != "idtech2" ]&&[ "${engine}" != "idtech3" ]&&[ "${engine}" != "iw2.0" ]&&[ "${engine}" != "iw3.0" ]&&; then +if [ "${gamename}" != "Battlefield: 1942" ]&&[ "${engine}" != "quake" ]&&[ "${engine}" != "idtech2" ]&&[ "${engine}" != "idtech3" ]&&[ "${engine}" != "iw2.0" ]&&[ "${engine}" != "iw3.0" ]; then currentopt+=( "${cmd_update[@]}" "${cmd_force_update[@]}") fi From 7e1bc80fe1e6e203fea1ec8a065f23badafec04e Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sat, 25 Feb 2017 17:36:39 +0000 Subject: [PATCH 03/33] A re shuffle and changed some commands --- lgsm/functions/core_getopt.sh | 66 ++++++++++++++++++++--------------- 1 file changed, 38 insertions(+), 28 deletions(-) diff --git a/lgsm/functions/core_getopt.sh b/lgsm/functions/core_getopt.sh index e853ea890..1fa60fd69 100644 --- a/lgsm/functions/core_getopt.sh +++ b/lgsm/functions/core_getopt.sh @@ -10,14 +10,14 @@ local function_selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))" ## User commands | Trigger commands | Description # Standard commands cmd_install=( "i;install" "command_install.sh" "Install the server." ) -cmd_auto_install=( "ai;auto-install" "command_autoinstall.sh" "Install the server without prompts." ) +cmd_auto_install=( "ai;auto-install" "fn_autoinstall" "Install the server without prompts." ) cmd_start=( "st;start" "command_start.sh" "Start the server." ) cmd_stop=( "sp;stop" "command_stop.sh" "Stop the server." ) cmd_restart=( "r;restart" "command_restart.sh" "Restart the server." ) cmd_details=( "dt;details" "command_details.sh" "Display relevant server information." ) cmd_postdetails=( "pd;postdetails" "command_postdetails.sh" "Post stripped details to pastebin for support." ) cmd_backup=( "b;backup" "command_backup.sh" "Create archives of the server." ) -cmd_update_functions=( "uf;update-functions" "command_update_functions.sh" "Update LinuxGSM functions." ) +cmd_update_functions=( "ul;update-lgsm;uf;update-functions" "command_update_functions.sh" "Update LinuxGSM functions." ) cmd_test_alert=( "ta;test-alert" "command_test_alert.sh" "Send a test alert." ) cmd_monitor=( "m;monitor" "command_monitor.sh" "Check server status and restart it if crashed." ) # Console servers only @@ -25,7 +25,7 @@ cmd_console=( "c;console" "command_console.sh" "Access server console." ) cmd_debug=( "d;debug" "command_debug.sh" "Start server directly in your terminal." ) # Update servers only cmd_update=( "u;update" "command_update.sh" "Check for updates and apply if available." ) -cmd_force_update=( "fu;force-update;update-restart;ur" "forceupdate=1; command_update.sh" "Unconditionally update the server." ) +cmd_force_update=( "fu;force-update;update-restart;ur" "forceupdate=1; command_update.sh" "Force update the server." ) # SteamCMD servers only cmd_validate=( "v;validate" "command_validate.sh" "Validate server files with SteamCMD." ) # Server with mods-install @@ -42,46 +42,46 @@ cmd_install_cdkey=( "cd;server-cd-key" "install_ut2k4_key.sh" "Add your server c cmd_install_dst_token=( "ct;cluster-token" "install_dst_token.sh" "Configure cluster token." ) cmd_fastdl=( "fd;fastdl" "command_fastdl.sh" "Build a FastDL directory." ) # Dev commands -cmd_dev_debug=( "dev;dev-debug" "command_dev_debug.sh" "DEVCOMMAND" ) -cmd_dev_detect_deps=( "dd;detect-deps" "command_dev_detect_deps.sh" "DEVCOMMAND" ) -cmd_dev_detect_glibc=( "dg;detect-glibc" "command_dev_detect_glibc.sh" "DEVCOMMAND" ) -cmd_dev_detect_ldd=( "dl;detect-ldd" "command_dev_detect_ldd.sh" "DEVCOMMAND" ) +cmd_dev_debug=( "dev;developer" "command_dev_debug.sh" "Enable developer Mode." ) +cmd_dev_detect_deps=( "dd;detect-deps" "command_dev_detect_deps.sh" "Detect required dependencies." ) +cmd_dev_detect_glibc=( "dg;detect-glibc" "command_dev_detect_glibc.sh" "Detect required glibc." ) +cmd_dev_detect_ldd=( "dl;detect-ldd" "command_dev_detect_ldd.sh" "Detect required dynamic dependencies." ) ### Set specific opt here ### ## Common opt to all servers +currentopt=( "${cmd_start[@]}" "${cmd_stop[@]}" "${cmd_restart[@]}" "${cmd_monitor[@]}" "${cmd_test_alert[@]}" "${cmd_details[@]}" "${cmd_postdetails[@]}" ) -currentopt=( "${cmd_install[@]}" "${cmd_auto_install[@]}" "${cmd_start[@]}" "${cmd_stop[@]}" "${cmd_restart[@]}" "${cmd_details[@]}" ) -currentopt+=( "${cmd_backup[@]}" "${cmd_update_functions[@]}" "${cmd_test_alert[@]}" "${cmd_monitor[@]}" ) - -## Servers that do not have a feature - -# Exclude games without a console -if [ "${gamename}" != "TeamSpeak 3" ]; then - currentopt+=( "${cmd_console[@]}" "${cmd_debug[@]}" ) -fi # Exclude noupdated games here if [ "${gamename}" != "Battlefield: 1942" ]&&[ "${engine}" != "quake" ]&&[ "${engine}" != "idtech2" ]&&[ "${engine}" != "idtech3" ]&&[ "${engine}" != "iw2.0" ]&&[ "${engine}" != "iw3.0" ]; then - currentopt+=( "${cmd_update[@]}" "${cmd_force_update[@]}") + currentopt+=( "${cmd_update[@]}" ) + # force update for SteamCMD only + if [ -n "${appid}" ]; then + currentopt+=( "${cmd_force_update[@]}" ) + fi fi -## Include games that have access to specific commands # Validate command if [ -n "${appid}" ]; then currentopt+=( "${cmd_validate[@]}" ) fi + +# Update LGSM +currentopt+=( "${cmd_update_functions[@]}" ) + +#Backup +currentopt+=( "${cmd_backup[@]}" ) + + +# Exclude games without a console +if [ "${gamename}" != "TeamSpeak 3" ]; then + currentopt+=( "${cmd_console[@]}" "${cmd_debug[@]}" ) +fi + # FastDL command if [ "${engine}" == "source" ]; then currentopt+=( "${cmd_fastdl[@]}" ) fi -# Wipe command -if [ "${gamename}" == "Rust" ]; then - currentopt+=( "${cmd_wipe[@]}" ) -fi -# Mods commands -if [ "${engine}" == "source" ]||[ "${gamename}" == "Rust" ]||[ "${gamename}" == "Hurtworld" ]||[ "${gamename}" == "7 Days To Die" ]; then - currentopt+=( "${cmd_mods_install[@]}" "${cmd_mods_remove[@]}" "${cmd_mods_update[@]}" ) -fi ## Game server exclusive commands # TeamSpeak exclusive @@ -89,6 +89,9 @@ if [ "${gamename}" == "TeamSpeak 3" ]; then currentopt+=( "${cmd_change_password[@]}" ) fi # Unreal exclusive +if [ "${gamename}" == "Rust" ]; then + currentopt+=( "${cmd_wipe[@]}" ) +fi if [ "${engine}" == "unreal2" ]; then if [ "${gamename}" == "Unreal Tournament 2004" ]; then currentopt+=( "${cmd_install_cdkey[@]}" "${cmd_map_compressor_u2[@]}" ) @@ -108,9 +111,16 @@ if [ "${gamename}" == "Multi Theft Auto" ]; then currentopt+=( "${cmd_install_default_resources[@]}" ) fi -## Developer commands -currentopt+=( "${cmd_dev_debug[@]}" "${cmd_dev_detect_deps[@]}" "${cmd_dev_detect_glibc[@]}" "${cmd_dev_detect_ldd[@]}" ) +## Mods commands +if [ "${engine}" == "source" ]||[ "${gamename}" == "Rust" ]||[ "${gamename}" == "Hurtworld" ]||[ "${gamename}" == "7 Days To Die" ]; then + currentopt+=( "${cmd_mods_install[@]}" "${cmd_mods_remove[@]}" "${cmd_mods_update[@]}" ) +fi +## Developer commands +currentopt+=( "${cmd_dev_debug[@]}" ) +if [ -f ".dev-debug" ]; then + currentopt+=( "${cmd_dev_detect_deps[@]}" "${cmd_dev_detect_glibc[@]}" "${cmd_dev_detect_ldd[@]}" ) +fi ### Build list of available commands optcommands=() From 0398f33c621f692b8dbe352d1701af381aeb454b Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sat, 25 Feb 2017 17:43:24 +0000 Subject: [PATCH 04/33] re wording --- lgsm/functions/core_getopt.sh | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/lgsm/functions/core_getopt.sh b/lgsm/functions/core_getopt.sh index 1fa60fd69..2e46278f1 100644 --- a/lgsm/functions/core_getopt.sh +++ b/lgsm/functions/core_getopt.sh @@ -14,18 +14,18 @@ cmd_auto_install=( "ai;auto-install" "fn_autoinstall" "Install the server withou cmd_start=( "st;start" "command_start.sh" "Start the server." ) cmd_stop=( "sp;stop" "command_stop.sh" "Stop the server." ) cmd_restart=( "r;restart" "command_restart.sh" "Restart the server." ) -cmd_details=( "dt;details" "command_details.sh" "Display relevant server information." ) -cmd_postdetails=( "pd;postdetails" "command_postdetails.sh" "Post stripped details to pastebin for support." ) -cmd_backup=( "b;backup" "command_backup.sh" "Create archives of the server." ) +cmd_details=( "dt;details" "command_details.sh" "Display server information." ) +cmd_postdetails=( "pd;postdetails" "command_postdetails.sh" "Post details to hastebin (removing passwords)." ) +cmd_backup=( "b;backup" "command_backup.sh" "Create backup archives of the server." ) cmd_update_functions=( "ul;update-lgsm;uf;update-functions" "command_update_functions.sh" "Update LinuxGSM functions." ) cmd_test_alert=( "ta;test-alert" "command_test_alert.sh" "Send a test alert." ) -cmd_monitor=( "m;monitor" "command_monitor.sh" "Check server status and restart it if crashed." ) +cmd_monitor=( "m;monitor" "command_monitor.sh" "Check server status and restart if crashed." ) # Console servers only cmd_console=( "c;console" "command_console.sh" "Access server console." ) cmd_debug=( "d;debug" "command_debug.sh" "Start server directly in your terminal." ) # Update servers only -cmd_update=( "u;update" "command_update.sh" "Check for updates and apply if available." ) -cmd_force_update=( "fu;force-update;update-restart;ur" "forceupdate=1; command_update.sh" "Force update the server." ) +cmd_update=( "u;update" "command_update.sh" "Check and apply any updates." ) +cmd_force_update=( "fu;force-update;update-restart;ur" "forceupdate=1; command_update.sh" "Bypass update check and apply any updates." ) # SteamCMD servers only cmd_validate=( "v;validate" "command_validate.sh" "Validate server files with SteamCMD." ) # Server with mods-install From 3229ae3b1fc8702d2605ef056e93310f4e4f0fd0 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sat, 25 Feb 2017 17:48:32 +0000 Subject: [PATCH 05/33] minor tidy --- lgsm/functions/core_getopt.sh | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/lgsm/functions/core_getopt.sh b/lgsm/functions/core_getopt.sh index 2e46278f1..3c3fe0f43 100644 --- a/lgsm/functions/core_getopt.sh +++ b/lgsm/functions/core_getopt.sh @@ -49,10 +49,9 @@ cmd_dev_detect_ldd=( "dl;detect-ldd" "command_dev_detect_ldd.sh" "Detect require ### Set specific opt here ### -## Common opt to all servers currentopt=( "${cmd_start[@]}" "${cmd_stop[@]}" "${cmd_restart[@]}" "${cmd_monitor[@]}" "${cmd_test_alert[@]}" "${cmd_details[@]}" "${cmd_postdetails[@]}" ) -# Exclude noupdated games here +# Exclude noupdate games here if [ "${gamename}" != "Battlefield: 1942" ]&&[ "${engine}" != "quake" ]&&[ "${engine}" != "idtech2" ]&&[ "${engine}" != "idtech3" ]&&[ "${engine}" != "iw2.0" ]&&[ "${engine}" != "iw3.0" ]; then currentopt+=( "${cmd_update[@]}" ) # force update for SteamCMD only @@ -78,16 +77,18 @@ if [ "${gamename}" != "TeamSpeak 3" ]; then currentopt+=( "${cmd_console[@]}" "${cmd_debug[@]}" ) fi +## Game server exclusive commands + # FastDL command if [ "${engine}" == "source" ]; then currentopt+=( "${cmd_fastdl[@]}" ) fi -## Game server exclusive commands # TeamSpeak exclusive if [ "${gamename}" == "TeamSpeak 3" ]; then currentopt+=( "${cmd_change_password[@]}" ) fi + # Unreal exclusive if [ "${gamename}" == "Rust" ]; then currentopt+=( "${cmd_wipe[@]}" ) @@ -102,10 +103,12 @@ fi if [ "${engine}" == "unreal" ]; then currentopt+=( "${cmd_map_compressor_u99[@]}" ) fi + # DST exclusive if [ "${gamename}" == "Don't Starve Together" ]; then currentopt+=( "${cmd_install_dst_token[@]}" ) fi + # MTA exclusive if [ "${gamename}" == "Multi Theft Auto" ]; then currentopt+=( "${cmd_install_default_resources[@]}" ) @@ -181,4 +184,4 @@ done echo -e "${red}Unknown command${default}: $0 ${getopt}" exitcode=2 fn_opt_usage -core_exit.sh +core_exit.sh \ No newline at end of file From c0891101c17b35b641d082f67f4449d9105767c0 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sat, 25 Feb 2017 22:14:36 +0000 Subject: [PATCH 06/33] display fix --- lgsm/functions/mods_core.sh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lgsm/functions/mods_core.sh b/lgsm/functions/mods_core.sh index 620bfa921..35ab904e4 100644 --- a/lgsm/functions/mods_core.sh +++ b/lgsm/functions/mods_core.sh @@ -346,7 +346,7 @@ fn_mod_compatible_test(){ fn_create_mods_dir(){ # Create lgsm data modsdir if [ ! -d "${modsdir}" ];then - echo "creating lgsm mods data directory ${modsdir}..." + echo -en "creating LinuxGSM mods data directory ${modsdir}..." mkdir -p "${modsdir}" exitcode=$? if [ ${exitcode} -ne 0 ]; then @@ -361,7 +361,7 @@ fn_create_mods_dir(){ fi # Create mod install directory if [ ! -d "${modinstalldir}" ]; then - echo "creating mods install directory ${modinstalldir}..." + echo -en "creating mods install directory ${modinstalldir}..." mkdir -p "${modinstalldir}" exitcode=$? if [ ${exitcode} -ne 0 ]; then @@ -438,7 +438,7 @@ fn_mods_check_installed(){ if [ ${installedmodscount} -eq 0 ]; then echo "" fn_print_failure_nl "No installed mods or addons were found" - echo " * Install mods using LGSM first with: ./${selfname} mods-install" + echo " * Install mods using LinuxGSM first with: ./${selfname} mods-install" fn_script_log_error "No installed mods or addons were found." core_exit.sh fi From cd2d7d1f34dae7e928b3d3faabf9cd91322eac0d Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sun, 26 Feb 2017 14:56:40 +0000 Subject: [PATCH 07/33] files to fileswc --- lgsm/functions/mods_core.sh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lgsm/functions/mods_core.sh b/lgsm/functions/mods_core.sh index 35ab904e4..7e9c1cdf9 100644 --- a/lgsm/functions/mods_core.sh +++ b/lgsm/functions/mods_core.sh @@ -42,7 +42,7 @@ fn_mod_lowercase(){ echo -ne "converting ${modprettyname} files to lowercase..." sleep 0.5 fn_script_log_info "Converting ${modprettyname} files to lowercase" - files=$(find "${extractdir}" -depth | wc -l) + fileswc=$(find "${extractdir}" -depth | wc -l) echo -en "\r" while read -r src; do dst=`dirname "${src}"`/`basename "${src}" | tr '[A-Z]' '[a-z]'` @@ -52,10 +52,10 @@ fn_mod_lowercase(){ local exitcode=$? ((renamedwc++)) fi - echo -ne "${renamedwc} / ${totalfileswc} / $files converting ${modprettyname} files to lowercase..." $'\r' + echo -ne "${renamedwc} / ${totalfileswc} / ${fileswc} converting ${modprettyname} files to lowercase..." $'\r' ((totalfileswc++)) done < <(find "${extractdir}" -depth) - echo -ne "${renamedwc} / ${totalfileswc} / $files converting ${modprettyname} files to lowercase..." + echo -ne "${renamedwc} / ${totalfileswc} / ${fileswc} converting ${modprettyname} files to lowercase..." if [ ${exitcode} -ne 0 ]; then fn_print_fail_eol_nl From 8c17f44d24bcb31b16dccabd67d6ea94bee245fa Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sun, 26 Feb 2017 14:57:05 +0000 Subject: [PATCH 08/33] Forgot to add installer --- lgsm/functions/core_getopt.sh | 3 +++ 1 file changed, 3 insertions(+) diff --git a/lgsm/functions/core_getopt.sh b/lgsm/functions/core_getopt.sh index 3c3fe0f43..39efa37e4 100644 --- a/lgsm/functions/core_getopt.sh +++ b/lgsm/functions/core_getopt.sh @@ -119,6 +119,9 @@ if [ "${engine}" == "source" ]||[ "${gamename}" == "Rust" ]||[ "${gamename}" == currentopt+=( "${cmd_mods_install[@]}" "${cmd_mods_remove[@]}" "${cmd_mods_update[@]}" ) fi +## Installer +currentopt+=( "${cmd_install[@]}" "${cmd_auto_install[@]}" ) + ## Developer commands currentopt+=( "${cmd_dev_debug[@]}" ) if [ -f ".dev-debug" ]; then From f152d66d55af303bf4e15ee113da71573f685b24 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sun, 26 Feb 2017 15:03:56 +0000 Subject: [PATCH 09/33] altered the look slightly --- lgsm/functions/install_server_dir.sh | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/lgsm/functions/install_server_dir.sh b/lgsm/functions/install_server_dir.sh index 12762df57..426e25a2b 100644 --- a/lgsm/functions/install_server_dir.sh +++ b/lgsm/functions/install_server_dir.sh @@ -12,12 +12,11 @@ echo "" echo "Server Directory" echo "=================================" sleep 1 -echo "" -pwd -echo "" if [ -d "${filesdir}" ]; then fn_print_warning_nl "A server is already installed here." fi +pwd +echo "" if [ -z "${autoinstall}" ]; then if ! fn_prompt_yn "Continue?" Y; then exit From 753612106cc1c560f57dc8c6e3cf28c4bfa87185 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sun, 26 Feb 2017 20:31:46 +0000 Subject: [PATCH 10/33] Large refactor of command_fastdl (not finished yet) improving the look and efficiency of teh code --- lgsm/functions/command_fastdl.sh | 481 ++++++++++++++++++------------- 1 file changed, 280 insertions(+), 201 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 5d20df759..3a85ed788 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -6,18 +6,11 @@ # Description: Creates a FastDL directory. local commandname="FASTDL" -local commandaction="FastDL Generator" +local commandaction="FastDL" local function_selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))" check.sh -# Only Source supports FastDL -if [ "${engine}" != "source" ]; then - fn_print_error "${gamename} does not support FastDL" - fn_script_log_error "${gamename} does not support FastDL" - core_exit.sh -fi - # Directories webdir="${rootdir}/public_html" fastdldir="${webdir}/fastdl" @@ -44,123 +37,90 @@ fn_check_bzip2(){ fi } -# Initiates FastDL -fn_fastdl_init(){ - fn_print_header - fn_script_log "Started FastDL Generator" - sleep 1 - fn_check_bzip2 - # User confirmation - if ! fn_prompt_yn "Build FastDL directory?" Y; then - exit - fi - fn_script_log "Initiating FastDL creation" - - # Check and create directories - if [ ! -d "${webdir}" ]; then - echo "" - fn_print_info "Creating FastDL directories" - echo -en "\n" - sleep 1 - fn_print_dots "Creating ${webdir} directory" - sleep 0.5 - mkdir "${webdir}" - fn_print_ok "Created ${webdir} directory" - fn_script_log "FastDL created ${webdir} directory" - sleep 1 - echo -en "\n" - fi - if [ ! -d "${fastdldir}" ]; then - # No directory, won't ask for removing old ones - newfastdl="true" - fn_print_dots "Creating fastdl directory" - sleep 0.5 - mkdir "${fastdldir}" - fn_print_ok "Created fastdl directory" - fn_script_log "Created fastdl directory" - sleep 1 - echo -en "\n" - clearoldfastdl="off" # Nothing to clear - elif [ "$(ls -A "${fastdldir}")" ]; then - newfastdl="false" - else - newfastdl="true" - fi -} - # Prompts user for FastDL creation settings fn_fastdl_config(){ - fn_print_info "Entering configuration" - fn_script_log "Configuration" - sleep 2 - echo -en "\n" + echo "FastDL setup" + echo "=================================" + # Prompt for clearing old files if directory was already here - if [ "${newfastdl}" == "false" ]; then - fn_print_dots - if fn_prompt_yn "Clear old FastDL files?" Y; then - clearoldfastdl="on"; fn_script_log "clearoldfastdl enabled"; fn_print_ok "Clearing Enabled" - else - clearoldfastdl="off"; fn_script_log "clearoldfastdl disabled"; fn_print_ok "Clearing Disabled" - fi - echo -en "\n" - fi - # Settings for bzip2 users - if [ ${bzip2installed} == 1 ]; then - # Prompt for using bzip2 if it's installed - fn_print_dots - if fn_prompt_yn "Enable bzip2 file compression?" Y; then - bzip2enable="on"; fn_script_log "bzip2 enabled"; fn_print_ok "bzip2 Enabled" - else - bzip2enable="off"; fn_script_log "bzip2 disabled"; fn_print_ok "bzip2 Disabled" - fi - echo -en "\n" - if [ "${gamename}" == "Garry's Mod" ]&&[ "${bzip2enable}" == "on" ]; then - # Prompt for clearing uncompressed files, can save some space but might cause issues for gmod - fn_print_dots - if fn_prompt_yn "Clear non-bzip2 FastDL files?" Y; then - clearnonbzip2="on"; fn_script_log "Clearing non-bzip2 files Enabled."; fn_print_ok "Clearing non-bzip2 files Enabled" - else - clearnonbzip2="off"; fn_script_log "Clearing non-bzip2 files Disabled."; fn_print_ok "Clearing non-bzip2 files Disabled" - fi - echo -en "\n" + if [ -d "${fastdldir}" ]; then + fn_print_warning_nl "FastDL directory already exists." + echo "${fastdldir}" + echo "" + if fn_prompt_yn "Overwrite existing directory?" Y; then + clearoldfastdl="on" else - # Other games default remove non bzip2 files - clearnonbzip2="on" - fn_script_log "Original uncompressed fastDL files won't be kept." + clearoldfastdl="off" fi fi + # Garry's Mod Specific if [ "${gamename}" == "Garry's Mod" ]; then # Prompt to clear addons dir from fastdl, can use unnecessary space or be required depending on addon's file structures fn_print_dots if fn_prompt_yn "Clear addons dir from fastdl dir?" Y; then - cleargmodaddons="on"; fn_script_log "Addons clearing Enabled."; fn_print_ok "Addons clearing Enabled" + cleargmodaddons="on"; else - cleargmodaddons="off"; fn_script_log "Addons clearing Disabled."; fn_print_ok "Addons clearing Disabled" + cleargmodaddons="off"; fi - echo -en "\n" + # Prompt for download enforcer, which is using a .lua addfile resource generator fn_print_dots if fn_prompt_yn "Use client download enforcer?" Y; then - luaressource="on"; fn_script_log "DL enforcer Enabled."; fn_print_ok "Enforcer Enabled" + luaressource="on" else - luaressource="off"; fn_script_log "DL enforcer Disabled."; fn_print_ok "Enforcer Disabled" + luaressource="off" fi - echo -en "\n" + fi +} + +fn_fastdl_dirs(){ + # Check and create directories + if [ ! -d "${modsdir}" ];then + echo -en "creating web directory ${webdir}..." + mkdir -p "${webdir}" + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "creating web directory ${webdir}..." + core_exit.sh + else + fn_print_ok_eol_nl + fn_script_log_pass "creating web directory ${webdir}..." + fi + sleep 0.5 + fi + if [ ! -d "${fastdldir}" ];then + echo -en "creating fastdl directory ${fastdldir}..." + mkdir -p "${fastdldir}" + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "creating fastdl directory ${fastdldir}..." + core_exit.sh + else + fn_print_ok_eol_nl + fn_script_log_pass "creating fastdl directory ${fastdldir}..." + fi + sleep 0.5 fi } fn_clear_old_fastdl(){ # Clearing old FastDL if user answered yes - if [ "${clearoldfastdl}" == "on" ]; then - fn_print_info "Clearing existing FastDL directory" - fn_script_log "Clearing existing FastDL directory" - sleep 0.5 + if [ ! -d "${modsdir}" ];then + echo -en "clearing existing FastDL directory ${fastdldir}..." rm -R "${fastdldir:?}"/* - fn_print_ok "Old FastDL directory cleared" - fn_script_log "Old FastDL directory cleared" - sleep 1 - echo -en "\n" + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "clearing existing FastDL directory ${fastdldir}..." + core_exit.sh + else + fn_print_ok_eol_nl + fn_script_log_pass "clearing existing FastDL directory ${fastdldir}..." + fi + sleep 0.5 fi } @@ -174,7 +134,7 @@ fn_fastdl_gmod(){ # No choice to cd to the directory, as find can't then display relative directory cd "${systemdir}" || exit - + # Map Files fn_print_dots "Copying map files..." fn_script_log "Copying map files" @@ -273,76 +233,206 @@ fn_fastdl_gmod(){ fi } +# Using this gist https://gist.github.com/agunnerson-ibm/efca449565a3e7356906 +fn_human_readable_file_size() { + local abbrevs=( + $((1 << 60)):ZB + $((1 << 50)):EB + $((1 << 40)):TB + $((1 << 30)):GB + $((1 << 20)):MB + $((1 << 10)):KB + $((1)):bytes + ) + + local bytes="${1}" + local precision="${2}" + + if [[ "${bytes}" == "1" ]]; then + echo "1 byte" + else + for item in "${abbrevs[@]}"; do + local factor="${item%:*}" + local abbrev="${item#*:}" + if [[ "${bytes}" -ge "${factor}" ]]; then + local size="$(bc -l <<< "${bytes} / ${factor}")" + printf "%.*f %s\n" "${precision}" "${size}" "${abbrev}" + break + fi + done + fi +} + fn_fastdl_source(){ # Copy all needed files for FastDL - echo "" - fn_print_dots "Starting gathering all needed files" - fn_script_log "Starting gathering all needed files" - sleep 1 - echo -en "\n" + if [ -n "${copyflag}" ]; then + # Removes all existing FastDL files. + if [ -d "${fastdldir}" ]; then + echo -e "removing existing FastDL files" + sleep 0.1 + fileswc=1 + totalfileswc=$(find "${fastdldir}" | wc -l) + tput sc + while read -r filetoremove; do + tput rc; tput el + printf "removing ${fileswc} / ${totalfileswc} : ${filetoremove}..." + ((fileswc++)) + rm -rf "${filetoremove}" + ((exitcode=$?)) + if [ ${exitcode} -ne 0 ]; then + fn_script_log_fatal "Removing ${filetoremove}" + break + else + fn_script_log_pass "Removing ${filetoremove}" + fi + sleep 0.01 + done < <(find "${fastdldir}") + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + core_exit.sh + else + fn_print_ok_eol_nl + fi + fi + fn_fastdl_dirs - # Map Files - fn_print_dots "Copying map files..." - fn_script_log "Copying map files" - sleep 0.5 - mkdir "${fastdldir}/maps" - find "${systemdir}/maps" -name '*.bsp' -exec cp {} "${fastdldir}/maps" \; - find "${systemdir}/maps" -name '*.ain' -exec cp {} "${fastdldir}/maps" \; - find "${systemdir}/maps" -name '*.nav' -exec cp {} "${fastdldir}/maps" \; - find "${systemdir}/maps" -name '*.jpg' -exec cp {} "${fastdldir}/maps" \; - find "${systemdir}/maps" -name '*.txt' -exec cp {} "${fastdldir}/maps" \; - fn_print_ok "Map files copied" - sleep 0.5 - echo -en "\n" + echo -e "copying files to ${fastdldir}" + fn_script_log "copying files to ${fastdldir}" + else + if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then + rm -f "${tmpdir}/fastdl_files_to_compress.txt" + fi + echo -e "analyzing required files" + fn_script_log "analyzing required files" + fi + + # Maps + if [ -d "${systemdir}/maps" ]; then + local allowed_extentions_array=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) + for allowed_extention in "${allowed_extentions_array[@]}" + do + fileswc=0 + tput sc + if [ -z "${copyflag}" ]; then + tput rc; tput el + printf "gathering maps ${allowed_extention} : ${fileswc}..." + fi + while read -r mapfile; do + ((fileswc++)) + if [ -n "${copyflag}" ]; then + tput rc; tput el + printf "copying maps ${allowed_extention} : ${fileswc}..." + if [ ! -d "${fastdldir}/maps" ]; then + mkdir "${fastdldir}/maps" + fi + cp "${mapfile}" "${fastdldir}/maps" + else + tput rc; tput el + printf "gathering maps ${allowed_extention} : ${fileswc}..." + sleep 0.01 + echo "${mapfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + fi + done < <(find "${systemdir}/maps" -type f -iname ${allowed_extention}) + + if [ -z "${copyflag}" ]; then + tput rc; tput el + printf "gathering maps ${allowed_extention} : ${fileswc}..." + fi + if [ ${fileswc} != 0 ]&&[ -n "${copyflag}" ]||[ -z "${copyflag}" ]; then + fn_print_ok_eol_nl + fi + done + fi # Materials - fn_print_dots "Copying materials..." - fn_script_log "Copying materials" - sleep 0.5 - mkdir "${fastdldir}/materials" - find "${systemdir}/materials" -name '*.vtf' -exec cp {} "${fastdldir}/materials" \; - find "${systemdir}/materials" -name '*.vmt' -exec cp {} "${fastdldir}/materials" \; - find "${systemdir}/materials" -name '*.vbf' -exec cp {} "${fastdldir}/materials" \; - fn_print_ok "Materials copied" - sleep 0.5 - echo -en "\n" + if [ -d "${systemdir}/materials" ]; then + local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) + for allowed_extention in "${allowed_extentions_array[@]}" + do + while read -r materialfile; do + ((totalfileswc++)) + echo -en "materials: ${allowed_extention} : ${totalfileswc}..." $'\r' + sleep 0.01 + echo "${materialfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + done < <(find "${systemdir}/materials" -type f -iname ${allowed_extention}) + echo -en "materials: ${allowed_extention} : ${totalfileswc}..." + fn_print_ok_eol_nl + totalfileswc=0 + done + fi # Models - fn_print_dots "Copying models..." - fn_script_log "Copying models" - sleep 1 - mkdir "${fastdldir}/models" - find "${systemdir}/models" -name '*.vtx' -exec cp {} "${fastdldir}/models" \; - find "${systemdir}/models" -name '*.vvd' -exec cp {} "${fastdldir}/models" \; - find "${systemdir}/models" -name '*.mdl' -exec cp {} "${fastdldir}/models" \; - find "${systemdir}/models" -name '*.phy' -exec cp {} "${fastdldir}/models" \; - find "${systemdir}/models" -name '*.jpg' -exec cp {} "${fastdldir}/models" \; - find "${systemdir}/models" -name '*.png' -exec cp {} "${fastdldir}/models" \; - fn_print_ok "Models copied" - sleep 0.5 - echo -en "\n" + if [ -d "${systemdir}/models" ]; then + local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) + for allowed_extention in "${allowed_extentions_array[@]}" + do + while read -r modelfile; do + ((totalfileswc++)) + echo -en "models: ${allowed_extention} : ${totalfileswc}..." $'\r' + sleep 0.01 + echo "${modelfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + done < <(find "${systemdir}/materials" -type f -iname ${allowed_extention}) + echo -en "models: ${allowed_extention} : ${totalfileswc}..." + fn_print_ok_eol_nl + totalfileswc=0 + done + fi # Particles - fn_print_dots "Copying particles..." - fn_script_log "Copying particles" - sleep 0.5 - mkdir "${fastdldir}/particles" - find "${systemdir}" -name '*.pcf' -exec cp {} "${fastdldir}/particles" \; - fn_print_ok "Particles copied" - sleep 0.5 - echo -en "\n" + if [ -d "${systemdir}/particles" ]; then + local allowed_extentions_array=( "*.pcf" ) + for allowed_extention in "${allowed_extentions_array[@]}" + do + while read -r particlefile; do + ((totalfileswc++)) + echo -en "models: ${allowed_extention} : ${totalfileswc}..." $'\r' + sleep 0.01 + echo "${particlefile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + done < <(find "${systemdir}/models" -type f -iname ${allowed_extention}) + echo -en "models: ${allowed_extention} : ${totalfileswc}..." + fn_print_ok_eol_nl + totalfileswc=0 + done + fi # Sounds - fn_print_dots "Copying sounds..." - fn_script_log "Copying sounds" - sleep 0.5 - mkdir "${fastdldir}/sound" - find "${systemdir}" -name '*.wav' -exec cp {} "${fastdldir}/sound" \; - find "${systemdir}" -name '*.mp3' -exec cp {} "${fastdldir}/sound" \; - find "${systemdir}" -name '*.ogg' -exec cp {} "${fastdldir}/sound" \; - fn_print_ok "Sounds copied" - sleep 0.5 - echo -en "\n" + if [ -d "${systemdir}/sounds" ]; then + local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.mdl" "*.phy" "*.jpg" "*.png" ) + for allowed_extention in "${allowed_extentions_array[@]}" + do + while read -r soundfile; do + ((totalfileswc++)) + echo -en "sounds: ${allowed_extention} : ${totalfileswc}..." $'\r' + sleep 0.01 + echo "${soundfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + done < <(find "${systemdir}/models" -type f -iname ${allowed_extention}) + echo -en "sounds: ${allowed_extention} : ${totalfileswc}..." + fn_print_ok_eol_nl + totalfileswc=0 + done + fi + +if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then + totalfiles=$(wc -l < "${tmpdir}/fastdl_files_to_compress.txt") + # Calculates total file size + while read dufile; do + filesize=$(du -b "${dufile}"| awk '{ print $1 }') + filesizetotal=$(( ${filesizetotal} + ${filesize} )) + done <"${tmpdir}/fastdl_files_to_compress.txt" +fi + +if [ -z "${copyflag}" ]; then + echo "about to compress ${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0) " + rm "${tmpdir}/fastdl_files_to_compress.txt" + if fn_prompt_yn "Continue?" Y; then + copyflag=1 + fn_fastdl_source + else + core_exit.sh + fi +else + fn_fastdl_bzip2 +fi } # Generate lua file that will force download any file into the FastDL directory @@ -387,59 +477,48 @@ fn_fastdl_gmod_lua_enforcer(){ } fn_fastdl_bzip2(){ - # Compressing using bzip2 if user said yes - echo "" - if [ ${bzip2enable} == "on" ]; then - fn_print_info "Have a break, this step could take a while..." - echo -en "\n" - echo "" - fn_print_dots "Compressing files using bzip2..." - fn_script_log "Compressing files using bzip2..." - # bzip2 all files that are not already compressed (keeping original files) - find "${fastdldir:?}" \( -type f ! -name "*.bz2" \) -exec bzip2 -qk \{\} \; - fn_print_ok "bzip2 compression done" - fn_script_log "bzip2 compression done" - sleep 1 - echo -en "\n" - # Clear non compressed FastDL files - if [ "${clearnonbzip2}" == "on" ]; then - fn_print_dots "Clearing original uncompressed FastDL files..." - sleep 1 - find "${fastdldir:?}" \( -type f ! -name "*.bz2" \) -exec rm {} \; - fn_print_ok "Cleared uncompressed FastDL files" - fn_script_log "Cleared uncompressed FastDL files." - fi - fi + while read -r filetocompress; do + echo -en "compressing ${filetocompress}..." + bzip2 "${filetocompress}" + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "creating web directory ${webdir}..." + core_exit.sh + else + fn_print_ok_eol_nl + fn_script_log_pass "creating web directory ${webdir}..." + fi + done < <(find "${fastdldir:?}" \( -type f ! -name "*.bz2" \)) } fn_fastdl_completed(){ # Finished message - echo "" - fn_print_ok "FastDL created!" - fn_script_log "FastDL job done" - sleep 2 - echo -en "\n" - echo "" - fn_print_info_nl "Need more documentation?" - echo " * https://github.com/GameServerManagers/LinuxGSM/wiki/FastDL" - echo -en "\n" - if [ "$bzip2installed" == "0" ]; then - echo "By the way, you'd better install bzip2 and re-run this command!" - fi - echo "Credits: UltimateByte" + echo "FastDL files are located in:" + echo "${webdir}" + echo "FastDL completed" + fn_script_log "FastDL completed" } +# Only Source supports FastDL +if [ "${engine}" != "source" ]; then + fn_print_fatal "${gamename} does not support FastDL" + fn_script_log_fatal "${gamename} does not support FastDL" + core_exit.sh +fi + # Run functions -fn_check_bzip2 -fn_fastdl_init +fn_print_header +echo "More info: https://git.io/vyk9a" +echo "" fn_fastdl_config -fn_clear_old_fastdl + + if [ "${gamename}" == "Garry's Mod" ]; then fn_fastdl_gmod fn_fastdl_gmod_lua_enforcer else fn_fastdl_source fi -fn_fastdl_bzip2 fn_fastdl_completed core_exit.sh From c4d31412a482509b8a59acce2b34bbdd82a6981b Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sun, 26 Feb 2017 21:20:28 +0000 Subject: [PATCH 11/33] Further improvements --- lgsm/functions/command_fastdl.sh | 140 ++++++++++++++++++++----------- 1 file changed, 89 insertions(+), 51 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 3a85ed788..76b9a4d69 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -308,7 +308,7 @@ fn_fastdl_source(){ # Maps if [ -d "${systemdir}/maps" ]; then - local allowed_extentions_array=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) + local allowed_extentions_array_=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) for allowed_extention in "${allowed_extentions_array[@]}" do fileswc=0 @@ -349,32 +349,36 @@ fn_fastdl_source(){ local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) for allowed_extention in "${allowed_extentions_array[@]}" do - while read -r materialfile; do - ((totalfileswc++)) - echo -en "materials: ${allowed_extention} : ${totalfileswc}..." $'\r' - sleep 0.01 - echo "${materialfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + fileswc=0 + tput sc + if [ -z "${copyflag}" ]; then + tput rc; tput el + printf "gathering materials ${allowed_extention} : ${fileswc}..." + fi + while read -r mapfile; do + ((fileswc++)) + if [ -n "${copyflag}" ]; then + tput rc; tput el + printf "copying materials ${allowed_extention} : ${fileswc}..." + if [ ! -d "${fastdldir}/materials" ]; then + mkdir "${fastdldir}/materials" + fi + cp "${mapfile}" "${fastdldir}/materials" + else + tput rc; tput el + printf "gathering materials ${allowed_extention} : ${fileswc}..." + sleep 0.01 + echo "${mapfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + fi done < <(find "${systemdir}/materials" -type f -iname ${allowed_extention}) - echo -en "materials: ${allowed_extention} : ${totalfileswc}..." - fn_print_ok_eol_nl - totalfileswc=0 - done - fi - # Models - if [ -d "${systemdir}/models" ]; then - local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) - for allowed_extention in "${allowed_extentions_array[@]}" - do - while read -r modelfile; do - ((totalfileswc++)) - echo -en "models: ${allowed_extention} : ${totalfileswc}..." $'\r' - sleep 0.01 - echo "${modelfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" - done < <(find "${systemdir}/materials" -type f -iname ${allowed_extention}) - echo -en "models: ${allowed_extention} : ${totalfileswc}..." - fn_print_ok_eol_nl - totalfileswc=0 + if [ -z "${copyflag}" ]; then + tput rc; tput el + printf "gathering materials ${allowed_extention} : ${fileswc}..." + fi + if [ ${fileswc} != 0 ]&&[ -n "${copyflag}" ]||[ -z "${copyflag}" ]; then + fn_print_ok_eol_nl + fi done fi @@ -383,15 +387,36 @@ fn_fastdl_source(){ local allowed_extentions_array=( "*.pcf" ) for allowed_extention in "${allowed_extentions_array[@]}" do - while read -r particlefile; do - ((totalfileswc++)) - echo -en "models: ${allowed_extention} : ${totalfileswc}..." $'\r' - sleep 0.01 - echo "${particlefile}" >> "${tmpdir}/fastdl_files_to_compress.txt" - done < <(find "${systemdir}/models" -type f -iname ${allowed_extention}) - echo -en "models: ${allowed_extention} : ${totalfileswc}..." - fn_print_ok_eol_nl - totalfileswc=0 + fileswc=0 + tput sc + if [ -z "${copyflag}" ]; then + tput rc; tput el + printf "gathering particles ${allowed_extention} : ${fileswc}..." + fi + while read -r mapfile; do + ((fileswc++)) + if [ -n "${copyflag}" ]; then + tput rc; tput el + printf "copying particles ${allowed_extention} : ${fileswc}..." + if [ ! -d "${fastdldir}/particles" ]; then + mkdir "${fastdldir}/particles" + fi + cp "${mapfile}" "${fastdldir}/particles" + else + tput rc; tput el + printf "gathering particles ${allowed_extention} : ${fileswc}..." + sleep 0.01 + echo "${mapfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + fi + done < <(find "${systemdir}/particles" -type f -iname ${allowed_extention}) + + if [ -z "${copyflag}" ]; then + tput rc; tput el + printf "gathering particles ${allowed_extention} : ${fileswc}..." + fi + if [ ${fileswc} != 0 ]&&[ -n "${copyflag}" ]||[ -z "${copyflag}" ]; then + fn_print_ok_eol_nl + fi done fi @@ -400,15 +425,36 @@ fn_fastdl_source(){ local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.mdl" "*.phy" "*.jpg" "*.png" ) for allowed_extention in "${allowed_extentions_array[@]}" do - while read -r soundfile; do - ((totalfileswc++)) - echo -en "sounds: ${allowed_extention} : ${totalfileswc}..." $'\r' - sleep 0.01 - echo "${soundfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" - done < <(find "${systemdir}/models" -type f -iname ${allowed_extention}) - echo -en "sounds: ${allowed_extention} : ${totalfileswc}..." - fn_print_ok_eol_nl - totalfileswc=0 + fileswc=0 + tput sc + if [ -z "${copyflag}" ]; then + tput rc; tput el + printf "gathering sounds ${allowed_extention} : ${fileswc}..." + fi + while read -r mapfile; do + ((fileswc++)) + if [ -n "${copyflag}" ]; then + tput rc; tput el + printf "copying soundss ${allowed_extention} : ${fileswc}..." + if [ ! -d "${fastdldir}/sounds" ]; then + mkdir "${fastdldir}/sounds" + fi + cp "${mapfile}" "${fastdldir}/sounds" + else + tput rc; tput el + printf "gathering sounds ${allowed_extention} : ${fileswc}..." + sleep 0.01 + echo "${mapfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + fi + done < <(find "${systemdir}/sounds" -type f -iname ${allowed_extention}) + + if [ -z "${copyflag}" ]; then + tput rc; tput el + printf "gathering sounds ${allowed_extention} : ${fileswc}..." + fi + if [ ${fileswc} != 0 ]&&[ -n "${copyflag}" ]||[ -z "${copyflag}" ]; then + fn_print_ok_eol_nl + fi done fi @@ -500,20 +546,12 @@ fn_fastdl_completed(){ fn_script_log "FastDL completed" } -# Only Source supports FastDL -if [ "${engine}" != "source" ]; then - fn_print_fatal "${gamename} does not support FastDL" - fn_script_log_fatal "${gamename} does not support FastDL" - core_exit.sh -fi - # Run functions fn_print_header echo "More info: https://git.io/vyk9a" echo "" fn_fastdl_config - if [ "${gamename}" == "Garry's Mod" ]; then fn_fastdl_gmod fn_fastdl_gmod_lua_enforcer From 96ac99b543c5148763a49b5757b2277f57a54e15 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Fri, 3 Mar 2017 17:35:53 +0000 Subject: [PATCH 12/33] merged copy code in to one --- lgsm/functions/command_fastdl.sh | 219 ++++++++----------------------- 1 file changed, 58 insertions(+), 161 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 76b9a4d69..6343e5ab7 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -306,179 +306,76 @@ fn_fastdl_source(){ fn_script_log "analyzing required files" fi - # Maps - if [ -d "${systemdir}/maps" ]; then - local allowed_extentions_array_=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) - for allowed_extention in "${allowed_extentions_array[@]}" - do - fileswc=0 - tput sc - if [ -z "${copyflag}" ]; then - tput rc; tput el - printf "gathering maps ${allowed_extention} : ${fileswc}..." + local directorys_array_=( "maps" "materials" "particles" "sounds" "*.txt" ) + for directory in "${directorys_array[@]}" + do + if [ -d "${systemdir}/${directory}" ]; then + if [ "${directory}" == "maps" ]; then + local allowed_extentions_array_=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) + elif [ "${directory}" == "materials" ]; then + local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) + elif [ "${directory}" == "particles" ]; then + local allowed_extentions_array=( "*.pcf" ) + elif [ "${directory}" == "sounds" ]; then + local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.mdl" "*.phy" "*.jpg" "*.png" ) fi - while read -r mapfile; do - ((fileswc++)) - if [ -n "${copyflag}" ]; then + for allowed_extention in "${allowed_extentions_array[@]}" + do + fileswc=0 + tput sc + if [ -z "${copyflag}" ]; then tput rc; tput el - printf "copying maps ${allowed_extention} : ${fileswc}..." - if [ ! -d "${fastdldir}/maps" ]; then - mkdir "${fastdldir}/maps" - fi - cp "${mapfile}" "${fastdldir}/maps" - else - tput rc; tput el - printf "gathering maps ${allowed_extention} : ${fileswc}..." - sleep 0.01 - echo "${mapfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + printf "gathering ${directory} ${allowed_extention} : ${fileswc}..." fi - done < <(find "${systemdir}/maps" -type f -iname ${allowed_extention}) - - if [ -z "${copyflag}" ]; then - tput rc; tput el - printf "gathering maps ${allowed_extention} : ${fileswc}..." - fi - if [ ${fileswc} != 0 ]&&[ -n "${copyflag}" ]||[ -z "${copyflag}" ]; then - fn_print_ok_eol_nl - fi - done - fi - - # Materials - if [ -d "${systemdir}/materials" ]; then - local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) - for allowed_extention in "${allowed_extentions_array[@]}" - do - fileswc=0 - tput sc - if [ -z "${copyflag}" ]; then - tput rc; tput el - printf "gathering materials ${allowed_extention} : ${fileswc}..." - fi - while read -r mapfile; do - ((fileswc++)) - if [ -n "${copyflag}" ]; then - tput rc; tput el - printf "copying materials ${allowed_extention} : ${fileswc}..." - if [ ! -d "${fastdldir}/materials" ]; then - mkdir "${fastdldir}/materials" + while read -r mapfile; do + ((fileswc++)) + if [ -n "${copyflag}" ]; then + tput rc; tput el + printf "copying ${directory} ${allowed_extention} : ${fileswc}..." + if [ ! -d "${fastdldir}/${directory}" ]; then + mkdir "${fastdldir}/${directory}" + fi + cp "${mapfile}" "${fastdldir}/${directory}" + else + tput rc; tput el + printf "gathering ${directory} ${allowed_extention} : ${fileswc}..." + sleep 0.01 + echo "${mapfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" fi - cp "${mapfile}" "${fastdldir}/materials" - else - tput rc; tput el - printf "gathering materials ${allowed_extention} : ${fileswc}..." - sleep 0.01 - echo "${mapfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" - fi - done < <(find "${systemdir}/materials" -type f -iname ${allowed_extention}) + done < <(find "${systemdir}/${directory}" -type f -iname ${allowed_extention}) - if [ -z "${copyflag}" ]; then - tput rc; tput el - printf "gathering materials ${allowed_extention} : ${fileswc}..." - fi - if [ ${fileswc} != 0 ]&&[ -n "${copyflag}" ]||[ -z "${copyflag}" ]; then - fn_print_ok_eol_nl - fi - done - fi - - # Particles - if [ -d "${systemdir}/particles" ]; then - local allowed_extentions_array=( "*.pcf" ) - for allowed_extention in "${allowed_extentions_array[@]}" - do - fileswc=0 - tput sc - if [ -z "${copyflag}" ]; then - tput rc; tput el - printf "gathering particles ${allowed_extention} : ${fileswc}..." - fi - while read -r mapfile; do - ((fileswc++)) - if [ -n "${copyflag}" ]; then + if [ -z "${copyflag}" ]; then tput rc; tput el - printf "copying particles ${allowed_extention} : ${fileswc}..." - if [ ! -d "${fastdldir}/particles" ]; then - mkdir "${fastdldir}/particles" - fi - cp "${mapfile}" "${fastdldir}/particles" - else - tput rc; tput el - printf "gathering particles ${allowed_extention} : ${fileswc}..." - sleep 0.01 - echo "${mapfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + printf "gathering ${directory} ${allowed_extention} : ${fileswc}..." fi - done < <(find "${systemdir}/particles" -type f -iname ${allowed_extention}) - - if [ -z "${copyflag}" ]; then - tput rc; tput el - printf "gathering particles ${allowed_extention} : ${fileswc}..." - fi - if [ ${fileswc} != 0 ]&&[ -n "${copyflag}" ]||[ -z "${copyflag}" ]; then - fn_print_ok_eol_nl - fi - done - fi - - # Sounds - if [ -d "${systemdir}/sounds" ]; then - local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.mdl" "*.phy" "*.jpg" "*.png" ) - for allowed_extention in "${allowed_extentions_array[@]}" - do - fileswc=0 - tput sc - if [ -z "${copyflag}" ]; then - tput rc; tput el - printf "gathering sounds ${allowed_extention} : ${fileswc}..." - fi - while read -r mapfile; do - ((fileswc++)) - if [ -n "${copyflag}" ]; then - tput rc; tput el - printf "copying soundss ${allowed_extention} : ${fileswc}..." - if [ ! -d "${fastdldir}/sounds" ]; then - mkdir "${fastdldir}/sounds" - fi - cp "${mapfile}" "${fastdldir}/sounds" - else - tput rc; tput el - printf "gathering sounds ${allowed_extention} : ${fileswc}..." - sleep 0.01 - echo "${mapfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + if [ ${fileswc} != 0 ]&&[ -n "${copyflag}" ]||[ -z "${copyflag}" ]; then + fn_print_ok_eol_nl fi - done < <(find "${systemdir}/sounds" -type f -iname ${allowed_extention}) - - if [ -z "${copyflag}" ]; then - tput rc; tput el - printf "gathering sounds ${allowed_extention} : ${fileswc}..." - fi - if [ ${fileswc} != 0 ]&&[ -n "${copyflag}" ]||[ -z "${copyflag}" ]; then - fn_print_ok_eol_nl - fi - done + done + fi + done + + if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then + totalfiles=$(wc -l < "${tmpdir}/fastdl_files_to_compress.txt") + # Calculates total file size + while read dufile; do + filesize=$(du -b "${dufile}"| awk '{ print $1 }') + filesizetotal=$(( ${filesizetotal} + ${filesize} )) + done <"${tmpdir}/fastdl_files_to_compress.txt" fi -if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then - totalfiles=$(wc -l < "${tmpdir}/fastdl_files_to_compress.txt") - # Calculates total file size - while read dufile; do - filesize=$(du -b "${dufile}"| awk '{ print $1 }') - filesizetotal=$(( ${filesizetotal} + ${filesize} )) - done <"${tmpdir}/fastdl_files_to_compress.txt" -fi - -if [ -z "${copyflag}" ]; then - echo "about to compress ${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0) " - rm "${tmpdir}/fastdl_files_to_compress.txt" - if fn_prompt_yn "Continue?" Y; then - copyflag=1 - fn_fastdl_source + if [ -z "${copyflag}" ]; then + echo "about to compress ${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0) " + rm "${tmpdir}/fastdl_files_to_compress.txt" + if fn_prompt_yn "Continue?" Y; then + copyflag=1 + fn_fastdl_source + else + core_exit.sh + fi else - core_exit.sh + fn_fastdl_bzip2 fi -else - fn_fastdl_bzip2 -fi } # Generate lua file that will force download any file into the FastDL directory From 91525dcbbf4cb235d1763b7573aadc25d1a7fd37 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Fri, 3 Mar 2017 17:37:26 +0000 Subject: [PATCH 13/33] added if --- lgsm/functions/command_fastdl.sh | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 6343e5ab7..e2c787ce1 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -366,7 +366,9 @@ fn_fastdl_source(){ if [ -z "${copyflag}" ]; then echo "about to compress ${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0) " - rm "${tmpdir}/fastdl_files_to_compress.txt" + if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then + rm "${tmpdir}/fastdl_files_to_compress.txt" + fi if fn_prompt_yn "Continue?" Y; then copyflag=1 fn_fastdl_source From 7ffe904a0609d1611234a7055a591786bda48a05 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Fri, 3 Mar 2017 17:57:39 +0000 Subject: [PATCH 14/33] fixes for fn_fastdl_source --- lgsm/functions/command_fastdl.sh | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index e2c787ce1..f0e09fd6d 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -306,12 +306,12 @@ fn_fastdl_source(){ fn_script_log "analyzing required files" fi - local directorys_array_=( "maps" "materials" "particles" "sounds" "*.txt" ) + local directorys_array=( "maps" "materials" "particles" "sounds" ) for directory in "${directorys_array[@]}" do if [ -d "${systemdir}/${directory}" ]; then if [ "${directory}" == "maps" ]; then - local allowed_extentions_array_=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) + local allowed_extentions_array=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) elif [ "${directory}" == "materials" ]; then local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) elif [ "${directory}" == "particles" ]; then @@ -366,9 +366,7 @@ fn_fastdl_source(){ if [ -z "${copyflag}" ]; then echo "about to compress ${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0) " - if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then - rm "${tmpdir}/fastdl_files_to_compress.txt" - fi + rm "${tmpdir}/fastdl_files_to_compress.txt" if fn_prompt_yn "Continue?" Y; then copyflag=1 fn_fastdl_source From 0abbe793be1e9af03becc8509617e6b940cc4e06 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Fri, 3 Mar 2017 21:49:48 +0000 Subject: [PATCH 15/33] Getting gmod version up and running --- lgsm/functions/command_fastdl.sh | 225 ++++++++++++------------------- 1 file changed, 83 insertions(+), 142 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index f0e09fd6d..dc39a3792 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -23,17 +23,9 @@ luafastdlfullpath="${luasvautorundir}/${luafastdlfile}" fn_check_bzip2(){ # Returns true if not installed if [ -z "$(command -v bzip2)" ]; then - bzip2installed="0" - fn_print_info "bzip2 is not installed! Install it to enable file compression" - fn_script_log_info "bzip2 is not installed. Install it to enable file compression." - fn_script_log_info "https://github.com/GameServerManagers/LinuxGSM/wiki/FastDL#bzip2-compression" - echo -en "\n" - sleep 1 - echo " * https://github.com/GameServerManagers/LinuxGSM/wiki/FastDL#bzip2-compression" - sleep 2 - echo "" - else - bzip2installed="1" + fn_print_fail "bzip2 is not installed" + fn_script_log_fatal "bzip2 is not installed" + core_exit.sh fi } @@ -56,9 +48,9 @@ fn_fastdl_config(){ # Garry's Mod Specific if [ "${gamename}" == "Garry's Mod" ]; then - # Prompt to clear addons dir from fastdl, can use unnecessary space or be required depending on addon's file structures + # Prompt to clear addons dir from fastdl, can use unnecessary space or not be required depending on addon's file structures fn_print_dots - if fn_prompt_yn "Clear addons dir from fastdl dir?" Y; then + if fn_prompt_yn "Clear addons directory from FastDL?" Y; then cleargmodaddons="on"; else cleargmodaddons="off"; @@ -125,111 +117,51 @@ fn_clear_old_fastdl(){ } fn_fastdl_gmod(){ - # Copy all needed files for FastDL - echo "" - fn_print_dots "Starting gathering all needed files" - fn_script_log "Starting gathering all needed files" - sleep 1 - echo -en "\n" - - # No choice to cd to the directory, as find can't then display relative directory - cd "${systemdir}" || exit - - # Map Files - fn_print_dots "Copying map files..." - fn_script_log "Copying map files" - sleep 0.5 - find . -name '*.bsp' | cpio --quiet -updm "${fastdldir}" - find . -name '*.ain' | cpio --quiet -updm "${fastdldir}" - fn_print_ok "Map files copied" - sleep 0.5 - echo -en "\n" - - # Materials - fn_print_dots "Copying materials..." - fn_script_log "Copying materials" - sleep 0.5 - find . -name '*.vtf' | cpio --quiet -updm "${fastdldir}" - find . -name '*.vmt' | cpio --quiet -updm "${fastdldir}" - fn_print_ok "Materials copied" - sleep 0.5 - echo -en "\n" - - # Models - fn_print_dots "Copying models..." - fn_script_log "Copying models" - sleep 1 - find . -name '*.vtx' | cpio --quiet -updm "${fastdldir}" - find . -name '*.vvd' | cpio --quiet -updm "${fastdldir}" - find . -name '*.mdl' | cpio --quiet -updm "${fastdldir}" - find . -name '*.phy' | cpio --quiet -updm "${fastdldir}" - fn_print_ok "Models copied" - sleep 0.5 - echo -en "\n" - - # Particles - fn_print_dots "Copying particles..." - fn_script_log "Copying particles" - sleep 0.5 - find . -name '*.pcf' | cpio --quiet -updm "${fastdldir}" - fn_print_ok "Particles copied" - sleep 0.5 - echo -en "\n" - - # Sounds - fn_print_dots "Copying sounds..." - fn_script_log "Copying sounds" - sleep 0.5 - find . -name '*.wav' | cpio --quiet -updm "${fastdldir}" - find . -name '*.mp3' | cpio --quiet -updm "${fastdldir}" - find . -name '*.ogg' | cpio --quiet -updm "${fastdldir}" - fn_print_ok "Sounds copied" - sleep 0.5 - echo -en "\n" - - # Resources (mostly fonts) - fn_print_dots "Copying fonts and png..." - fn_script_log "Copying fonts and png" - sleep 1 - find . -name '*.otf' | cpio --quiet -updm "${fastdldir}" - find . -name '*.ttf' | cpio --quiet -updm "${fastdldir}" - find . -name '*.png' | cpio --quiet -updm "${fastdldir}" - fn_print_ok "Fonts and png copied" - sleep 0.5 - echo -en "\n" - - # Going back to rootdir in order to prevent mistakes - cd "${rootdir}" - # Correct addons directory structure for FastDL if [ -d "${fastdldir}/addons" ]; then - fn_print_info "Adjusting addons' file structure" - fn_script_log "Adjusting addons' file structure" - sleep 1 + echo -en "updating addons file structure..." cp -Rf "${fastdldir}"/addons/*/* "${fastdldir}" - fn_print_ok "Adjusted addons' file structure" - sleep 1 - echo -en "\n" + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "updating addons file structure" + core_exit.sh + else + fn_print_ok_eol_nl + fn_script_log_pass "updating addons file structure" + fi # Clear addons directory in fastdl if [ "${cleargmodaddons}" == "on" ]; then - fn_print_info "Clearing addons dir from fastdl dir" - fn_script_log "Clearing addons dir from fastdl dir" + echo -en "clearing addons dir from fastdl dir" + fn_script_log "clearing addons dir from fastdl dir..." sleep 1 rm -R "${fastdldir:?}/addons" - fn_print_ok "Cleared addons dir from fastdl dir" - sleep 1 - echo -en "\n" + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "clearing addons dir from fastdl dir" + core_exit.sh + else + fn_print_ok_eol_nl + fn_script_log_pass "clearing addons dir from fastdl dir" + fi fi fi # Correct content that may be into a lua directory by mistake like some darkrpmodification addons if [ -d "${fastdldir}/lua" ]; then - fn_print_dots "Typical DarkRP files detected, fixing" + echo -en "correcting DarkRP files..." sleep 2 cp -Rf "${fastdldir}/lua/"* "${fastdldir}" - fn_print_ok "Stupid DarkRP file structure fixed" - sleep 2 - echo -en "\n" + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "correcting DarkRP files" + core_exit.sh + else + fn_print_ok_eol_nl + fn_script_log_pass "correcting DarkRP files" + fi fi } @@ -310,14 +242,30 @@ fn_fastdl_source(){ for directory in "${directorys_array[@]}" do if [ -d "${systemdir}/${directory}" ]; then - if [ "${directory}" == "maps" ]; then - local allowed_extentions_array=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) - elif [ "${directory}" == "materials" ]; then - local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) - elif [ "${directory}" == "particles" ]; then - local allowed_extentions_array=( "*.pcf" ) - elif [ "${directory}" == "sounds" ]; then - local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.mdl" "*.phy" "*.jpg" "*.png" ) + if [ "${gamename}" == "Garry's Mod" ]; then + if [ "${directory}" == "maps" ]; then + local allowed_extentions_array=( "*.bsp" "*.ain" ) + elif [ "${directory}" == "materials" ]; then + local allowed_extentions_array=( "*.vtf" "*.vmt" ) + elif [ "${directory}" == "models" ]; then + local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.phy" ) + elif [ "${directory}" == "particles" ]; then + local allowed_extentions_array=( "*.pcf" ) + elif [ "${directory}" == "sounds" ]; then + local allowed_extentions_array=( "*.wav" "*.mp3" "*.ogg" ) + elif [ "${directory}" == "resources" ]; then + local allowed_extentions_array=( "*.otf" "*.ttf" "*.png" ) + fi + else + if [ "${directory}" == "maps" ]; then + local allowed_extentions_array=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) + elif [ "${directory}" == "materials" ]; then + local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) + elif [ "${directory}" == "particles" ]; then + local allowed_extentions_array=( "*.pcf" ) + elif [ "${directory}" == "sounds" ]; then + local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.mdl" "*.phy" "*.jpg" "*.png" ) + fi fi for allowed_extention in "${allowed_extentions_array[@]}" do @@ -381,41 +329,36 @@ fn_fastdl_source(){ # Generate lua file that will force download any file into the FastDL directory fn_fastdl_gmod_lua_enforcer(){ # Remove lua file if luaressource is turned off and file exists - echo "" - if [ "${luaressource}" == "off" ]; then - if [ -f "${luafastdlfullpath}" ]; then - fn_print_dots "Removing download enforcer" - sleep 1 - rm -R "${luafastdlfullpath:?}" - fn_print_ok "Removed download enforcer" - fn_script_log "Removed old download inforcer" - echo -en "\n" - sleep 2 + if [ -f "${luafastdlfullpath}" ]; then + echo -en "removing existing download enforcer..." + rm -R "${luafastdlfullpath:?}" + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "removing existing download enforcer" + core_exit.sh + else + fn_print_ok_eol_nl + fn_script_log_pass "removing existing download enforcer" fi fi # Remove old lua file and generate a new one if user said yes if [ "${luaressource}" == "on" ]; then - if [ -f "${luafastdlfullpath}" ]; then - fn_print_dots "Removing old download enforcer" - sleep 1 - rm "${luafastdlfullpath}" - fn_print_ok "Removed old download enforcer" - fn_script_log "Removed old download enforcer" - echo -en "\n" - sleep 1 - fi - fn_print_dots "Generating new download enforcer" - fn_script_log "Generating new download enforcer" - sleep 1 + echo -en "creating new download enforcer..." + fn_script_log "creating new download enforcer" # Read all filenames and put them into a lua file at the right path find "${fastdldir:?}" \( -type f ! -name "*.bz2" \) -printf '%P\n' | while read line; do echo "resource.AddFile( "\""${line}"\"" )" >> "${luafastdlfullpath}" done - fn_print_ok "Download enforcer generated" - fn_script_log "Download enforcer generated" - echo -en "\n" - echo "" - sleep 2 + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "creating new download enforcer" + core_exit.sh + else + fn_print_ok_eol_nl + fn_script_log_pass "creating new download enforcer" + fi fi } @@ -448,12 +391,10 @@ fn_print_header echo "More info: https://git.io/vyk9a" echo "" fn_fastdl_config - +fn_fastdl_source if [ "${gamename}" == "Garry's Mod" ]; then fn_fastdl_gmod fn_fastdl_gmod_lua_enforcer -else - fn_fastdl_source fi fn_fastdl_completed core_exit.sh From a4f634dc034d368caefaafe529aeed46038f914f Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Fri, 3 Mar 2017 22:39:10 +0000 Subject: [PATCH 16/33] Further improvements downlaod enforcer currently broken --- lgsm/functions/command_fastdl.sh | 69 ++++++++++++++++++-------------- 1 file changed, 40 insertions(+), 29 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index dc39a3792..7179484cd 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -40,28 +40,30 @@ fn_fastdl_config(){ echo "${fastdldir}" echo "" if fn_prompt_yn "Overwrite existing directory?" Y; then - clearoldfastdl="on" + fn_script_log_info "Overwrite existing directory: YES" else - clearoldfastdl="off" + core_exit.sh fi fi # Garry's Mod Specific if [ "${gamename}" == "Garry's Mod" ]; then # Prompt to clear addons dir from fastdl, can use unnecessary space or not be required depending on addon's file structures - fn_print_dots if fn_prompt_yn "Clear addons directory from FastDL?" Y; then cleargmodaddons="on"; + fn_script_log_info "Clear addons directory from FastDL: YES" else cleargmodaddons="off"; + fn_script_log_info "Clear addons directory from FastDL: NO" fi # Prompt for download enforcer, which is using a .lua addfile resource generator - fn_print_dots if fn_prompt_yn "Use client download enforcer?" Y; then luaressource="on" + fn_script_log_info "Use client download enforcer: YES" else luaressource="off" + fn_script_log_info "Use client download enforcer: NO" fi fi } @@ -74,11 +76,11 @@ fn_fastdl_dirs(){ exitcode=$? if [ ${exitcode} -ne 0 ]; then fn_print_fail_eol_nl - fn_script_log_fatal "creating web directory ${webdir}..." + fn_script_log_fatal "Creating web directory ${webdir}" core_exit.sh else fn_print_ok_eol_nl - fn_script_log_pass "creating web directory ${webdir}..." + fn_script_log_pass "Creating web directory ${webdir}" fi sleep 0.5 fi @@ -88,11 +90,11 @@ fn_fastdl_dirs(){ exitcode=$? if [ ${exitcode} -ne 0 ]; then fn_print_fail_eol_nl - fn_script_log_fatal "creating fastdl directory ${fastdldir}..." + fn_script_log_fatal "Creating fastdl directory ${fastdldir}" core_exit.sh else fn_print_ok_eol_nl - fn_script_log_pass "creating fastdl directory ${fastdldir}..." + fn_script_log_pass "Creating fastdl directory ${fastdldir}" fi sleep 0.5 fi @@ -106,11 +108,11 @@ fn_clear_old_fastdl(){ exitcode=$? if [ ${exitcode} -ne 0 ]; then fn_print_fail_eol_nl - fn_script_log_fatal "clearing existing FastDL directory ${fastdldir}..." + fn_script_log_fatal "Clearing existing FastDL directory ${fastdldir}" core_exit.sh else fn_print_ok_eol_nl - fn_script_log_pass "clearing existing FastDL directory ${fastdldir}..." + fn_script_log_pass "Clearing existing FastDL directory ${fastdldir}" fi sleep 0.5 fi @@ -133,7 +135,6 @@ fn_fastdl_gmod(){ # Clear addons directory in fastdl if [ "${cleargmodaddons}" == "on" ]; then echo -en "clearing addons dir from fastdl dir" - fn_script_log "clearing addons dir from fastdl dir..." sleep 1 rm -R "${fastdldir:?}/addons" exitcode=$? @@ -147,7 +148,6 @@ fn_fastdl_gmod(){ fi fi fi - # Correct content that may be into a lua directory by mistake like some darkrpmodification addons if [ -d "${fastdldir}/lua" ]; then echo -en "correcting DarkRP files..." @@ -229,13 +229,13 @@ fn_fastdl_source(){ fn_fastdl_dirs echo -e "copying files to ${fastdldir}" - fn_script_log "copying files to ${fastdldir}" + fn_script_log_info "Copying files to ${fastdldir}" else if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then rm -f "${tmpdir}/fastdl_files_to_compress.txt" fi - echo -e "analyzing required files" - fn_script_log "analyzing required files" + echo -e "analysing required files" + fn_script_log_info "Analysing required files" fi local directorys_array=( "maps" "materials" "particles" "sounds" ) @@ -273,17 +273,26 @@ fn_fastdl_source(){ tput sc if [ -z "${copyflag}" ]; then tput rc; tput el - printf "gathering ${directory} ${allowed_extention} : ${fileswc}..." + printf "copying ${directory} ${allowed_extention} : ${fileswc}..." fi while read -r mapfile; do ((fileswc++)) if [ -n "${copyflag}" ]; then tput rc; tput el printf "copying ${directory} ${allowed_extention} : ${fileswc}..." + sleep 0.01 if [ ! -d "${fastdldir}/${directory}" ]; then mkdir "${fastdldir}/${directory}" fi cp "${mapfile}" "${fastdldir}/${directory}" + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "Copying ${mapfile} > ${fastdldir}/${directory}" + core_exit.sh + else + fn_script_log_pass "Copying ${mapfile} > ${fastdldir}/${directory}" + fi else tput rc; tput el printf "gathering ${directory} ${allowed_extention} : ${fileswc}..." @@ -313,7 +322,8 @@ fn_fastdl_source(){ fi if [ -z "${copyflag}" ]; then - echo "about to compress ${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0) " + echo "about to compress ${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0)" + fn_script_log_info "${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0)" rm "${tmpdir}/fastdl_files_to_compress.txt" if fn_prompt_yn "Continue?" Y; then copyflag=1 @@ -322,6 +332,9 @@ fn_fastdl_source(){ core_exit.sh fi else + if [ "${gamename}" == "Garry's Mod" ]; then + fn_fastdl_gmod_lua_enforcer + fi fn_fastdl_bzip2 fi } @@ -330,34 +343,33 @@ fn_fastdl_source(){ fn_fastdl_gmod_lua_enforcer(){ # Remove lua file if luaressource is turned off and file exists if [ -f "${luafastdlfullpath}" ]; then - echo -en "removing existing download enforcer..." + echo -en "removing existing download enforcer: ${luafastdlfile}..." rm -R "${luafastdlfullpath:?}" exitcode=$? if [ ${exitcode} -ne 0 ]; then fn_print_fail_eol_nl - fn_script_log_fatal "removing existing download enforcer" + fn_script_log_fatal "removing existing download enforcer ${luafastdlfullpath}" core_exit.sh else fn_print_ok_eol_nl - fn_script_log_pass "removing existing download enforcer" + fn_script_log_pass "removing existing download enforcer ${luafastdlfullpath}" fi fi # Remove old lua file and generate a new one if user said yes if [ "${luaressource}" == "on" ]; then - echo -en "creating new download enforcer..." - fn_script_log "creating new download enforcer" + echo -en "creating new download enforcer: ${luafastdlfile}..." # Read all filenames and put them into a lua file at the right path - find "${fastdldir:?}" \( -type f ! -name "*.bz2" \) -printf '%P\n' | while read line; do + find "${fastdldir:?}" \( -type f -name "*.bz2" \) -printf '%P\n' | while read line; do echo "resource.AddFile( "\""${line}"\"" )" >> "${luafastdlfullpath}" done exitcode=$? if [ ${exitcode} -ne 0 ]; then fn_print_fail_eol_nl - fn_script_log_fatal "creating new download enforcer" + fn_script_log_fatal "creating new download enforcer ${luafastdlfullpath}" core_exit.sh else fn_print_ok_eol_nl - fn_script_log_pass "creating new download enforcer" + fn_script_log_pass "creating new download enforcer ${luafastdlfullpath}" fi fi } @@ -369,11 +381,11 @@ fn_fastdl_bzip2(){ exitcode=$? if [ ${exitcode} -ne 0 ]; then fn_print_fail_eol_nl - fn_script_log_fatal "creating web directory ${webdir}..." + fn_script_log_fatal "compressing ${filetocompress}" core_exit.sh else fn_print_ok_eol_nl - fn_script_log_pass "creating web directory ${webdir}..." + fn_script_log_pass "compressing ${filetocompress}" fi done < <(find "${fastdldir:?}" \( -type f ! -name "*.bz2" \)) } @@ -383,7 +395,7 @@ fn_fastdl_completed(){ echo "FastDL files are located in:" echo "${webdir}" echo "FastDL completed" - fn_script_log "FastDL completed" + fn_script_log_info "FastDL completed" } # Run functions @@ -394,7 +406,6 @@ fn_fastdl_config fn_fastdl_source if [ "${gamename}" == "Garry's Mod" ]; then fn_fastdl_gmod - fn_fastdl_gmod_lua_enforcer fi fn_fastdl_completed core_exit.sh From 6a474dc6ad139441caeda2c6d92baf820d0fa606 Mon Sep 17 00:00:00 2001 From: UltimateByte Date: Sat, 4 Mar 2017 05:17:09 +0100 Subject: [PATCH 17/33] core_exit.sh --- lgsm/functions/command_dev_detect_deps.sh | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/lgsm/functions/command_dev_detect_deps.sh b/lgsm/functions/command_dev_detect_deps.sh index f709a4603..42ea13880 100644 --- a/lgsm/functions/command_dev_detect_deps.sh +++ b/lgsm/functions/command_dev_detect_deps.sh @@ -148,4 +148,6 @@ rm -f "${tmpdir}/.depdetect_ubuntu_list_uniq" rm -f "${tmpdir}/.depdetect_readelf" rm -f "${tmpdir}/.depdetect_unknown" -rm -f "${tmpdir}/.depdetect_unknown_uniq" \ No newline at end of file +rm -f "${tmpdir}/.depdetect_unknown_uniq" + +core_exit.sh From 7660f3a874e5c543e35bb510b4edf7af668efde3 Mon Sep 17 00:00:00 2001 From: UltimateByte Date: Sat, 4 Mar 2017 05:17:09 +0100 Subject: [PATCH 18/33] core_exit.sh --- lgsm/functions/command_dev_detect_glibc.sh | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/lgsm/functions/command_dev_detect_glibc.sh b/lgsm/functions/command_dev_detect_glibc.sh index 7703fba34..536a12c2a 100644 --- a/lgsm/functions/command_dev_detect_glibc.sh +++ b/lgsm/functions/command_dev_detect_glibc.sh @@ -37,4 +37,6 @@ while IFS= read -r -d $'\0' line; do done echo "" cat "${tmpdir}/detect_glibc.tmp"|sort|uniq|sort -r --version-sort -rm "${tmpdir}/detect_glibc.tmp" \ No newline at end of file +rm "${tmpdir}/detect_glibc.tmp" + +core_exit.sh From 7fe986a6876d2a9980e3be5690064f50b3600493 Mon Sep 17 00:00:00 2001 From: UltimateByte Date: Sat, 4 Mar 2017 05:17:10 +0100 Subject: [PATCH 19/33] core_exit.sh --- lgsm/functions/command_dev_detect_ldd.sh | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/lgsm/functions/command_dev_detect_ldd.sh b/lgsm/functions/command_dev_detect_ldd.sh index 16f1f9473..4e1c7b2b3 100644 --- a/lgsm/functions/command_dev_detect_ldd.sh +++ b/lgsm/functions/command_dev_detect_ldd.sh @@ -50,4 +50,6 @@ echo "=================================" cat "${tmpdir}/detect_ldd_not_found.tmp" rm "${tmpdir}/detect_ldd.tmp" -rm "${tmpdir}/detect_ldd_not_found.tmp" \ No newline at end of file +rm "${tmpdir}/detect_ldd_not_found.tmp" + +core_exit.sh From e51746e5b117fbb9da938c8ad84f0ffef41994c8 Mon Sep 17 00:00:00 2001 From: UltimateByte Date: Sat, 4 Mar 2017 05:33:47 +0100 Subject: [PATCH 20/33] proper exit (fix opt running after uf) --- lgsm/functions/core_getopt.sh | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/lgsm/functions/core_getopt.sh b/lgsm/functions/core_getopt.sh index 39efa37e4..d658397e2 100644 --- a/lgsm/functions/core_getopt.sh +++ b/lgsm/functions/core_getopt.sh @@ -174,12 +174,11 @@ for i in "${optcommands[@]}"; do if [ "$(echo "${currentopt[index]}"| awk -F ';' -v x=${currcmdindex} '{ print $x }')" == "${getopt}" ]; then # Run command ${currentopt[index+1]} + core_exit.sh break fi done done - break - core_exit.sh fi done @@ -187,4 +186,4 @@ done echo -e "${red}Unknown command${default}: $0 ${getopt}" exitcode=2 fn_opt_usage -core_exit.sh \ No newline at end of file +core_exit.sh From 1c06996cff4036a838b507ee5a581e9180646be4 Mon Sep 17 00:00:00 2001 From: UltimateByte Date: Sat, 4 Mar 2017 05:42:19 +0100 Subject: [PATCH 21/33] attempt to fix lua enforcer --- lgsm/functions/command_fastdl.sh | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 7179484cd..60c78fa18 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -341,10 +341,10 @@ fn_fastdl_source(){ # Generate lua file that will force download any file into the FastDL directory fn_fastdl_gmod_lua_enforcer(){ - # Remove lua file if luaressource is turned off and file exists + # Clear old lua file if [ -f "${luafastdlfullpath}" ]; then echo -en "removing existing download enforcer: ${luafastdlfile}..." - rm -R "${luafastdlfullpath:?}" + rm "${luafastdlfullpath:?}" exitcode=$? if [ ${exitcode} -ne 0 ]; then fn_print_fail_eol_nl @@ -355,9 +355,10 @@ fn_fastdl_gmod_lua_enforcer(){ fn_script_log_pass "removing existing download enforcer ${luafastdlfullpath}" fi fi - # Remove old lua file and generate a new one if user said yes + # Generate new one if user said yes if [ "${luaressource}" == "on" ]; then echo -en "creating new download enforcer: ${luafastdlfile}..." + touch "${luafastdlfullpath}" # Read all filenames and put them into a lua file at the right path find "${fastdldir:?}" \( -type f -name "*.bz2" \) -printf '%P\n' | while read line; do echo "resource.AddFile( "\""${line}"\"" )" >> "${luafastdlfullpath}" From 02b661adbb61fcd3896353804d9d586e0ee480d0 Mon Sep 17 00:00:00 2001 From: UltimateByte Date: Sat, 4 Mar 2017 05:49:54 +0100 Subject: [PATCH 22/33] lua ressource not bz2 ! --- lgsm/functions/command_fastdl.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 60c78fa18..3b695cf0e 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -360,7 +360,7 @@ fn_fastdl_gmod_lua_enforcer(){ echo -en "creating new download enforcer: ${luafastdlfile}..." touch "${luafastdlfullpath}" # Read all filenames and put them into a lua file at the right path - find "${fastdldir:?}" \( -type f -name "*.bz2" \) -printf '%P\n' | while read line; do + find "${fastdldir:?}" \( -type f ! -name "*.bz2" \) -printf '%P\n' | while read line; do echo "resource.AddFile( "\""${line}"\"" )" >> "${luafastdlfullpath}" done exitcode=$? From 394bfd59056a6a9db5f0d5a42abca09da7be8135 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sat, 4 Mar 2017 14:34:53 +0000 Subject: [PATCH 23/33] Added if statement for webdir allowing the user to change it Also added forgotten dirs for gmod --- lgsm/functions/command_fastdl.sh | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 3b695cf0e..0c4766704 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -12,7 +12,9 @@ local function_selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))" check.sh # Directories -webdir="${rootdir}/public_html" +if [ -z "${webdir}" ]; then + webdir="${lgsmdir}/public_html" +fi fastdldir="${webdir}/fastdl" addonsdir="${systemdir}/addons" # Server lua autorun dir, used to autorun lua on client connect to the server @@ -238,7 +240,7 @@ fn_fastdl_source(){ fn_script_log_info "Analysing required files" fi - local directorys_array=( "maps" "materials" "particles" "sounds" ) + local directorys_array=( "maps" "materials" "models" "particles" "sounds" "resources" ) for directory in "${directorys_array[@]}" do if [ -d "${systemdir}/${directory}" ]; then From 20f63bcc10ca809dd2ef99742a8d5a3f4c5ca451 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sat, 4 Mar 2017 23:18:31 +0000 Subject: [PATCH 24/33] Lots of garrys mod stuff --- lgsm/functions/command_fastdl.sh | 149 +++++++++++++++++++++++++------ 1 file changed, 121 insertions(+), 28 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 0c4766704..3fdd705c5 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -13,7 +13,7 @@ check.sh # Directories if [ -z "${webdir}" ]; then - webdir="${lgsmdir}/public_html" + webdir="${rootdir}/public_html" fi fastdldir="${webdir}/fastdl" addonsdir="${systemdir}/addons" @@ -121,6 +121,88 @@ fn_clear_old_fastdl(){ } fn_fastdl_gmod(){ + # Copy all needed files for FastDL + if [ -n "${copyflag}" ]; then + # Removes all existing FastDL files. + if [ -d "${fastdldir}" ]; then + echo -e "removing existing FastDL files" + sleep 0.1 + fileswc=1 + totalfileswc=$(find "${fastdldir}" | wc -l) + tput sc + while read -r filetoremove; do + tput rc; tput el + printf "removing ${fileswc} / ${totalfileswc} : ${filetoremove}..." + ((fileswc++)) + rm -rf "${filetoremove}" + ((exitcode=$?)) + if [ ${exitcode} -ne 0 ]; then + fn_script_log_fatal "Removing ${filetoremove}" + break + else + fn_script_log_pass "Removing ${filetoremove}" + fi + sleep 0.01 + done < <(find "${fastdldir}") + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + core_exit.sh + else + fn_print_ok_eol_nl + fi + fi + fn_fastdl_dirs + + echo -e "copying files to ${fastdldir}" + fn_script_log_info "Copying files to ${fastdldir}" + else + if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then + rm -f "${tmpdir}/fastdl_files_to_compress.txt" + fi + echo -e "analysing required files" + fn_script_log_info "Analysing required files" + fi + cd "${systemdir}" + local 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 + fileswc=0 + tput sc + if [ -z "${copyflag}" ]; then + tput rc; tput el + printf "copying ${directory} ${allowed_extention} : ${fileswc}..." + fi + while read -r ext; do + ((fileswc++)) + if [ -n "${copyflag}" ]; then + tput rc; tput el + printf "copying ${directory} ${allowed_extention} : ${fileswc}..." + sleep 0.01 + cp --parents "${ext}" "${fastdldir}" + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "Copying ${ext} > ${fastdldir}" + core_exit.sh + else + fn_script_log_pass "Copying ${ext} > ${fastdldir}" + fi + else + tput rc; tput el + printf "gathering ${directory} ${allowed_extention} : ${fileswc}..." + sleep 0.01 + echo "${ext}" >> "${tmpdir}/fastdl_files_to_compress.txt" + fi + done < <(find . -type f -iname ${allowed_extention}) + + if [ -z "${copyflag}" ]; then + tput rc; tput el + printf "gathering ${allowed_extention} : ${fileswc}..." + fi + if [ ${fileswc} != 0 ]&&[ -n "${copyflag}" ]||[ -z "${copyflag}" ]; then + fn_print_ok_eol_nl + fi + done # Correct addons directory structure for FastDL if [ -d "${fastdldir}/addons" ]; then echo -en "updating addons file structure..." @@ -136,7 +218,7 @@ fn_fastdl_gmod(){ fi # Clear addons directory in fastdl if [ "${cleargmodaddons}" == "on" ]; then - echo -en "clearing addons dir from fastdl dir" + echo -en "clearing addons dir from fastdl dir..." sleep 1 rm -R "${fastdldir:?}/addons" exitcode=$? @@ -165,6 +247,31 @@ fn_fastdl_gmod(){ fn_script_log_pass "correcting DarkRP files" fi fi + if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then + totalfiles=$(wc -l < "${tmpdir}/fastdl_files_to_compress.txt") + # Calculates total file size + while read dufile; do + filesize=$(du -b "${dufile}"| awk '{ print $1 }') + filesizetotal=$(( ${filesizetotal} + ${filesize} )) + done <"${tmpdir}/fastdl_files_to_compress.txt" + fi + + if [ -z "${copyflag}" ]; then + echo "about to compress ${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0)" + fn_script_log_info "${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0)" + rm "${tmpdir}/fastdl_files_to_compress.txt" + if fn_prompt_yn "Continue?" Y; then + copyflag=1 + fn_fastdl_gmod + else + core_exit.sh + fi + else + if [ "${gamename}" == "Garry's Mod" ]; then + fn_fastdl_gmod_lua_enforcer + fi + fn_fastdl_bzip2 + fi } # Using this gist https://gist.github.com/agunnerson-ibm/efca449565a3e7356906 @@ -244,30 +351,14 @@ fn_fastdl_source(){ for directory in "${directorys_array[@]}" do if [ -d "${systemdir}/${directory}" ]; then - if [ "${gamename}" == "Garry's Mod" ]; then - if [ "${directory}" == "maps" ]; then - local allowed_extentions_array=( "*.bsp" "*.ain" ) - elif [ "${directory}" == "materials" ]; then - local allowed_extentions_array=( "*.vtf" "*.vmt" ) - elif [ "${directory}" == "models" ]; then - local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.phy" ) - elif [ "${directory}" == "particles" ]; then - local allowed_extentions_array=( "*.pcf" ) - elif [ "${directory}" == "sounds" ]; then - local allowed_extentions_array=( "*.wav" "*.mp3" "*.ogg" ) - elif [ "${directory}" == "resources" ]; then - local allowed_extentions_array=( "*.otf" "*.ttf" "*.png" ) - fi - else - if [ "${directory}" == "maps" ]; then - local allowed_extentions_array=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) - elif [ "${directory}" == "materials" ]; then - local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) - elif [ "${directory}" == "particles" ]; then - local allowed_extentions_array=( "*.pcf" ) - elif [ "${directory}" == "sounds" ]; then - local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.mdl" "*.phy" "*.jpg" "*.png" ) - fi + if [ "${directory}" == "maps" ]; then + local allowed_extentions_array=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) + elif [ "${directory}" == "materials" ]; then + local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) + elif [ "${directory}" == "particles" ]; then + local allowed_extentions_array=( "*.pcf" ) + elif [ "${directory}" == "sounds" ]; then + local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.mdl" "*.phy" "*.jpg" "*.png" ) fi for allowed_extention in "${allowed_extentions_array[@]}" do @@ -380,7 +471,7 @@ fn_fastdl_gmod_lua_enforcer(){ fn_fastdl_bzip2(){ while read -r filetocompress; do echo -en "compressing ${filetocompress}..." - bzip2 "${filetocompress}" + bzip2 -f "${filetocompress}" exitcode=$? if [ ${exitcode} -ne 0 ]; then fn_print_fail_eol_nl @@ -406,9 +497,11 @@ fn_print_header echo "More info: https://git.io/vyk9a" echo "" fn_fastdl_config -fn_fastdl_source + if [ "${gamename}" == "Garry's Mod" ]; then fn_fastdl_gmod +else + fn_fastdl_source fi fn_fastdl_completed core_exit.sh From aeaa454814dbcb4d59f69857bde4b5e67b4872c9 Mon Sep 17 00:00:00 2001 From: UltimateByte Date: Sun, 5 Mar 2017 04:19:35 +0100 Subject: [PATCH 25/33] Missing github info for BladeSymphony --- BladeSymphony/bsserver | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/BladeSymphony/bsserver b/BladeSymphony/bsserver index b0eb68e9b..470221666 100644 --- a/BladeSymphony/bsserver +++ b/BladeSymphony/bsserver @@ -75,6 +75,13 @@ appid="228780" # Example: "-beta latest_experimental" branch="" +## Github Branch Select +# Allows for the use of different function files +# from a different repo and/or branch. +githubuser="GameServerManagers" +githubrepo="LinuxGSM" +githubbranch="master" + ## LinuxGSM Server Details # Do not edit gamename="Blade Symphony" From bf8ebfe3637d232cdd67b735343df9ab5a28f122 Mon Sep 17 00:00:00 2001 From: UltimateByte Date: Sun, 5 Mar 2017 08:04:31 +0100 Subject: [PATCH 26/33] Cleaning & fixes & functions rearranging --- lgsm/functions/command_fastdl.sh | 244 +++++++++++++------------------ 1 file changed, 100 insertions(+), 144 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 3fdd705c5..96f810c06 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -22,57 +22,97 @@ luasvautorundir="${systemdir}/lua/autorun/server" luafastdlfile="lgsm_cl_force_fastdl.lua" luafastdlfullpath="${luasvautorundir}/${luafastdlfile}" -fn_check_bzip2(){ - # Returns true if not installed - if [ -z "$(command -v bzip2)" ]; then - fn_print_fail "bzip2 is not installed" - fn_script_log_fatal "bzip2 is not installed" - core_exit.sh - fi -} +# Check if bzip2 is installed +if [ -z "$(command -v bzip2)" ]; then + fn_print_fail "bzip2 is not installed" + fn_script_log_fatal "bzip2 is not installed" + core_exit.sh +fi + +# Header +fn_print_header +echo "More info: https://git.io/vyk9a" +echo "" # Prompts user for FastDL creation settings -fn_fastdl_config(){ - echo "FastDL setup" - echo "=================================" +echo "${commandaction} setup" +echo "=================================" - # Prompt for clearing old files if directory was already here - if [ -d "${fastdldir}" ]; then - fn_print_warning_nl "FastDL directory already exists." - echo "${fastdldir}" - echo "" - if fn_prompt_yn "Overwrite existing directory?" Y; then - fn_script_log_info "Overwrite existing directory: YES" - else - core_exit.sh - fi +# Prompt for clearing old files if directory was already here +if [ -d "${fastdldir}" ]; then + fn_print_warning_nl "FastDL directory already exists." + echo "${fastdldir}" + echo "" + if fn_prompt_yn "Overwrite existing directory?" Y; then + fn_script_log_info "Overwrite existing directory: YES" + else + core_exit.sh fi +fi - # Garry's Mod Specific - if [ "${gamename}" == "Garry's Mod" ]; then - # Prompt to clear addons dir from fastdl, can use unnecessary space or not be required depending on addon's file structures - if fn_prompt_yn "Clear addons directory from FastDL?" Y; then - cleargmodaddons="on"; - fn_script_log_info "Clear addons directory from FastDL: YES" - else - cleargmodaddons="off"; - fn_script_log_info "Clear addons directory from FastDL: NO" - fi +# Garry's Mod Specific +if [ "${gamename}" == "Garry's Mod" ]; 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" + fn_script_log_info "Force clients to download files: YES" + else + luaresource="off" + fn_script_log_info "Force clients to download filesr: NO" + fi +fi + +fn_clear_old_fastdl(){ + # Clearing old FastDL + if [ -d "${fastdldir}" ];then + echo -en "clearing existing FastDL directory ${fastdldir}..." + rm -R "${fastdldir:?}"/* + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "Clearing existing FastDL directory ${fastdldir}" + core_exit.sh + else + fn_print_ok_eol_nl + fn_script_log_pass "Clearing existing FastDL directory ${fastdldir}" + fi + sleep 0.5 + fi +} - # Prompt for download enforcer, which is using a .lua addfile resource generator - if fn_prompt_yn "Use client download enforcer?" Y; then - luaressource="on" - fn_script_log_info "Use client download enforcer: YES" +fn_clear_old_fastdl_alt(){ + if [ -d "${fastdldir}" ]; then + echo -e "removing existing FastDL files" + sleep 0.1 + fileswc=1 + totalfileswc=$(find "${fastdldir}" | wc -l) + tput sc + while read -r filetoremove; do + tput rc; tput el + printf "removing ${fileswc} / ${totalfileswc} : ${filetoremove}..." + ((fileswc++)) + rm -rf "${filetoremove}" + ((exitcode=$?)) + if [ ${exitcode} -ne 0 ]; then + fn_script_log_fatal "Removing ${filetoremove}" + break + else + fn_script_log_pass "Removing ${filetoremove}" + fi + sleep 0.01 + done < <(find "${fastdldir}") + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + core_exit.sh else - luaressource="off" - fn_script_log_info "Use client download enforcer: NO" + fn_print_ok_eol_nl fi fi } fn_fastdl_dirs(){ # Check and create directories - if [ ! -d "${modsdir}" ];then + if [ ! -d "${webdir}" ];then echo -en "creating web directory ${webdir}..." mkdir -p "${webdir}" exitcode=$? @@ -102,57 +142,12 @@ fn_fastdl_dirs(){ fi } -fn_clear_old_fastdl(){ - # Clearing old FastDL if user answered yes - if [ ! -d "${modsdir}" ];then - echo -en "clearing existing FastDL directory ${fastdldir}..." - rm -R "${fastdldir:?}"/* - exitcode=$? - if [ ${exitcode} -ne 0 ]; then - fn_print_fail_eol_nl - fn_script_log_fatal "Clearing existing FastDL directory ${fastdldir}" - core_exit.sh - else - fn_print_ok_eol_nl - fn_script_log_pass "Clearing existing FastDL directory ${fastdldir}" - fi - sleep 0.5 - fi -} - fn_fastdl_gmod(){ # Copy all needed files for FastDL if [ -n "${copyflag}" ]; then - # Removes all existing FastDL files. - if [ -d "${fastdldir}" ]; then - echo -e "removing existing FastDL files" - sleep 0.1 - fileswc=1 - totalfileswc=$(find "${fastdldir}" | wc -l) - tput sc - while read -r filetoremove; do - tput rc; tput el - printf "removing ${fileswc} / ${totalfileswc} : ${filetoremove}..." - ((fileswc++)) - rm -rf "${filetoremove}" - ((exitcode=$?)) - if [ ${exitcode} -ne 0 ]; then - fn_script_log_fatal "Removing ${filetoremove}" - break - else - fn_script_log_pass "Removing ${filetoremove}" - fi - sleep 0.01 - done < <(find "${fastdldir}") - if [ ${exitcode} -ne 0 ]; then - fn_print_fail_eol_nl - core_exit.sh - else - fn_print_ok_eol_nl - fi - fi + # Clear previous FastDL dir + fn_clear_old_fastdl_alt fn_fastdl_dirs - echo -e "copying files to ${fastdldir}" fn_script_log_info "Copying files to ${fastdldir}" else @@ -217,19 +212,17 @@ fn_fastdl_gmod(){ fn_script_log_pass "updating addons file structure" fi # Clear addons directory in fastdl - if [ "${cleargmodaddons}" == "on" ]; then - echo -en "clearing addons dir from fastdl dir..." - sleep 1 - rm -R "${fastdldir:?}/addons" - exitcode=$? - if [ ${exitcode} -ne 0 ]; then - fn_print_fail_eol_nl - fn_script_log_fatal "clearing addons dir from fastdl dir" - core_exit.sh - else - fn_print_ok_eol_nl - fn_script_log_pass "clearing addons dir from fastdl dir" - fi + echo -en "clearing addons dir from fastdl dir..." + sleep 1 + rm -R "${fastdldir:?}/addons" + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "clearing addons dir from fastdl dir" + core_exit.sh + else + fn_print_ok_eol_nl + fn_script_log_pass "clearing addons dir from fastdl dir" fi fi # Correct content that may be into a lua directory by mistake like some darkrpmodification addons @@ -307,36 +300,8 @@ fn_human_readable_file_size() { fn_fastdl_source(){ # Copy all needed files for FastDL if [ -n "${copyflag}" ]; then - # Removes all existing FastDL files. - if [ -d "${fastdldir}" ]; then - echo -e "removing existing FastDL files" - sleep 0.1 - fileswc=1 - totalfileswc=$(find "${fastdldir}" | wc -l) - tput sc - while read -r filetoremove; do - tput rc; tput el - printf "removing ${fileswc} / ${totalfileswc} : ${filetoremove}..." - ((fileswc++)) - rm -rf "${filetoremove}" - ((exitcode=$?)) - if [ ${exitcode} -ne 0 ]; then - fn_script_log_fatal "Removing ${filetoremove}" - break - else - fn_script_log_pass "Removing ${filetoremove}" - fi - sleep 0.01 - done < <(find "${fastdldir}") - if [ ${exitcode} -ne 0 ]; then - fn_print_fail_eol_nl - core_exit.sh - else - fn_print_ok_eol_nl - fi - fi + fn_clear_old_fastdl_alt fn_fastdl_dirs - echo -e "copying files to ${fastdldir}" fn_script_log_info "Copying files to ${fastdldir}" else @@ -347,8 +312,8 @@ fn_fastdl_source(){ fn_script_log_info "Analysing required files" fi - local directorys_array=( "maps" "materials" "models" "particles" "sounds" "resources" ) - for directory in "${directorys_array[@]}" + local directories_array=( "maps" "materials" "models" "particles" "sounds" "resources" ) + for directory in "${directories_array[@]}" do if [ -d "${systemdir}/${directory}" ]; then if [ "${directory}" == "maps" ]; then @@ -449,7 +414,7 @@ fn_fastdl_gmod_lua_enforcer(){ fi fi # Generate new one if user said yes - if [ "${luaressource}" == "on" ]; then + if [ "${luaresource}" == "on" ]; then echo -en "creating new download enforcer: ${luafastdlfile}..." touch "${luafastdlfullpath}" # Read all filenames and put them into a lua file at the right path @@ -484,24 +449,15 @@ fn_fastdl_bzip2(){ done < <(find "${fastdldir:?}" \( -type f ! -name "*.bz2" \)) } -fn_fastdl_completed(){ - # Finished message - echo "FastDL files are located in:" - echo "${webdir}" - echo "FastDL completed" - fn_script_log_info "FastDL completed" -} - # Run functions -fn_print_header -echo "More info: https://git.io/vyk9a" -echo "" -fn_fastdl_config - if [ "${gamename}" == "Garry's Mod" ]; then fn_fastdl_gmod else fn_fastdl_source fi -fn_fastdl_completed +# Finished message +echo "FastDL files are located in:" +echo "${webdir}" +echo "FastDL completed" +fn_script_log_info "FastDL completed" core_exit.sh From 71dcf5937839f0bb1182d50fa076bdb0a16c0daf Mon Sep 17 00:00:00 2001 From: UltimateByte Date: Sun, 5 Mar 2017 08:22:33 +0100 Subject: [PATCH 27/33] Second pass cleaning & compressing output rework --- lgsm/functions/command_fastdl.sh | 17 ++++++----------- 1 file changed, 6 insertions(+), 11 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 96f810c06..d68d16c5e 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -259,11 +259,6 @@ fn_fastdl_gmod(){ else core_exit.sh fi - else - if [ "${gamename}" == "Garry's Mod" ]; then - fn_fastdl_gmod_lua_enforcer - fi - fn_fastdl_bzip2 fi } @@ -389,11 +384,6 @@ fn_fastdl_source(){ else core_exit.sh fi - else - if [ "${gamename}" == "Garry's Mod" ]; then - fn_fastdl_gmod_lua_enforcer - fi - fn_fastdl_bzip2 fi } @@ -434,8 +424,10 @@ fn_fastdl_gmod_lua_enforcer(){ } fn_fastdl_bzip2(){ + echo -en "compressing files..." + echo "" while read -r filetocompress; do - echo -en "compressing ${filetocompress}..." + echo -en "\r\033[Kcompressing ${filetocompress}..." bzip2 -f "${filetocompress}" exitcode=$? if [ ${exitcode} -ne 0 ]; then @@ -447,14 +439,17 @@ fn_fastdl_bzip2(){ fn_script_log_pass "compressing ${filetocompress}" fi done < <(find "${fastdldir:?}" \( -type f ! -name "*.bz2" \)) + echo "" } # Run functions if [ "${gamename}" == "Garry's Mod" ]; then fn_fastdl_gmod + fn_fastdl_gmod_lua_enforcer else fn_fastdl_source fi +fn_fastdl_bzip2 # Finished message echo "FastDL files are located in:" echo "${webdir}" From 1346393250489775739ef2eb3541f115918d137f Mon Sep 17 00:00:00 2001 From: UltimateByte Date: Sun, 5 Mar 2017 08:36:41 +0100 Subject: [PATCH 28/33] less compression output & clear tabs --- lgsm/functions/command_fastdl.sh | 37 ++++++++++++++++---------------- 1 file changed, 18 insertions(+), 19 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index d68d16c5e..c4495e99a 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -62,22 +62,22 @@ if [ "${gamename}" == "Garry's Mod" ]; then fi fi -fn_clear_old_fastdl(){ - # Clearing old FastDL - if [ -d "${fastdldir}" ];then - echo -en "clearing existing FastDL directory ${fastdldir}..." - rm -R "${fastdldir:?}"/* - exitcode=$? - if [ ${exitcode} -ne 0 ]; then - fn_print_fail_eol_nl - fn_script_log_fatal "Clearing existing FastDL directory ${fastdldir}" - core_exit.sh - else - fn_print_ok_eol_nl - fn_script_log_pass "Clearing existing FastDL directory ${fastdldir}" - fi - sleep 0.5 - fi +fn_clear_old_fastdl(){ + # Clearing old FastDL + if [ -d "${fastdldir}" ];then + echo -en "clearing existing FastDL directory ${fastdldir}..." + rm -R "${fastdldir:?}"/* + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "Clearing existing FastDL directory ${fastdldir}" + core_exit.sh + else + fn_print_ok_eol_nl + fn_script_log_pass "Clearing existing FastDL directory ${fastdldir}" + fi + sleep 0.5 + fi } fn_clear_old_fastdl_alt(){ @@ -435,11 +435,10 @@ fn_fastdl_bzip2(){ fn_script_log_fatal "compressing ${filetocompress}" core_exit.sh else - fn_print_ok_eol_nl fn_script_log_pass "compressing ${filetocompress}" fi done < <(find "${fastdldir:?}" \( -type f ! -name "*.bz2" \)) - echo "" + fn_print_ok_eol_nl } # Run functions @@ -452,7 +451,7 @@ fi fn_fastdl_bzip2 # Finished message echo "FastDL files are located in:" -echo "${webdir}" +echo "${fastdldir}" echo "FastDL completed" fn_script_log_info "FastDL completed" core_exit.sh From bbb95362346cf2a3ff7bb0e18d7848619871900c Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sun, 5 Mar 2017 15:09:08 +0000 Subject: [PATCH 29/33] directory not used here --- lgsm/functions/command_fastdl.sh | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index c4495e99a..4aa50fbe7 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -165,13 +165,13 @@ fn_fastdl_gmod(){ tput sc if [ -z "${copyflag}" ]; then tput rc; tput el - printf "copying ${directory} ${allowed_extention} : ${fileswc}..." + printf "copying ${allowed_extention} : ${fileswc}..." fi while read -r ext; do ((fileswc++)) if [ -n "${copyflag}" ]; then tput rc; tput el - printf "copying ${directory} ${allowed_extention} : ${fileswc}..." + printf "copying ${allowed_extention} : ${fileswc}..." sleep 0.01 cp --parents "${ext}" "${fastdldir}" exitcode=$? @@ -184,7 +184,7 @@ fn_fastdl_gmod(){ fi else tput rc; tput el - printf "gathering ${directory} ${allowed_extention} : ${fileswc}..." + printf "gathering ${allowed_extention} : ${fileswc}..." sleep 0.01 echo "${ext}" >> "${tmpdir}/fastdl_files_to_compress.txt" fi From a8ae8a43afdc0dd470050ce5146ad8abce510df8 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sun, 5 Mar 2017 15:13:06 +0000 Subject: [PATCH 30/33] minor tidy --- lgsm/functions/command_fastdl.sh | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 4aa50fbe7..fab1f38a8 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -63,8 +63,8 @@ if [ "${gamename}" == "Garry's Mod" ]; then fi fn_clear_old_fastdl(){ - # Clearing old FastDL - if [ -d "${fastdldir}" ];then + # Clearing old FastDL + if [ -d "${fastdldir}" ]; then echo -en "clearing existing FastDL directory ${fastdldir}..." rm -R "${fastdldir:?}"/* exitcode=$? @@ -112,7 +112,7 @@ fn_clear_old_fastdl_alt(){ fn_fastdl_dirs(){ # Check and create directories - if [ ! -d "${webdir}" ];then + if [ ! -d "${webdir}" ]; then echo -en "creating web directory ${webdir}..." mkdir -p "${webdir}" exitcode=$? @@ -126,7 +126,7 @@ fn_fastdl_dirs(){ fi sleep 0.5 fi - if [ ! -d "${fastdldir}" ];then + if [ ! -d "${fastdldir}" ]; then echo -en "creating fastdl directory ${fastdldir}..." mkdir -p "${fastdldir}" exitcode=$? From ae9d308084111fbdb0a5d25e674a8a5988ac0fd6 Mon Sep 17 00:00:00 2001 From: UltimateByte Date: Sun, 5 Mar 2017 22:22:51 +0100 Subject: [PATCH 31/33] major fastdl re-think --- lgsm/functions/command_fastdl.sh | 368 +++++++++++++++---------------- 1 file changed, 173 insertions(+), 195 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index fab1f38a8..be97474c6 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -62,13 +62,14 @@ if [ "${gamename}" == "Garry's Mod" ]; then fi fi +# Clears any fastdl directory content fn_clear_old_fastdl(){ # Clearing old FastDL if [ -d "${fastdldir}" ]; then echo -en "clearing existing FastDL directory ${fastdldir}..." - rm -R "${fastdldir:?}"/* + rm -R "${fastdldir:?}" exitcode=$? - if [ ${exitcode} -ne 0 ]; then + if [ "${exitcode}" -ne 0 ]; then fn_print_fail_eol_nl fn_script_log_fatal "Clearing existing FastDL directory ${fastdldir}" core_exit.sh @@ -80,36 +81,6 @@ fn_clear_old_fastdl(){ fi } -fn_clear_old_fastdl_alt(){ - if [ -d "${fastdldir}" ]; then - echo -e "removing existing FastDL files" - sleep 0.1 - fileswc=1 - totalfileswc=$(find "${fastdldir}" | wc -l) - tput sc - while read -r filetoremove; do - tput rc; tput el - printf "removing ${fileswc} / ${totalfileswc} : ${filetoremove}..." - ((fileswc++)) - rm -rf "${filetoremove}" - ((exitcode=$?)) - if [ ${exitcode} -ne 0 ]; then - fn_script_log_fatal "Removing ${filetoremove}" - break - else - fn_script_log_pass "Removing ${filetoremove}" - fi - sleep 0.01 - done < <(find "${fastdldir}") - if [ ${exitcode} -ne 0 ]; then - fn_print_fail_eol_nl - core_exit.sh - else - fn_print_ok_eol_nl - fi - fi -} - fn_fastdl_dirs(){ # Check and create directories if [ ! -d "${webdir}" ]; then @@ -142,59 +113,146 @@ fn_fastdl_dirs(){ fi } -fn_fastdl_gmod(){ - # Copy all needed files for FastDL - if [ -n "${copyflag}" ]; then - # Clear previous FastDL dir - fn_clear_old_fastdl_alt - fn_fastdl_dirs - echo -e "copying files to ${fastdldir}" - fn_script_log_info "Copying files to ${fastdldir}" +# Using this gist https://gist.github.com/agunnerson-ibm/efca449565a3e7356906 +fn_human_readable_file_size(){ + local abbrevs=( + $((1 << 60)):ZB + $((1 << 50)):EB + $((1 << 40)):TB + $((1 << 30)):GB + $((1 << 20)):MB + $((1 << 10)):KB + $((1)):bytes + ) + + local bytes="${1}" + local precision="${2}" + + if [[ "${bytes}" == "1" ]]; then + echo "1 byte" + else + for item in "${abbrevs[@]}"; do + local factor="${item%:*}" + local abbrev="${item#*:}" + if [[ "${bytes}" -ge "${factor}" ]]; then + local size="$(bc -l <<< "${bytes} / ${factor}")" + printf "%.*f %s\n" "${precision}" "${size}" "${abbrev}" + break + fi + done + fi +} + +# Provides info about the fastdl directory content and prompts for confirmation +fn_fastdl_preview(){ + # Remove any file list + if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then + rm -f "${tmpdir}/fastdl_files_to_compress.txt" + fi + echo -e "analysing required files" + fn_script_log_info "Analysing required files" + # Garry's Mod + if [ "${gamename}" == "Garry's Mod" ]; 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 + fileswc=0 + tput sc + while read -r ext; do + ((fileswc++)) + tput rc; tput el + printf "gathering ${allowed_extention} : ${fileswc}..." + echo "${ext}" >> "${tmpdir}/fastdl_files_to_compress.txt" + done < <(find . -type f -iname ${allowed_extention}) + if [ ${fileswc} != 0 ]; then + fn_print_ok_eol_nl + fi + done + # Source engine else - if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then - rm -f "${tmpdir}/fastdl_files_to_compress.txt" - fi - echo -e "analysing required files" - fn_script_log_info "Analysing required files" + fastdl_directories_array=( "maps" "materials" "models" "particles" "sounds" "resources" ) + for directory in "${fastdl_directories_array[@]}"; do + if [ -d "${systemdir}/${directory}" ]; then + if [ "${directory}" == "maps" ]; then + local allowed_extentions_array=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) + elif [ "${directory}" == "materials" ]; then + local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) + elif [ "${directory}" == "models" ]; then + local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.phy" "*.jpg" "*.png" ) + elif [ "${directory}" == "particles" ]; then + local allowed_extentions_array=( "*.pcf" ) + elif [ "${directory}" == "sounds" ]; then + local allowed_extentions_array=( "*.wav" "*.mp3" "*.ogg" ) + fi + for allowed_extention in "${allowed_extentions_array[@]}"; do + fileswc=0 + tput sc + while read -r ext; do + ((fileswc++)) + tput rc; tput el + printf "gathering ${directory} ${allowed_extention} : ${fileswc}..." + echo "${ext}" >> "${tmpdir}/fastdl_files_to_compress.txt" + done < <(find "${systemdir}/${directory}" -type f -iname ${allowed_extention}) + tput rc; tput el + printf "gathering ${directory} ${allowed_extention} : ${fileswc}..." + if [ ${fileswc} != 0 ]; then + fn_print_ok_eol_nl + fi + done + fi + done + fi + if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then + echo "calculating total file size..." + sleep 0.5 + totalfiles=$(wc -l < "${tmpdir}/fastdl_files_to_compress.txt") + # Calculates total file size + while read dufile; do + filesize=$(stat -c %s "${dufile}") + filesizetotal=$(( ${filesizetotal} + ${filesize} )) + exitcode=$? + if [ "${exitcode}" != 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "Calculating total file size." + core_exit.sh + fi + done <"${tmpdir}/fastdl_files_to_compress.txt" + else + fn_print_fail_eol_nl "generating file list" + fn_script_log_fatal "Generating file list." + core_exit.sh fi - cd "${systemdir}" - local allowed_extentions_array=( "*.ain" "*.bsp" "*.mdl" "*.mp3" "*.ogg" "*.otf" "*.pcf" "*.phy" "*.png" "*.vtf" "*.vmt" "*.vtx" "*.vvd" "*.ttf" "*.wav" ) + echo "about to compress ${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0)" + fn_script_log_info "${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0)" + rm "${tmpdir}/fastdl_files_to_compress.txt" + if ! fn_prompt_yn "Continue?" Y; then + fn_script_log "User exited" + core_exit.sh + fi +} + +# Builds Garry's Mod fastdl directory content +fn_fastdl_gmod(){ + cd "${systemdir}" || exit for allowed_extention in "${allowed_extentions_array[@]}" do fileswc=0 tput sc - if [ -z "${copyflag}" ]; then + while read -r fastdlfile; do + ((fileswc++)) tput rc; tput el printf "copying ${allowed_extention} : ${fileswc}..." - fi - while read -r ext; do - ((fileswc++)) - if [ -n "${copyflag}" ]; then - tput rc; tput el - printf "copying ${allowed_extention} : ${fileswc}..." - sleep 0.01 - cp --parents "${ext}" "${fastdldir}" - exitcode=$? - if [ ${exitcode} -ne 0 ]; then - fn_print_fail_eol_nl - fn_script_log_fatal "Copying ${ext} > ${fastdldir}" - core_exit.sh - else - fn_script_log_pass "Copying ${ext} > ${fastdldir}" - fi + cp --parents "${fastdlfile}" "${fastdldir}" + exitcode=$? + if [ ${exitcode} -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "Copying ${fastdlfile} > ${fastdldir}" + core_exit.sh else - tput rc; tput el - printf "gathering ${allowed_extention} : ${fileswc}..." - sleep 0.01 - echo "${ext}" >> "${tmpdir}/fastdl_files_to_compress.txt" + fn_script_log_pass "Copying ${fastdlfile} > ${fastdldir}" fi done < <(find . -type f -iname ${allowed_extention}) - - if [ -z "${copyflag}" ]; then - tput rc; tput el - printf "gathering ${allowed_extention} : ${fileswc}..." - fi - if [ ${fileswc} != 0 ]&&[ -n "${copyflag}" ]||[ -z "${copyflag}" ]; then + if [ ${fileswc} != 0 ]; then fn_print_ok_eol_nl fi done @@ -248,153 +306,74 @@ fn_fastdl_gmod(){ filesizetotal=$(( ${filesizetotal} + ${filesize} )) done <"${tmpdir}/fastdl_files_to_compress.txt" fi - - if [ -z "${copyflag}" ]; then - echo "about to compress ${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0)" - fn_script_log_info "${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0)" - rm "${tmpdir}/fastdl_files_to_compress.txt" - if fn_prompt_yn "Continue?" Y; then - copyflag=1 - fn_fastdl_gmod - else - core_exit.sh - fi - fi -} - -# Using this gist https://gist.github.com/agunnerson-ibm/efca449565a3e7356906 -fn_human_readable_file_size() { - local abbrevs=( - $((1 << 60)):ZB - $((1 << 50)):EB - $((1 << 40)):TB - $((1 << 30)):GB - $((1 << 20)):MB - $((1 << 10)):KB - $((1)):bytes - ) - - local bytes="${1}" - local precision="${2}" - - if [[ "${bytes}" == "1" ]]; then - echo "1 byte" - else - for item in "${abbrevs[@]}"; do - local factor="${item%:*}" - local abbrev="${item#*:}" - if [[ "${bytes}" -ge "${factor}" ]]; then - local size="$(bc -l <<< "${bytes} / ${factor}")" - printf "%.*f %s\n" "${precision}" "${size}" "${abbrev}" - break - fi - done - fi } fn_fastdl_source(){ - # Copy all needed files for FastDL - if [ -n "${copyflag}" ]; then - fn_clear_old_fastdl_alt - fn_fastdl_dirs - echo -e "copying files to ${fastdldir}" - fn_script_log_info "Copying files to ${fastdldir}" - else - if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then - rm -f "${tmpdir}/fastdl_files_to_compress.txt" - fi - echo -e "analysing required files" - fn_script_log_info "Analysing required files" - fi - - local directories_array=( "maps" "materials" "models" "particles" "sounds" "resources" ) - for directory in "${directories_array[@]}" + for directory in "${fastdl_directories_array[@]}" do if [ -d "${systemdir}/${directory}" ]; then if [ "${directory}" == "maps" ]; then local allowed_extentions_array=( "*.bsp" "*.ain" "*.nav" "*.jpg" "*.txt" ) elif [ "${directory}" == "materials" ]; then local allowed_extentions_array=( "*.vtf" "*.vmt" "*.vbf" ) + elif [ "${directory}" == "models" ]; then + local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.phy" "*.jpg" "*.png" ) elif [ "${directory}" == "particles" ]; then local allowed_extentions_array=( "*.pcf" ) elif [ "${directory}" == "sounds" ]; then - local allowed_extentions_array=( "*.vtx" "*.vvd" "*.mdl" "*.mdl" "*.phy" "*.jpg" "*.png" ) + local allowed_extentions_array=( "*.wav" "*.mp3" "*.ogg" ) fi for allowed_extention in "${allowed_extentions_array[@]}" do fileswc=0 tput sc - if [ -z "${copyflag}" ]; then + while read -r fastdlfile; do + ((fileswc++)) tput rc; tput el printf "copying ${directory} ${allowed_extention} : ${fileswc}..." - fi - while read -r mapfile; do - ((fileswc++)) - if [ -n "${copyflag}" ]; then - tput rc; tput el - printf "copying ${directory} ${allowed_extention} : ${fileswc}..." - sleep 0.01 - if [ ! -d "${fastdldir}/${directory}" ]; then - mkdir "${fastdldir}/${directory}" - fi - cp "${mapfile}" "${fastdldir}/${directory}" - exitcode=$? - if [ ${exitcode} -ne 0 ]; then - fn_print_fail_eol_nl - fn_script_log_fatal "Copying ${mapfile} > ${fastdldir}/${directory}" - core_exit.sh - else - fn_script_log_pass "Copying ${mapfile} > ${fastdldir}/${directory}" - fi + sleep 0.01 + if [ ! -d "${fastdldir}/${directory}" ]; then + mkdir "${fastdldir}/${directory}" + fi + cp "${fastdlfile}" "${fastdldir}/${directory}" + exitcode=$? + if [ "${exitcode}" -ne 0 ]; then + fn_print_fail_eol_nl + fn_script_log_fatal "Copying ${fastdlfile} > ${fastdldir}/${directory}" + core_exit.sh else - tput rc; tput el - printf "gathering ${directory} ${allowed_extention} : ${fileswc}..." - sleep 0.01 - echo "${mapfile}" >> "${tmpdir}/fastdl_files_to_compress.txt" + fn_script_log_pass "Copying ${fastdlfile} > ${fastdldir}/${directory}" fi done < <(find "${systemdir}/${directory}" -type f -iname ${allowed_extention}) - - if [ -z "${copyflag}" ]; then - tput rc; tput el - printf "gathering ${directory} ${allowed_extention} : ${fileswc}..." - fi - if [ ${fileswc} != 0 ]&&[ -n "${copyflag}" ]||[ -z "${copyflag}" ]; then + if [ ${fileswc} != 0 ]; then fn_print_ok_eol_nl fi done fi done +} - if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then - totalfiles=$(wc -l < "${tmpdir}/fastdl_files_to_compress.txt") - # Calculates total file size - while read dufile; do - filesize=$(du -b "${dufile}"| awk '{ print $1 }') - filesizetotal=$(( ${filesizetotal} + ${filesize} )) - done <"${tmpdir}/fastdl_files_to_compress.txt" - fi - - if [ -z "${copyflag}" ]; then - echo "about to compress ${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0)" - fn_script_log_info "${totalfiles} files, total size $(fn_human_readable_file_size ${filesizetotal} 0)" - rm "${tmpdir}/fastdl_files_to_compress.txt" - if fn_prompt_yn "Continue?" Y; then - copyflag=1 - fn_fastdl_source - else - core_exit.sh - fi +# Builds the fastdl directory content +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 + fn_fastdl_gmod + fn_fastdl_gmod_dl_enforcer + else + fn_fastdl_source fi } # Generate lua file that will force download any file into the FastDL directory -fn_fastdl_gmod_lua_enforcer(){ +fn_fastdl_gmod_dl_enforcer(){ # Clear old lua file if [ -f "${luafastdlfullpath}" ]; then echo -en "removing existing download enforcer: ${luafastdlfile}..." rm "${luafastdlfullpath:?}" exitcode=$? - if [ ${exitcode} -ne 0 ]; then + if [ "${exitcode}" -ne 0 ]; then fn_print_fail_eol_nl fn_script_log_fatal "removing existing download enforcer ${luafastdlfullpath}" core_exit.sh @@ -408,11 +387,11 @@ fn_fastdl_gmod_lua_enforcer(){ echo -en "creating new download enforcer: ${luafastdlfile}..." touch "${luafastdlfullpath}" # Read all filenames and put them into a lua file at the right path - find "${fastdldir:?}" \( -type f ! -name "*.bz2" \) -printf '%P\n' | while read line; do - echo "resource.AddFile( "\""${line}"\"" )" >> "${luafastdlfullpath}" - done + while read line; do + echo "resource.AddFile( \"${line}\" )" >> "${luafastdlfullpath}" + done < <(find "${fastdldir:?}" \( -type f ! -name "*.bz2" \) -printf '%P\n') exitcode=$? - if [ ${exitcode} -ne 0 ]; then + if [ "${exitcode}" -ne 0 ]; then fn_print_fail_eol_nl fn_script_log_fatal "creating new download enforcer ${luafastdlfullpath}" core_exit.sh @@ -423,6 +402,7 @@ fn_fastdl_gmod_lua_enforcer(){ fi } +# Compresses FastDL files using bzip2 fn_fastdl_bzip2(){ echo -en "compressing files..." echo "" @@ -430,7 +410,7 @@ fn_fastdl_bzip2(){ echo -en "\r\033[Kcompressing ${filetocompress}..." bzip2 -f "${filetocompress}" exitcode=$? - if [ ${exitcode} -ne 0 ]; then + if [ "${exitcode}" -ne 0 ]; then fn_print_fail_eol_nl fn_script_log_fatal "compressing ${filetocompress}" core_exit.sh @@ -442,12 +422,10 @@ fn_fastdl_bzip2(){ } # Run functions -if [ "${gamename}" == "Garry's Mod" ]; then - fn_fastdl_gmod - fn_fastdl_gmod_lua_enforcer -else - fn_fastdl_source -fi +fn_fastdl_preview +fn_clear_old_fastdl +fn_fastdl_dirs +fn_fastdl_build fn_fastdl_bzip2 # Finished message echo "FastDL files are located in:" From 62aa1c0cda50d9a15ec0b72fe9d34f1c2f58fdda Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sun, 5 Mar 2017 21:40:45 +0000 Subject: [PATCH 32/33] message not required --- lgsm/functions/command_fastdl.sh | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index be97474c6..0cd0012d6 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -228,7 +228,7 @@ fn_fastdl_preview(){ if ! fn_prompt_yn "Continue?" Y; then fn_script_log "User exited" core_exit.sh - fi + fi } # Builds Garry's Mod fastdl directory content @@ -404,8 +404,6 @@ fn_fastdl_gmod_dl_enforcer(){ # Compresses FastDL files using bzip2 fn_fastdl_bzip2(){ - echo -en "compressing files..." - echo "" while read -r filetocompress; do echo -en "\r\033[Kcompressing ${filetocompress}..." bzip2 -f "${filetocompress}" From c32be4e661c3495277a622a5c262534c9d66fac0 Mon Sep 17 00:00:00 2001 From: Daniel Gibbs Date: Sun, 5 Mar 2017 21:43:23 +0000 Subject: [PATCH 33/33] capitals for some log messages --- lgsm/functions/command_fastdl.sh | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/lgsm/functions/command_fastdl.sh b/lgsm/functions/command_fastdl.sh index 0cd0012d6..8d558a670 100644 --- a/lgsm/functions/command_fastdl.sh +++ b/lgsm/functions/command_fastdl.sh @@ -263,11 +263,11 @@ fn_fastdl_gmod(){ exitcode=$? if [ ${exitcode} -ne 0 ]; then fn_print_fail_eol_nl - fn_script_log_fatal "updating addons file structure" + fn_script_log_fatal "Updating addons file structure" core_exit.sh else fn_print_ok_eol_nl - fn_script_log_pass "updating addons file structure" + fn_script_log_pass "Updating addons file structure" fi # Clear addons directory in fastdl echo -en "clearing addons dir from fastdl dir..." @@ -276,11 +276,11 @@ fn_fastdl_gmod(){ exitcode=$? if [ ${exitcode} -ne 0 ]; then fn_print_fail_eol_nl - fn_script_log_fatal "clearing addons dir from fastdl dir" + fn_script_log_fatal "Clearing addons dir from fastdl dir" core_exit.sh else fn_print_ok_eol_nl - fn_script_log_pass "clearing addons dir from fastdl dir" + fn_script_log_pass "Clearing addons dir from fastdl dir" fi fi # Correct content that may be into a lua directory by mistake like some darkrpmodification addons @@ -291,11 +291,11 @@ fn_fastdl_gmod(){ exitcode=$? if [ ${exitcode} -ne 0 ]; then fn_print_fail_eol_nl - fn_script_log_fatal "correcting DarkRP files" + fn_script_log_fatal "Correcting DarkRP files" core_exit.sh else fn_print_ok_eol_nl - fn_script_log_pass "correcting DarkRP files" + fn_script_log_pass "Correcting DarkRP files" fi fi if [ -f "${tmpdir}/fastdl_files_to_compress.txt" ]; then @@ -375,11 +375,11 @@ fn_fastdl_gmod_dl_enforcer(){ exitcode=$? if [ "${exitcode}" -ne 0 ]; then fn_print_fail_eol_nl - fn_script_log_fatal "removing existing download enforcer ${luafastdlfullpath}" + fn_script_log_fatal "Removing existing download enforcer ${luafastdlfullpath}" core_exit.sh else fn_print_ok_eol_nl - fn_script_log_pass "removing existing download enforcer ${luafastdlfullpath}" + fn_script_log_pass "Removing existing download enforcer ${luafastdlfullpath}" fi fi # Generate new one if user said yes @@ -393,11 +393,11 @@ fn_fastdl_gmod_dl_enforcer(){ exitcode=$? if [ "${exitcode}" -ne 0 ]; then fn_print_fail_eol_nl - fn_script_log_fatal "creating new download enforcer ${luafastdlfullpath}" + fn_script_log_fatal "Creating new download enforcer ${luafastdlfullpath}" core_exit.sh else fn_print_ok_eol_nl - fn_script_log_pass "creating new download enforcer ${luafastdlfullpath}" + fn_script_log_pass "Creating new download enforcer ${luafastdlfullpath}" fi fi } @@ -410,10 +410,10 @@ fn_fastdl_bzip2(){ exitcode=$? if [ "${exitcode}" -ne 0 ]; then fn_print_fail_eol_nl - fn_script_log_fatal "compressing ${filetocompress}" + fn_script_log_fatal "Compressing ${filetocompress}" core_exit.sh else - fn_script_log_pass "compressing ${filetocompress}" + fn_script_log_pass "Compressing ${filetocompress}" fi done < <(find "${fastdldir:?}" \( -type f ! -name "*.bz2" \)) fn_print_ok_eol_nl