Browse Source

Major re-organise

This is a major sort out of the new functions. To simplify and make it easier to follow the code. All functionality remains.

Possible bugs in this that will be resolved after testing
pull/1255/head
Daniel Gibbs 8 years ago
parent
commit
f1dbdd6cc6
  1. 114
      lgsm/functions/command_mods_install.sh
  2. 65
      lgsm/functions/command_mods_remove.sh
  3. 128
      lgsm/functions/command_mods_update.sh
  4. 571
      lgsm/functions/mods_core.sh
  5. 4
      lgsm/functions/mods_list.sh

114
lgsm/functions/command_mods_install.sh

@ -9,17 +9,61 @@ local commandname="MODS"
local commandaction="addons/mods" local commandaction="addons/mods"
local function_selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))" local function_selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))"
fn_mods_install_init(){ check.sh
mods_core.sh
fn_print_header fn_print_header
# Display installed mods
fn_installed_mods_light_list # exits if no mods installed
fn_mods_check_installed
# Displays a list of installed mods
fn_mods_installed_list
if [ ${installedmodscount} -gt 0 ]; then
echo "Installed addons/mods"
echo "================================="
# Go through all available commands, get details and display them to the user
for ((llindex=0; llindex < ${#installedmodslist[@]}; llindex++)); do
# Current mod is the "llindex" value of the array we're going through
currentmod="${installedmodslist[llindex]}"
fn_mod_get_info
# Display mod info to the user
echo -e " * \e[1m${green}${modcommand}${default}${default}"
((totalmodsinstalled++))
done
echo ""
fi
echo "Available addons/mods" echo "Available addons/mods"
echo "=================================" echo "================================="
# Display available mods from mods_list.sh # Display available mods from mods_list.sh
fn_mods_show_available # Set and reset vars
compatiblemodslistindex=0
# As long as we're within index values
while [ "${compatiblemodslistindex}" -lt "${#compatiblemodslist[@]}" ]; do
# Set values for convenience
displayedmodname="${compatiblemodslist[compatiblemodslistindex]}"
displayedmodcommand="${compatiblemodslist[compatiblemodslistindex+1]}"
displayedmodsite="${compatiblemodslist[compatiblemodslistindex+2]}"
displayedmoddescription="${compatiblemodslist[compatiblemodslistindex+3]}"
# Output mods to the user
echo -e "\e[1m${displayedmodname}${default} - ${displayedmoddescription} - ${displayedmodsite}"
echo -e " * ${cyan}${displayedmodcommand}${default}"
# Increment index from the amount of values we just displayed
let "compatiblemodslistindex+=4"
((totalmods++))
done
# If no mods are available for a specific game
if [ -z "${compatiblemodslist}" ]; then
fn_print_fail "No mods are currently available for ${gamename}."
fn_script_log_info "No mods are currently available for ${gamename}."
core_exit.sh
fi
fn_script_log_info "${totalmods} addons/mods are available for install"
## User selects a mod
echo "" echo ""
# Keep prompting as long as the user input doesn't correspond to an available mod
while [[ ! " ${availablemodscommands[@]} " =~ " ${usermodselect} " ]]; do while [[ ! " ${availablemodscommands[@]} " =~ " ${usermodselect} " ]]; do
echo -en "Enter an ${cyan}addon/mod${default} to ${green}install${default} (or exit to abort): " echo -en "Enter an ${cyan}addon/mod${default} to ${green}install${default} (or exit to abort): "
read -r usermodselect read -r usermodselect
@ -31,45 +75,47 @@ fn_mods_install_init(){
fn_print_error2_nl "${usermodselect} is not a valid addon/mod." fn_print_error2_nl "${usermodselect} is not a valid addon/mod."
fi fi
done done
currentmod="${usermodselect}"
echo "" echo ""
echo "Installing ${modprettyname}" echo "Installing ${modprettyname}"
echo "=================================" echo "================================="
fn_script_log_info "${modprettyname} selected for install" fn_script_log_info "${modprettyname} selected for install"
# Gives a pretty name to the user and get all mod info
currentmod="${usermodselect}"
}
# Run all required operation # Check if the mod is already installed and warn the user
fn_mod_installation(){ if [ -f "${modsinstalledlistfullpath}" ]; then
# Get mod info if [ -n "$(sed -n "/^${modcommand}$/p" "${modsinstalledlistfullpath}")" ]; then
fn_mod_get_info_from_command fn_print_warning_nl "${modprettyname} is already installed"
# Check if mod is already installed fn_script_log_warn "${modprettyname} is already installed"
sleep 1
echo " * Any configs may be overwritten."
while true; do
read -e -i "y" -p "Continue? [Y/n]" yn
case $yn in
[Yy]* ) break;;
[Nn]* ) echo Exiting; core_exit.sh;;
* ) echo "Please answer yes or no.";;
esac
done
fi
fn_script_log_info "User selected to continue"
fi
## Installation
fn_mod_get_info
fn_mod_already_installed fn_mod_already_installed
# Check and create required files fn_create_mods_dir
fn_mods_files fn_mods_clear_tmp_dir
# Clear lgsm/tmp/mods dir if exists then recreate it fn_mods_create_tmp_dir
fn_clear_tmp_mods fn_mod_install_files
fn_mods_tmpdir
# Download & extract mod
fn_install_mod_dl_extract
# Convert to lowercase if needed
fn_mod_lowercase fn_mod_lowercase
# Build a file list fn_mod_create_filelist
fn_mod_fileslist
# Copying to destination
fn_mod_copy_destination fn_mod_copy_destination
# Ending with installation routines
fn_mod_add_list fn_mod_add_list
# Post install fixes fn_mod_tidy_files_list
fn_postinstall_tasks fn_mods_clear_tmp_dir
# Cleaning
fn_clear_tmp_mods
echo "${modprettyname} installed" echo "${modprettyname} installed"
fn_script_log_pass "${modprettyname} installed." fn_script_log_pass "${modprettyname} installed."
}
check.sh
mods_core.sh
fn_mods_install_init
fn_mod_installation
core_exit.sh core_exit.sh

65
lgsm/functions/command_mods_remove.sh

@ -9,21 +9,30 @@ local commandname="MODS"
local commandaction="addons/mods" local commandaction="addons/mods"
local function_selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))" local function_selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))"
check.sh
mods_core.sh
fn_mods_check_installed
fn_mods_remove_init(){
fn_print_header fn_print_header
echo "Remove addons/mods" echo "Remove addons/mods"
echo "=================================" echo "================================="
# A simple function to exit if no mods were installed
# Also returns ${installedmodscount} if mods were found ## Displays list of installed mods
fn_mods_exit_if_not_installed # Generates list to display to user
# Displays installed addons to the user fn_mods_installed_list
fn_installed_mods_medium_list for ((mlindex=0; mlindex < ${#installedmodslist[@]}; mlindex++)); do
# Current mod is the "mlindex" value of the array we are going through
currentmod="${installedmodslist[mlindex]}"
# Get mod info
fn_mod_get_info
# Display mod info to the user
echo -e "${cyan}${modcommand}${default} - \e[1m${modprettyname}${default} - ${moddescription}"
done
echo "" echo ""
# Keep prompting as long as the user input doesn't correspond to an available mod # Keep prompting as long as the user input doesn't correspond to an available mod
while [[ ! " ${installedmodslist[@]} " =~ " ${usermodselect} " ]]; do while [[ ! " ${installedmodslist[@]} " =~ " ${usermodselect} " ]]; do
echo -en "Enter a ${cyan}mod${default} to ${red}remove${default} (or exit to abort): " echo -en "Enter an ${cyan}addon/mod${default} to ${green}install${default} (or exit to abort): "
read -r usermodselect read -r usermodselect
# Exit if user says exit or abort # Exit if user says exit or abort
if [ "${usermodselect}" == "exit" ]||[ "${usermodselect}" == "abort" ]; then if [ "${usermodselect}" == "exit" ]||[ "${usermodselect}" == "abort" ]; then
@ -33,6 +42,7 @@ fn_mods_remove_init(){
fn_print_error2_nl "${usermodselect} is not a valid addon/mod." fn_print_error2_nl "${usermodselect} is not a valid addon/mod."
fi fi
done done
fn_print_warning_nl "You are about to remove ${cyan}${usermodselect}${default}." fn_print_warning_nl "You are about to remove ${cyan}${usermodselect}${default}."
echo " * Any custom files/configuration will be removed." echo " * Any custom files/configuration will be removed."
while true; do while true; do
@ -43,16 +53,12 @@ fn_mods_remove_init(){
* ) echo "Please answer yes or no.";; * ) echo "Please answer yes or no.";;
esac esac
done done
# Gives a pretty name to the user and get all mod info
currentmod="${usermodselect}"
fn_mod_get_info_from_command
# Check file list in order to make sure we're able to remove the mod (returns ${modsfilelistsize})
fn_check_files_list
} currentmod="${usermodselect}"
fn_mod_get_info
fn_check_mod_files_list
# Uninstall the mod # Uninstall the mod
fn_mod_remove_process(){
fn_script_log "Removing ${modsfilelistsize} files from ${modprettyname}" fn_script_log "Removing ${modsfilelistsize} files from ${modprettyname}"
echo -e "removing ${modprettyname}" echo -e "removing ${modprettyname}"
echo -e "* ${modsfilelistsize} files to be removed" echo -e "* ${modsfilelistsize} files to be removed"
@ -71,13 +77,11 @@ fn_mod_remove_process(){
local exitcode=$? local exitcode=$?
fi fi
tput rc; tput el tput rc; tput el
printf "removing ${modprettyname} ${totalfileswc} / ${modsfilelistsize} : ${currentfileremove}..." printf "removing ${modprettyname} ${modfileline} / ${modsfilelistsize} : ${currentfileremove}..."
((modfileline++))
((totalfileswc++))
let modfileline=modfileline+1
done done
tput rc; tput ed; tput rc; tput ed;
echo -ne "removing ${modprettyname} ${totalfileswc} / ${modsfilelistsize}..." echo -ne "removing ${modprettyname} ${modfileline} / ${modsfilelistsize}..."
if [ ${exitcode} -ne 0 ]; then if [ ${exitcode} -ne 0 ]; then
fn_print_fail_eol_nl fn_print_fail_eol_nl
core_exit.sh core_exit.sh
@ -85,6 +89,7 @@ fn_mod_remove_process(){
fn_print_ok_eol_nl fn_print_ok_eol_nl
fi fi
sleep 0.5 sleep 0.5
# Remove file list # Remove file list
echo -en "removing ${modcommand}-files.txt..." echo -en "removing ${modcommand}-files.txt..."
sleep 0.5 sleep 0.5
@ -97,12 +102,12 @@ fn_mod_remove_process(){
else else
fn_print_ok_eol_nl fn_print_ok_eol_nl
fi fi
# Remove from installed mods list
# Remove mods from installed mods list
echo -en "removing ${modcommand} from ${modslockfile}..." echo -en "removing ${modcommand} from ${modslockfile}..."
sleep 0.5 sleep 0.5
fn_script_log "Removing: ${modcommand} from ${modslockfilefullpath}" fn_script_log "Removing: ${modcommand} from ${modslockfilefullpath}"
sed -i "/^${modcommand}$/d" "${modslockfilefullpath}" sed -i "/^${modcommand}$/d" "${modslockfilefullpath}"
# Post install tasks to solve potential issues
local exitcode=$? local exitcode=$?
if [ ${exitcode} -ne 0 ]; then if [ ${exitcode} -ne 0 ]; then
fn_print_fail_eol_nl fn_print_fail_eol_nl
@ -110,13 +115,17 @@ fn_mod_remove_process(){
else else
fn_print_ok_eol_nl fn_print_ok_eol_nl
fi fi
fn_postuninstall_tasks
# Oxide fix
# Oxide replaces server files, so a validate is required after uninstall
if [ "${engine}" == "unity3d" ]&&[[ "${modprettyname}" == *"Oxide"* ]]; then
fn_print_information_nl "Validating to restore original ${gamename} files replaced by Oxide"
fn_script_log "Validating to restore original ${gamename} files replaced by Oxide"
exitbypass="1"
command_validate.sh
unset exitbypass
fi
echo "${modprettyname} removed" echo "${modprettyname} removed"
fn_script_log "${modprettyname} removed" fn_script_log "${modprettyname} removed"
}
check.sh
mods_core.sh
fn_mods_remove_init
fn_mod_remove_process
core_exit.sh core_exit.sh

128
lgsm/functions/command_mods_update.sh

@ -9,81 +9,107 @@ local commandname="MODS"
local commandaction="Mods Update" local commandaction="Mods Update"
local function_selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))" local function_selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))"
check.sh
mods_core.sh
fn_print_header
fn_mods_update_init(){ echo "Update addons/mods"
fn_script_log "Entering mods & addons update"
echo "=================================" echo "================================="
echo "${gamename} mods & addons update" fn_mods_check_installed
# A simple function to exit if no mods were installed fn_print_information_nl "${installedmodscount} addons/mods will be updated"
# Also returns ${installedmodscount} if mods were found
fn_mods_exit_if_not_installed
echo ""
fn_print_information_nl "${installedmodscount} mods or addons will be updated:"
fn_script_log_info "${installedmodscount} mods or addons will be updated" fn_script_log_info "${installedmodscount} mods or addons will be updated"
# Display a list of installed addons fn_mods_installed_list
fn_installed_mods_update_list echo ""
} echo "Installed addons/mods"
echo "================================="
# Go through all available commands, get details and display them to the user
for ((ulindex=0; ulindex < ${#installedmodslist[@]}; ulindex++)); do
# Current mod is the "ulindex" value of the array we're going through
currentmod="${installedmodslist[ulindex]}"
fn_mod_get_info
# Display installed mods and the update policy
if [ -z "${modkeepfiles}" ]; then
# If modkeepfiles is not set for some reason, that's a problem
fn_script_log_error "Couldn't find update policy for ${modprettyname}"
fn_print_error_nl "Couldn't find update policy for ${modprettyname}"
exitcode="1"
core_exit.sh
# If the mod won't get updated
elif [ "${modkeepfiles}" == "NOUPDATE" ]; then
echo -e " * \e[31m${modprettyname}${default} (won't be updated)"
# If the mode is just overwritten
elif [ "${modkeepfiles}" == "OVERWRITE" ]; then
echo -e " * \e[1m${modprettyname}${default} (overwrite)"
else
echo -e " * ${yellow}${modprettyname}${default} (common custom files remain untouched)"
fi
done
# Recursively list all installed mods and apply update ## Update
fn_mods_update_loop(){ # List all installed mods and apply update
# Reset line value # Reset line value
installedmodsline="1" installedmodsline="1"
while [ $installedmodsline -le $installedmodscount ]; do while [ ${installedmodsline} -le ${installedmodscount} ]; do
# Current line defines current mod command
currentmod="$(sed "${installedmodsline}q;d" "${modslockfilefullpath}")" currentmod="$(sed "${installedmodsline}q;d" "${modslockfilefullpath}")"
if [ -n "${currentmod}" ]; then if [ -n "${currentmod}" ]; then
# Get mod info fn_mod_get_info
fn_mod_get_info_from_command # Don not update mod if the policy is set to "NOUPDATE"
# Don't update the mod if it's policy is to "NOUPDATE"
if [ "${modkeepfiles}" == "NOUPDATE" ]; then if [ "${modkeepfiles}" == "NOUPDATE" ]; then
fn_print_info "${modprettyname} won't be updated to preserve custom files" fn_print_info "${modprettyname} will not be updated to preserve custom files"
fn_script_log "${modprettyname} won't be updated to preserve custom files." fn_script_log_info "${modprettyname} will not be updated to preserve custom files"
let installedmodsline=installedmodsline+1
else else
echo "" echo ""
fn_print_dots_nl "Updating ${modprettyname}" fn_create_mods_dir
fn_script_log "Updating ${modprettyname}." fn_mods_clear_tmp_dir
# Check and create required files fn_mods_create_tmp_dir
fn_mods_files fn_mod_install_files
# Clear lgsm/tmp/mods dir if exists then recreate it
fn_clear_tmp_mods
fn_mods_tmpdir
# Download mod
fn_mod_dl
# Extract the mod
fn_mod_extract
# Convert to lowercase if needed
fn_mod_lowercase fn_mod_lowercase
# Remove files that should not be erased
fn_remove_cfg_files fn_remove_cfg_files
# Build a file list fn_mod_create_filelist
fn_mod_fileslist
# Copying to destination
fn_mod_copy_destination fn_mod_copy_destination
# Ending with installation routines
fn_mod_add_list fn_mod_add_list
# Post install fixes fn_mod_tidy_files_list
fn_postinstall_tasks fn_mods_clear_tmp_dir
# Cleaning
fn_clear_tmp_mods
fn_print_ok "${modprettyname} updated"
fn_script_log "${modprettyname} updated."
let installedmodsline=installedmodsline+1
fi fi
((installedmodsline++))
else else
fn_print_fail "No mod was selected" fn_print_fail "No mod was selected"
fn_script_log_fail "No mod was selected." fn_script_log_fail "No mod was selected"
exitcode="1" exitcode="1"
core_exit.sh core_exit.sh
fi fi
done done
echo "" echo ""
fn_print_ok_nl "Mods update complete" fn_print_ok_nl "Mods update complete"
fn_script_log "Mods update complete." fn_script_log "Mods update complete"
# Prevents specific files being overwritten upon update (set by ${modkeepfiles})
# For that matter, remove cfg files after extraction before copying them to destination
fn_remove_cfg_files(){
if [ "${modkeepfiles}" != "OVERWRITE" ]&&[ "${modkeepfiles}" != "NOUPDATE" ]; then
fn_print_dots "Preventing overwriting of ${modprettyname} config files"
fn_script_log "Preventing overwriting of ${modprettyname} config files"
sleep 0.5
# Count how many files there are to remove
removefilesamount="$(echo "${modkeepfiles}" | awk -F ';' '{ print NF }')"
# Test all subvalues of "modkeepfiles" using the ";" separator
for ((removefilesindex=1; removefilesindex < ${removefilesamount}; removefilesindex++)); do
# Put the current file we are looking for into a variable
filetoremove="$( echo "${modkeepfiles}" | awk -F ';' -v x=${removefilesindex} '{ print $x }' )"
# If it matches an existing file that have been extracted delete the file
if [ -f "${extractdir}/${filetoremove}" ]||[ -d "${extractdir}/${filetoremove}" ]; then
rm -r "${extractdir}/${filetoremove}"
# Write the file path in a tmp file, to rebuild a full file list as it is rebuilt upon update
if [ ! -f "${modsdir}/.removedfiles.tmp" ]; then
touch "${modsdir}/.removedfiles.tmp"
fi
echo "${filetoremove}" >> "${modsdir}/.removedfiles.tmp"
fi
done
fn_print_ok "Preventing overwriting of ${modprettyname} config files"
sleep 0.5
fi
} }
check.sh
mods_core.sh
fn_mods_update_init
fn_mods_update_loop
core_exit.sh core_exit.sh

571
lgsm/functions/mods_core.sh

@ -16,82 +16,17 @@ extractdir="${modstmpdir}/extract"
modsinstalledlist="installed-mods.txt" modsinstalledlist="installed-mods.txt"
modsinstalledlistfullpath="${modsdir}/${modsinstalledlist}" modsinstalledlistfullpath="${modsdir}/${modsinstalledlist}"
# Database initialisation
mods_list.sh
## Directory management
# Create mods files and directories if it doesn't exist
# Assuming the game is already installed as mods_list.sh checked for it.
fn_mods_files(){
# Create mod install directory
if [ ! -d "${modinstalldir}" ]; then
echo "creating mods install directory ${modinstalldir}..."
mkdir -p "${modinstalldir}"
exitcode=$?
if [ ${exitcode} -ne 0 ]; then
fn_print_fail_eol_nl
fn_script_log_fatal "Creating mod download dir ${modstmpdir}"
core_exit.sh
else
fn_print_ok_eol_nl
fn_script_log_pass "Creating mod download dir ${modstmpdir}"
fi
sleep 0.5
fi
# Create lgsm/data/${modsinstalledlist}
if [ ! -f "${modsinstalledlistfullpath}" ]; then
touch "${modsinstalledlistfullpath}"
fn_script_log "Created ${modsinstalledlistfullpath}"
fi
}
# Create tmp download mod directory ## Installation
fn_mods_tmpdir(){
if [ ! -d "${modstmpdir}" ]; then
mkdir -p "${modstmpdir}"
exitcode=$?
echo -ne "creating mod download dir ${modstmpdir}..."
if [ ${exitcode} -ne 0 ]; then
fn_print_fail_eol_nl
fn_script_log_fatal "Creating mod download dir ${modstmpdir}"
core_exit.sh
else
fn_print_ok_eol_nl
fn_script_log_pass "Creating mod download dir ${modstmpdir}"
fi
fi
}
# Clear contents of mod download directory when finished # Download management
fn_clear_tmp_mods(){ fn_mod_install_files(){
if [ -d "${modstmpdir}" ]; then
rm -r "${modstmpdir}"/*
exitcode=$?
if [ ${exitcode} -ne 0 ]; then
fn_print_fail_eol_nl
fn_script_log_fatal "Clearing mod download directory ${modstmpdir}"
core_exit.sh
else
fn_print_ok_eol_nl
fn_script_log_pass "Clearing mod download directory ${modstmpdir}"
fi
fi
# Clear temp file list as well
if [ -f "${modsdir}/.removedfiles.tmp" ]; then
rm "${modsdir}/.removedfiles.tmp"
fi
}
## Download management
fn_install_mod_dl_extract(){
fn_fetch_file "${modurl}" "${modstmpdir}" "${modfilename}" fn_fetch_file "${modurl}" "${modstmpdir}" "${modfilename}"
# Check if variable is valid checking if file has been downloaded and exists # Check if variable is valid checking if file has been downloaded and exists
if [ ! -f "${modstmpdir}/${modfilename}" ]; then if [ ! -f "${modstmpdir}/${modfilename}" ]; then
fn_print_failure "An issue occurred upon downloading ${modprettyname}" fn_print_failure "An issue occurred downloading ${modprettyname}"
fn_script_log_fail "An issue occurred downloading ${modprettyname}"
core_exit.sh core_exit.sh
fi fi
if [ ! -d "${extractdir}" ]; then if [ ! -d "${extractdir}" ]; then
@ -132,60 +67,29 @@ fn_mod_lowercase(){
fi fi
} }
# Don't overwrite specified files upon update (set by ${modkeepfiles})
# For that matter, remove cfg files after extraction before copying them to destination
fn_remove_cfg_files(){
if [ "${modkeepfiles}" != "OVERWRITE" ]&&[ "${modkeepfiles}" != "NOUPDATE" ]; then
fn_print_dots "Allow for not overwriting ${modprettyname} config files"
fn_script_log "Allow for not overwriting ${modprettyname} config files"
sleep 0.5
# Let's count how many files there are to remove
removefilesamount="$(echo "${modkeepfiles}" | awk -F ';' '{ print NF }')"
# Test all subvalue of "modkeepfiles" using the ";" separator
for ((removefilesindex=1; removefilesindex < ${removefilesamount}; removefilesindex++)); do
# Put current file we're looking for into a variable
filetoremove="$( echo "${modkeepfiles}" | awk -F ';' -v x=${removefilesindex} '{ print $x }' )"
# If it matches an existing file that have been extracted
if [ -f "${extractdir}/${filetoremove}" ]||[ -d "${extractdir}/${filetoremove}" ]; then
# Then delete the file!
rm -r "${extractdir}/${filetoremove}"
# Write this file path in a tmp file, to rebuild a full file list since it is rebuilt upon update
if [ ! -f "${modsdir}/.removedfiles.tmp" ]; then
touch "${modsdir}/.removedfiles.tmp"
fi
echo "${filetoremove}" >> "${modsdir}/.removedfiles.tmp"
fi
done
fn_print_ok "Allow for preserving ${modprettyname} config files"
sleep 0.5
fi
}
# Create ${modcommand}-files.txt containing the full extracted file/directory list # Create ${modcommand}-files.txt containing the full extracted file/directory list
fn_mod_fileslist(){ fn_mod_create_filelist(){
echo -ne "building ${modcommand}-files.txt..." echo -ne "building ${modcommand}-files.txt..."
sleep 0.5 sleep 0.5
# ${modsdir}/${modcommand}-files.txt # ${modsdir}/${modcommand}-files.txt
find "${extractdir}" -mindepth 1 -printf '%P\n' > "${modsdir}"/${modcommand}-files.txt find "${extractdir}" -mindepth 1 -printf '%P\n' > "${modsdir}/${modcommand}-files.txt"
local exitcode=$? local exitcode=$?
if [ ${exitcode} -ne 0 ]; then if [ ${exitcode} -ne 0 ]; then
fn_print_fail_eol_nl fn_print_fail_eol_nl
fn_script_log_fatal "Building ${modcommand}-files.txt" fn_script_log_fatal "Building ${modsdir}/${modcommand}-files.txt"
core_exit.sh core_exit.sh
else else
fn_print_ok_eol_nl fn_print_ok_eol_nl
fn_script_log_pass "Building ${modcommand}-files.txt" fn_script_log_pass "Building ${modsdir}/${modcommand}-files.txt"
fi fi
fn_script_log "Writing file list ${modsdir}/${modcommand}-files.txt"
# Adding removed files if needed # Adding removed files if needed
if [ -f "${modsdir}/.removedfiles.tmp" ]; then if [ -f "${modsdir}/.removedfiles.tmp" ]; then
cat "${modsdir}/.removedfiles.tmp" >> "${modsdir}"/${modcommand}-files.txt cat "${modsdir}/.removedfiles.tmp" >> "${modsdir}/${modcommand}-files.txt"
fi fi
sleep 0.5 sleep 0.5
} }
# Copy the mod to the destination ${modinstalldir} # Copy the mod into serverfiles
fn_mod_copy_destination(){ fn_mod_copy_destination(){
echo -ne "copying ${modprettyname} to ${modinstalldir}..." echo -ne "copying ${modprettyname} to ${modinstalldir}..."
sleep 0.5 sleep 0.5
@ -200,75 +104,32 @@ fn_mod_copy_destination(){
fi fi
} }
# Check if the mod is already installed and warn the user # Add the mod to the installed-mods.txt
fn_mod_already_installed(){
if [ -f "${modsinstalledlistfullpath}" ]; then
if [ -n "$(sed -n "/^${modcommand}$/p" "${modsinstalledlistfullpath}")" ]; then
fn_print_warning_nl "${modprettyname} is already installed"
fn_script_log_warn "${modprettyname} is already installed"
sleep 1
echo " * Any configs may be overwritten."
while true; do
read -e -i "y" -p "Continue? [Y/n]" yn
case $yn in
[Yy]* ) break;;
[Nn]* ) echo Exiting; core_exit.sh;;
* ) echo "Please answer yes or no.";;
esac
done
fi
fn_script_log_info "User selected to continue"
fi
}
# Add the mod to the installed mods list
fn_mod_add_list(){ fn_mod_add_list(){
# Append modname to lockfile if it's not already in it
if [ ! -n "$(sed -n "/^${modcommand}$/p" "${modsinstalledlistfullpath}")" ]; then if [ ! -n "$(sed -n "/^${modcommand}$/p" "${modsinstalledlistfullpath}")" ]; then
echo "${modcommand}" >> "${modsinstalledlistfullpath}" echo "${modcommand}" >> "${modsinstalledlistfullpath}"
fn_script_log_info "${modcommand} added to ${modsinstalledlist}" fn_script_log_info "${modcommand} added to ${modsinstalledlist}"
fi fi
} }
fn_check_files_list(){ fn_mod_tidy_files_list(){
# File list must exist and be valid before any operation on it # Prevent sensitive directories from being erased by removing them from: ${modcommand}-files.txt
if [ -f "${modsdir}/${modcommand}-files.txt" ]; then
# How many lines is the file list
modsfilelistsize="$(cat "${modsdir}/${modcommand}-files.txt" | wc -l)"
# If file list is empty
if [ "${modsfilelistsize}" -eq 0 ]; then
fn_print_failure "${modcommand}-files.txt is empty"
echo "* Unable to remove ${modprettyname}"
fn_script_log_fatal "${modcommand}-files.txt is empty: Unable to remove ${modprettyname}."
core_exit.sh
fi
else
fn_print_failure "${modsdir}/${modcommand}-files.txt does not exist"
fn_script_log_fatal "${modsdir}/${modcommand}-files.txt does not exist: Unable to remove ${modprettyname}."
core_exit.sh
fi
}
# Apply some post-install fixes to make sure everything will be fine
fn_postinstall_tasks(){
# Prevent sensitive directories from being erased upon uninstall by removing them from: ${modsdir}/${modcommand}-files.txt
# Check file validity # Check file validity
fn_check_files_list fn_check_mod_files_list
# Output to the user # Output to the user
echo -ne "tidy up ${modcommand}-files.txt..." echo -ne "tidy up ${modcommand}-files.txt..."
sleep 0.5 sleep 0.5
fn_script_log_info "Rearranging ${modcommand}-files.txt" fn_script_log_info "Tidy up ${modcommand}-files.txt"
# What lines/files to remove from file list (end var with a ";" separator) # Lines/files to remove from file list (end with ";" separator)
removefromlist="cfg;addons;" removefromlist="cfg;addons;"
# Loop through files to remove from file list, # Loop through files to remove from file list,
# that way these files won't get removed upon uninstall # generate elements to remove from list
# How many elements to remove from list
removefromlistamount="$(echo "${removefromlist}" | awk -F ';' '{ print NF }')" removefromlistamount="$(echo "${removefromlist}" | awk -F ';' '{ print NF }')"
# Test all subvalue of "removefromlist" using the ";" separator # Test all subvalue of "removefromlist" using the ";" separator
for ((filesindex=1; filesindex < ${removefromlistamount}; filesindex++)); do for ((filesindex=1; filesindex < ${removefromlistamount}; filesindex++)); do
# Put current file into test variable # Put current file into test variable
removefilevar="$(echo "${removefromlist}" | awk -F ';' -v x=${filesindex} '{ print $x }')" removefilevar="$(echo "${removefromlist}" | awk -F ';' -v x=${filesindex} '{ print $x }')"
# Then delete matching line(s)! # Delete matching line(s)
sed -i "/^${removefilevar}$/d" "${modsdir}/${modcommand}-files.txt" sed -i "/^${removefilevar}$/d" "${modsdir}/${modcommand}-files.txt"
local exitcode=$? local exitcode=$?
if [ ${exitcode} -ne 0 ]; then if [ ${exitcode} -ne 0 ]; then
@ -290,30 +151,23 @@ fn_postinstall_tasks(){
fi fi
} }
# Apply some post-uninstall fixes to make sure everything will be fine ## Information Gathering
fn_postuninstall_tasks(){
# Oxide fix
# Oxide replaces server files, so a validate is required after uninstall
if [ "${engine}" == "unity3d" ]&&[[ "${modprettyname}" == *"Oxide"* ]]; then
fn_print_information_nl "Validating to restore original ${gamename} files replaced by Oxide"
fn_script_log "Validating to restore original ${gamename} files replaced by Oxide"
exitbypass="1"
command_validate.sh
unset exitbypass
fi
}
######################### # Get details of a mod any (relevant and unique, such as full mod name or install command) value
## mods_list.sh arrays ## fn_mod_get_info(){
######################### # Variable to know when job is done
modinfocommand="0"
## Define info for a mod # Find entry in global array
for ((index=0; index <= ${#mods_global_array[@]}; index++)); do
# Define all variables from a mod at once when index is set to a separator # When entry is found
fn_mod_info(){ if [ "${mods_global_array[index]}" == "${currentmod}" ]; then
# If for some reason no index is set, none of this can work # Go back to the previous "MOD" separator
for ((index=index; index <= ${#mods_global_array[@]}; index--)); do
# When "MOD" is found
if [ "${mods_global_array[index]}" == "MOD" ]; then
# Get info
if [ -z "$index" ]; then if [ -z "$index" ]; then
fn_print_error "index variable not set. Please report an issue to LGSM Team." fn_print_error "index variable not set. Please report an issue."
echo "* https://github.com/GameServerManagers/LinuxGSM/issues" echo "* https://github.com/GameServerManagers/LinuxGSM/issues"
exitcode="1" exitcode="1"
core_exit.sh core_exit.sh
@ -331,6 +185,78 @@ fi
modexcludegames="${mods_global_array[index+11]}" modexcludegames="${mods_global_array[index+11]}"
modsite="${mods_global_array[index+12]}" modsite="${mods_global_array[index+12]}"
moddescription="${mods_global_array[index+13]}" moddescription="${mods_global_array[index+13]}"
fi
modinfocommand="1"
break
fi
((totalmods++))
done
fi
# Exit the loop if job is done
if [ "${modinfocommand}" == "1" ]; then
break
fi
done
# What happens if mod is not found
if [ "${modinfocommand}" == "0" ]; then
fn_script_log_error "Could not find information for ${currentmod}"
fn_print_error_nl "Could not find information for ${currentmod}"
exitcode="1"
core_exit.sh
fi
}
# Builds list of installed mods
# using installed-mods.txt grabing mod info from mods_list.sh
fn_mods_installed_list(){
# Set/reset variables
installedmodsline="1"
installedmodslist=()
# Loop through every line of the installed mods list ${modsinstalledlistfullpath}
while [ ${installedmodsline} -le ${installedmodscount} ]; do
currentmod="$(sed "${installedmodsline}q;d" "${modsinstalledlistfullpath}")"
# Get mod info to make sure mod exists
fn_mod_get_info
# Add the mod to available commands
installedmodslist+=( "${modcommand}" )
# Increment line check
((installedmodsline++))
done
if [ -n "${totalmods}" ] ;then
fn_script_log_info "${totalmods} addons/mods are already installed"
fi
}
# Checks if a mod is compatible for installation
# Provides available mods for installation
# Provides commands for mods installation
fn_mods_available(){
# First, reset variables
compatiblemodslist=()
availablemodscommands=()
modprettynamemaxlength="0"
modsitemaxlength="0"
moddescriptionmaxlength="0"
modcommandmaxlength="0"
# Find compatible games
# Find separators through the global array
for ((index="0"; index <= ${#mods_global_array[@]}; index++)); do
# If current value is a separator; then
if [ "${mods_global_array[index]}" == "${modseparator}" ]; then
# Set mod variables
fn_mods_define
# Test if game is compatible
fn_mod_compatible_test
# If game is compatible
if [ "${modcompatibility}" == "1" ]; then
# Put it into an array to prepare user output
compatiblemodslist+=( "${modprettyname}" "${modcommand}" "${modsite}" "${moddescription}" )
# Keep available commands in an array to make life easier
availablemodscommands+=( "${modcommand}" )
fi
fi
done
} }
## Mod compatibility check ## Mod compatibility check
@ -413,236 +339,109 @@ fn_mod_compatible_test(){
fi fi
} }
# Checks if a mod is compatible for installation ## Directory management
# Provides available mods for installation
# Provides commands for mods installation
fn_mods_available(){
# First, reset variables
compatiblemodslist=()
availablemodscommands=()
modprettynamemaxlength="0"
modsitemaxlength="0"
moddescriptionmaxlength="0"
modcommandmaxlength="0"
# Find compatible games
# Find separators through the global array
for ((index="0"; index <= ${#mods_global_array[@]}; index++)); do
# If current value is a separator; then
if [ "${mods_global_array[index]}" == "${modseparator}" ]; then
# Set mod variables
fn_mod_info
# Test if game is compatible
fn_mod_compatible_test
# If game is compatible
if [ "${modcompatibility}" == "1" ]; then
# Put it into an array to prepare user output
compatiblemodslist+=( "${modprettyname}" "${modcommand}" "${modsite}" "${moddescription}" )
# Keep available commands in an array to make life easier
availablemodscommands+=( "${modcommand}" )
fi
fi
done
}
# Output available mods in a nice way to the user # Create mods files and directories if it doesn't exist
fn_mods_show_available(){ fn_create_mods_dir(){
# Set and reset vars # Create mod install directory
compatiblemodslistindex=0 if [ ! -d "${modinstalldir}" ]; then
# As long as we're within index values echo "creating mods install directory ${modinstalldir}..."
while [ "${compatiblemodslistindex}" -lt "${#compatiblemodslist[@]}" ]; do mkdir -p "${modinstalldir}"
# Set values for convenience exitcode=$?
displayedmodname="${compatiblemodslist[compatiblemodslistindex]}" if [ ${exitcode} -ne 0 ]; then
displayedmodcommand="${compatiblemodslist[compatiblemodslistindex+1]}" fn_print_fail_eol_nl
displayedmodsite="${compatiblemodslist[compatiblemodslistindex+2]}" fn_script_log_fatal "Creating mod download dir ${modinstalldir}"
displayedmoddescription="${compatiblemodslist[compatiblemodslistindex+3]}"
# Output mods to the user
echo -e "\e[1m${displayedmodname}${default} - ${displayedmoddescription} - ${displayedmodsite}"
echo -e " * ${cyan}${displayedmodcommand}${default}"
# Increment index from the amount of values we just displayed
let "compatiblemodslistindex+=4"
((totalmods++))
done
# If no mods are found
if [ -z "${compatiblemodslist}" ]; then
fn_print_fail "No mods are currently available for ${gamename}."
core_exit.sh core_exit.sh
else
fn_print_ok_eol_nl
fn_script_log_pass "Creating mod download dir ${modinstalldir}"
fi
sleep 0.5
fi fi
fn_script_log_info "${totalmods} addons/mods are available for install"
}
# Checks if mods have been installed # Create lgsm/data/${modsinstalledlist}
# Also returns ${installedmodscount} if mods were found if [ ! -f "${modsinstalledlistfullpath}" ]; then
fn_check_installed_mods(){ touch "${modsinstalledlistfullpath}"
# Count installed mods fn_script_log_info "Created ${modsinstalledlistfullpath}"
if [ -f "${modsinstalledlistfullpath}" ]; then
installedmodscount="$(cat "${modsinstalledlistfullpath}" | wc -l)"
fi fi
} }
# A simple function to exit if no mods were installed # Create tmp download mod directory
# Also returns ${installedmodscount} if mods were found fn_mods_create_tmp_dir(){
fn_mods_exit_if_not_installed(){ if [ ! -d "${modstmpdir}" ]; then
# Checks if mods have been installed mkdir -p "${modstmpdir}"
# Also returns ${installedmodscount} if mods were found exitcode=$?
fn_check_installed_mods echo -ne "creating mod download dir ${modstmpdir}..."
# If no mods lockfile is found or if it is empty if [ ${exitcode} -ne 0 ]; then
if [ ! -f "${modsinstalledlistfullpath}" ]||[ -z "${installedmodscount}" ]||[ ${installedmodscount} -le 0 ]; then fn_print_fail_eol_nl
fn_print_information_nl "No installed mods or addons were found" fn_script_log_fatal "Creating mod download dir ${modstmpdir}"
echo " * Install mods using LGSM first with: ./${selfname} mods-install"
fn_script_log_info "No installed mods or addons were found."
core_exit.sh core_exit.sh
else
fn_print_ok_eol_nl
fn_script_log_pass "Creating mod download dir ${modstmpdir}"
fi
fi fi
} }
# Builds installed mods list and sets available commands according to installed mods # Remove the tmp mod download directory when finished
# (requires ${installedmodscount} from fn_check_installed_mods) fn_mods_clear_tmp_dir(){
fn_mods_available_commands_from_installed(){ if [ -d "${modstmpdir}" ]; then
# Set/reset variables rm -r "${modstmpdir}"
installedmodsline="1" exitcode=$?
installedmodslist=() if [ ${exitcode} -ne 0 ]; then
# Loop through every line of the installed mods list ${modsinstalledlistfullpath} fn_print_fail_eol_nl
while [ ${installedmodsline} -le ${installedmodscount} ]; do fn_script_log_fatal "Clearing mod download directory ${modstmpdir}"
currentmod="$(sed "${installedmodsline}q;d" "${modsinstalledlistfullpath}")" core_exit.sh
# Get mod info to make sure mod exists else
fn_mod_get_info_from_command fn_print_ok_eol_nl
# Add the mod to available commands fn_script_log_pass "Clearing mod download directory ${modstmpdir}"
installedmodslist+=( "${modcommand}" )
# Increment line check
let installedmodsline=installedmodsline+1
done
if [ -n "${totalmods}" ] ;then
fn_script_log_info "${totalmods} addons/mods are already installed"
fi fi
}
# Displays a detailed list of installed mods fi
# Requires fn_check_installed_mods and fn_mods_available_commands_from_installed to run # Clear temp file list as well
fn_installed_mods_detailed_list(){ if [ -f "${modsdir}/.removedfiles.tmp" ]; then
fn_check_installed_mods rm "${modsdir}/.removedfiles.tmp"
fn_mods_available_commands_from_installed fi
# Were now based on ${installedmodslist} array's values
# We're gonna go through all available commands, get details and display them to the user
for ((dlindex=0; dlindex < ${#installedmodslist[@]}; dlindex++)); do
# Current mod is the "dlindex" value of the array we're going through
currentmod="${installedmodslist[dlindex]}"
# Get mod info
fn_mod_get_info_from_command
# Display mod info to the user
echo -e "\e[1m${modprettyname}${default} - ${moddescription} - ${modsite}"
echo -e " * ${cyan}${modcommand}${default}"
done
} }
# Displays a detailed list of installed mods
# Requires fn_check_installed_mods and fn_mods_available_commands_from_installed to run
fn_installed_mods_medium_list(){
fn_check_installed_mods
fn_mods_available_commands_from_installed
# Were now based on ${installedmodslist} array's values
# We're gonna go through all available commands, get details and display them to the user
for ((mlindex=0; mlindex < ${#installedmodslist[@]}; mlindex++)); do
# Current mod is the "mlindex" value of the array we're going through
currentmod="${installedmodslist[mlindex]}"
# Get mod info
fn_mod_get_info_from_command
# Display mod info to the user
echo -e "${cyan}${modcommand}${default} - \e[1m${modprettyname}${default} - ${moddescription}"
done
}
# Displays a simple list of installed mods # Exit if no mods were installed
# Requires fn_check_installed_mods and fn_mods_available_commands_from_installed to run fn_mods_check_installed(){
# This list is only displayed when some mods are installed # Count installed mods
fn_installed_mods_light_list(){ if [ -f "${modsinstalledlistfullpath}" ]; then
fn_check_installed_mods installedmodscount="$(cat "${modsinstalledlistfullpath}" | wc -l)"
fn_mods_available_commands_from_installed else
if [ "${installedmodscount}" -gt 0 ]; then installedmodscount=0
echo "Installed addons/mods"
echo "================================="
# Were now based on ${installedmodslist} array's values
# We're gonna go through all available commands, get details and display them to the user
for ((llindex=0; llindex < ${#installedmodslist[@]}; llindex++)); do
# Current mod is the "llindex" value of the array we're going through
currentmod="${installedmodslist[llindex]}"
# Get mod info
fn_mod_get_info_from_command
# Display simple mod info to the user
echo -e " * \e[1m${green}${modcommand}${default}${default}"
((totalmodsinstalled++))
done
echo ""
fi fi
} # If no mods are found
if [ ${installedmodscount} -eq 0 ]; then
# Displays a simple list of installed mods for mods-update command fn_print_information_nl "No installed mods or addons were found"
# Requires fn_check_installed_mods and fn_mods_available_commands_from_installed to run echo " * Install mods using LGSM first with: ./${selfname} mods-install"
fn_installed_mods_update_list(){ fn_script_log_info "No installed mods or addons were found."
fn_check_installed_mods
fn_mods_available_commands_from_installed
echo "================================="
echo "Installed addons/mods"
# Were now based on ${installedmodslist} array's values
# We're gonna go through all available commands, get details and display them to the user
for ((ulindex=0; ulindex < ${#installedmodslist[@]}; ulindex++)); do
# Current mod is the "ulindex" value of the array we're going through
currentmod="${installedmodslist[ulindex]}"
# Get mod info
fn_mod_get_info_from_command
# Display simple mod info to the user according to the update policy
# If modkeepfiles is not set for some reason, that's a problem
if [ -z "${modkeepfiles}" ]; then
fn_script_log_error "Couldn't find update policy for ${modprettyname}"
fn_print_error_nl "Couldn't find update policy for ${modprettyname}"
exitcode="1"
core_exit.sh core_exit.sh
# If the mod won't get updated
elif [ "${modkeepfiles}" == "NOUPDATE" ]; then
echo -e " * \e[31m${modprettyname}${default} (won't be updated)"
# If the mode is just overwritten
elif [ "${modkeepfiles}" == "OVERWRITE" ]; then
echo -e " * \e[1m${modprettyname}${default} (overwrite)"
else
echo -e " * ${yellow}${modprettyname}${default} (common custom files remain untouched)"
fi fi
done
} }
# Get details of a mod any (relevant and unique, such as full mod name or install command) value fn_check_mod_files_list(){
fn_mod_get_info_from_command(){ # File list must exist and be valid before any operation on it
# Variable to know when job is done if [ -f "${modsdir}/${modcommand}-files.txt" ]; then
modinfocommand="0" # How many lines is the file list
# Find entry in global array modsfilelistsize="$(cat "${modsdir}/${modcommand}-files.txt" | wc -l)"
for ((index=0; index <= ${#mods_global_array[@]}; index++)); do # If file list is empty
# When entry is found if [ "${modsfilelistsize}" -eq 0 ]; then
if [ "${mods_global_array[index]}" == "${currentmod}" ]; then fn_print_failure "${modcommand}-files.txt is empty"
# Go back to the previous "MOD" separator echo "* Unable to remove ${modprettyname}"
for ((index=index; index <= ${#mods_global_array[@]}; index--)); do fn_script_log_fatal "${modcommand}-files.txt is empty: Unable to remove ${modprettyname}."
# When "MOD" is found core_exit.sh
if [ "${mods_global_array[index]}" == "MOD" ]; then
# Get info
fn_mod_info
modinfocommand="1"
break
fi
((totalmods++))
done
fi
# Exit the loop if job is done
if [ "${modinfocommand}" == "1" ]; then
break
fi fi
done else
fn_print_failure "${modsdir}/${modcommand}-files.txt does not exist"
# What happens if mod is not found fn_script_log_fatal "${modsdir}/${modcommand}-files.txt does not exist: Unable to remove ${modprettyname}."
if [ "${modinfocommand}" == "0" ]; then
fn_script_log_error "Could not find information for ${currentmod}"
fn_print_error_nl "Could not find information for ${currentmod}"
exitcode="1"
core_exit.sh core_exit.sh
fi fi
} }
fn_mods_scrape_urls # Database initialisation
fn_mods_info mods_list.sh
mods_dir.sh
fn_mods_available fn_mods_available

4
lgsm/functions/mods_list.sh

@ -17,7 +17,6 @@ local function_selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))"
modseparator="MOD" modseparator="MOD"
# Define mods information (required) # Define mods information (required)
fn_mods_info(){
# REQUIRED: mod_info_name=( MOD "modcommand" "Pretty Name" "URL" "filename" "modsubdirs" "LowercaseOn/Off" "/files/to/keep;" "/install/path" "ENGINES" "GAMES" "NOTGAMES" "AUTHOR_URL" "Short Description" ) # REQUIRED: mod_info_name=( MOD "modcommand" "Pretty Name" "URL" "filename" "modsubdirs" "LowercaseOn/Off" "/files/to/keep;" "/install/path" "ENGINES" "GAMES" "NOTGAMES" "AUTHOR_URL" "Short Description" )
# Example 1) Well made mod: mod_info_name=( MOD "awesomemod" "This is an Awesome Mod" "https://awesomemod.com/latest.zip" "awesomemod.zip" "0" "LowercaseOff" "OVERWRITE" "${systemdir}/addons" "source;unity3d;" "GAMES" "NOTGAMES" "https://awesomemod.com/" "This mod knows that 42 is the answer" ) # Example 1) Well made mod: mod_info_name=( MOD "awesomemod" "This is an Awesome Mod" "https://awesomemod.com/latest.zip" "awesomemod.zip" "0" "LowercaseOff" "OVERWRITE" "${systemdir}/addons" "source;unity3d;" "GAMES" "NOTGAMES" "https://awesomemod.com/" "This mod knows that 42 is the answer" )
# Example 2) Poorly made mod: mod_info_name=( MOD "stupidmod" "This is a stupid mod" "${crappymodurl}" "StupidMod.zip" "2" "LowercaseOn" "cfg;data/crappymod;" "${systemdir}" "source;" "GAMES" "Garry's mod;Counter-Strike: Source;" "This mod is dumber than dumb" ) # Example 2) Poorly made mod: mod_info_name=( MOD "stupidmod" "This is a stupid mod" "${crappymodurl}" "StupidMod.zip" "2" "LowercaseOn" "cfg;data/crappymod;" "${systemdir}" "source;" "GAMES" "Garry's mod;Counter-Strike: Source;" "This mod is dumber than dumb" )
@ -58,10 +57,8 @@ fn_mods_info(){
# REQUIRED: Set all mods info into one array for convenience # REQUIRED: Set all mods info into one array for convenience
mods_global_array=( "${mod_info_metamod[@]}" "${mod_info_sourcemod[@]}" "${mod_info_ulib[@]}" "${mod_info_ulx[@]}" "${mod_info_utime[@]}" "${mod_info_uclip[@]}" "${mod_info_acf[@]}" "${mod_info_acf_missiles[@]}" "${mod_info_acf_sweps[@]}" "${mod_info_advdupe2[@]}" "${mod_info_darkrp[@]}" "${mod_info_darkrpmodification[@]}" "${mod_info_rustoxide[@]}" "${mod_info_hwoxide[@]}" "${mod_info_sdtdoxide[@]}" ) mods_global_array=( "${mod_info_metamod[@]}" "${mod_info_sourcemod[@]}" "${mod_info_ulib[@]}" "${mod_info_ulx[@]}" "${mod_info_utime[@]}" "${mod_info_uclip[@]}" "${mod_info_acf[@]}" "${mod_info_acf_missiles[@]}" "${mod_info_acf_sweps[@]}" "${mod_info_advdupe2[@]}" "${mod_info_darkrp[@]}" "${mod_info_darkrpmodification[@]}" "${mod_info_rustoxide[@]}" "${mod_info_hwoxide[@]}" "${mod_info_sdtdoxide[@]}" )
}
# Get a proper URL for mods that don't provide a good one (optional) # Get a proper URL for mods that don't provide a good one (optional)
fn_mods_scrape_urls(){
fn_script_log_info "Retrieving latest mods URLs" fn_script_log_info "Retrieving latest mods URLs"
# Metamod # Metamod
metamodscrapeurl="http://www.gsptalk.com/mirror/sourcemod" metamodscrapeurl="http://www.gsptalk.com/mirror/sourcemod"
@ -74,4 +71,3 @@ fn_mods_scrape_urls(){
sourcemodlatestfile="$(wget "${sourcemodscrapeurl}" -q -O -)" sourcemodlatestfile="$(wget "${sourcemodscrapeurl}" -q -O -)"
sourcemoddownloadurl="https://sm.alliedmods.net/smdrop/${sourcemodmversion}" sourcemoddownloadurl="https://sm.alliedmods.net/smdrop/${sourcemodmversion}"
sourcemodurl="${sourcemoddownloadurl}/${sourcemodlatestfile}" sourcemodurl="${sourcemoddownloadurl}/${sourcemodlatestfile}"
}

Loading…
Cancel
Save