|
|
@@ -2,154 +2,183 @@
|
|
|
# LinuxGSM command_ts3.sh function
|
|
|
# Author: Daniel Gibbs
|
|
|
# Website: https://linuxgsm.com
|
|
|
-# Description: Handles updating of teamspeak 3 servers.
|
|
|
+# Description: Handles updating of Teamspeak 3 servers.
|
|
|
|
|
|
local commandname="UPDATE"
|
|
|
local commandaction="Update"
|
|
|
local function_selfname="$(basename "$(readlink -f "${BASH_SOURCE[0]}")")"
|
|
|
|
|
|
fn_update_ts3_dl(){
|
|
|
- info_distro.sh
|
|
|
if [ "${ts3arch}" == "amd64" ]; then
|
|
|
- latestts3releaselink=$(${curlpath} -s 'https://www.teamspeak.com/versions/server.json' | jq -r '.linux.x86_64.mirrors."teamspeak.com"')
|
|
|
+ local remotebuildurl=$(${curlpath} -s 'https://www.teamspeak.com/versions/server.json' | jq -r '.linux.x86_64.mirrors."teamspeak.com"')
|
|
|
elif [ "${ts3arch}" == "x86" ]; then
|
|
|
- latestts3releaselink=$(${curlpath} -s 'https://www.teamspeak.com/versions/server.json' | jq -r '.linux.x86.mirrors."teamspeak.com"')
|
|
|
+ local remotebuildurl=$(${curlpath} -s 'https://www.teamspeak.com/versions/server.json' | jq -r '.linux.x86.mirrors."teamspeak.com"')
|
|
|
fi
|
|
|
- fn_fetch_file "${latestts3releaselink}" "${tmpdir}" "teamspeak3-server_linux_${ts3arch}-${ts3_version_number}.tar.bz2"
|
|
|
- fn_dl_extract "${tmpdir}" "teamspeak3-server_linux_${ts3arch}-${ts3_version_number}.tar.bz2" "${tmpdir}"
|
|
|
+ fn_fetch_file "${remotebuildurl}" "${tmpdir}" "teamspeak3-server_linux_${ts3arch}-${remotebuild}.tar.bz2"
|
|
|
+ fn_dl_extract "${tmpdir}" "teamspeak3-server_linux_${ts3arch}-${remotebuild}.tar.bz2" "${tmpdir}"
|
|
|
echo -e "copying to ${serverfiles}...\c"
|
|
|
- fn_script_log "Copying to ${serverfiles}"
|
|
|
cp -R "${tmpdir}/teamspeak3-server_linux_${ts3arch}/"* "${serverfiles}"
|
|
|
local exitcode=$?
|
|
|
if [ "${exitcode}" == "0" ]; then
|
|
|
fn_print_ok_eol_nl
|
|
|
+ fn_script_log_pass "Copying to ${serverfiles}"
|
|
|
+ fn_clear_tmp
|
|
|
else
|
|
|
fn_print_fail_eol_nl
|
|
|
+ fn_script_log_fatal "Copying to ${serverfiles}"
|
|
|
+ core_exit.sh
|
|
|
fi
|
|
|
}
|
|
|
|
|
|
-fn_update_ts3_currentbuild(){
|
|
|
- # Gets current build info
|
|
|
- # Checks if current build info is available. If it fails, then a server restart will be forced to generate logs.
|
|
|
+fn_update_ts3_localbuild(){
|
|
|
+ # Gets local build info.
|
|
|
+ fn_print_dots "Checking for update: ${remotelocation}: checking local build"
|
|
|
+ sleep 0.5
|
|
|
+ # Uses log file to gather info.
|
|
|
+ # Gives time for log file to generate.
|
|
|
if [ ! -d "${serverfiles}/logs" ]||[ -z "$(find "${serverfiles}/logs/"* -name 'ts3server*_0.log' 2> /dev/null)" ]; then
|
|
|
- fn_print_error "Checking for update: teamspeak.com"
|
|
|
+ fn_print_error "Checking for update: ${remotelocation}: checking local build"
|
|
|
sleep 0.5
|
|
|
- fn_print_error_nl "Checking for update: teamspeak.com: No logs with server version found"
|
|
|
- fn_script_log_error "Checking for update: teamspeak.com: No logs with server version found"
|
|
|
+ fn_print_error_nl "Checking for update: ${remotelocation}: checking local build: no log files"
|
|
|
+ fn_script_log_error "No log file found"
|
|
|
sleep 0.5
|
|
|
- fn_print_info_nl "Checking for update: teamspeak.com: Forcing server restart"
|
|
|
- fn_script_log_info "Checking for update: teamspeak.com: Forcing server restart"
|
|
|
+ fn_print_info_nl "Checking for update: ${remotelocation}: checking local build: forcing server restart"
|
|
|
+ fn_script_log_info "Forcing server restart"
|
|
|
sleep 0.5
|
|
|
exitbypass=1
|
|
|
command_stop.sh
|
|
|
exitbypass=1
|
|
|
command_start.sh
|
|
|
- sleep 0.5
|
|
|
- # Check again and exit on failure.
|
|
|
- if [ ! -d "${serverfiles}/logs" ]||[ -z "$(find "${serverfiles}/logs/"* -name 'ts3server*_0.log')" ]; then
|
|
|
- fn_print_fail_nl "Checking for update: teamspeak.com: Still No logs with server version found"
|
|
|
- fn_script_log_fatal "Checking for update: teamspeak.com: Still No logs with server version found"
|
|
|
- core_exit.sh
|
|
|
- fi
|
|
|
+ totalseconds=0
|
|
|
+ # Check again, allow time to generate logs.
|
|
|
+ while [ ! -d "${serverfiles}/logs" ]||[ -z "$(find "${serverfiles}/logs/"* -name 'ts3server*_0.log' 2> /dev/null)" ]; do
|
|
|
+ sleep 1
|
|
|
+ fn_print_info "Checking for update: ${remotelocation}: checking local build: waiting for log file: ${totalseconds}"
|
|
|
+ if [ -v "${loopignore}" ]; then
|
|
|
+ loopignore=1
|
|
|
+ fn_script_log_info "Waiting for log file to generate"
|
|
|
+ fi
|
|
|
+
|
|
|
+ if [ "${totalseconds}" -gt "120" ]; then
|
|
|
+ localbuild="0"
|
|
|
+ fn_print_error "Checking for update: ${remotelocation}: waiting for log file: missing log file"
|
|
|
+ fn_script_log_error "Missing log file"
|
|
|
+ fn_script_log_error "Set localbuild to 0"
|
|
|
+ sleep 0.5
|
|
|
+ fi
|
|
|
+
|
|
|
+ totalseconds=$((totalseconds + 1))
|
|
|
+ done
|
|
|
fi
|
|
|
|
|
|
- # Get current build from logs
|
|
|
- currentbuild="$(cat "$(find "${serverfiles}/logs/"* -name "ts3server*_0.log" 2> /dev/null | sort | tail -1)" | grep -Eo "TeamSpeak 3 Server ((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}" | grep -Eo "((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}" | sort -V)"
|
|
|
- if [ -z "${currentbuild}" ]; then
|
|
|
- fn_print_error_nl "Checking for update: teamspeak.com: Current build version not found"
|
|
|
- fn_script_log_error "Checking for update: teamspeak.com: Current build version not found"
|
|
|
- sleep 0.5
|
|
|
- fn_print_info_nl "Checking for update: teamspeak.com: Forcing server restart"
|
|
|
- fn_script_log_info "Checking for update: teamspeak.com: Forcing server restart"
|
|
|
- exitbypass=1
|
|
|
- command_stop.sh
|
|
|
- exitbypass=1
|
|
|
- command_start.sh
|
|
|
- currentbuild="$(cat "$(find "${serverfiles}/logs/"* -name "ts3server*_0.log" 2> /dev/null | sort | tail -1)" | grep -Eo "TeamSpeak 3 Server ((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}" | grep -Eo "((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}" | sort -V)"
|
|
|
- if [ -z "${currentbuild}" ]; then
|
|
|
- fn_print_fail_nl "Checking for update: teamspeak.com: Current build version still not found"
|
|
|
- fn_script_log_fatal "Checking for update: teamspeak.com: Current build version still not found"
|
|
|
- core_exit.sh
|
|
|
- fi
|
|
|
+ if [ -z "${localbuild}" ]; then
|
|
|
+ localbuild=$(cat $(find ./* -name "ts3server*_0.log" 2> /dev/null | sort | tail -1) | grep -Eo "TeamSpeak 3 Server ((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}" | grep -Eo "((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}")
|
|
|
fi
|
|
|
-}
|
|
|
|
|
|
-fn_update_ts3_arch(){
|
|
|
-# Gets the teamspeak server architecture.
|
|
|
-info_distro.sh
|
|
|
-if [ "${arch}" == "x86_64" ]; then
|
|
|
- ts3arch="amd64"
|
|
|
-elif [ "${arch}" == "i386" ]||[ "${arch}" == "i686" ]; then
|
|
|
- ts3arch="x86"
|
|
|
-else
|
|
|
- echo ""
|
|
|
- fn_print_failure "Unknown or unsupported architecture: ${arch}"
|
|
|
- fn_script_log_fatal "Unknown or unsupported architecture: ${arch}"
|
|
|
- core_exit.sh
|
|
|
-fi
|
|
|
+ if [ -z "${localbuild}" ]; then
|
|
|
+ # Gives time for var to generate.
|
|
|
+ end=$((SECONDS+120))
|
|
|
+ totalseconds=0
|
|
|
+ while [ "${SECONDS}" -lt "${end}" ]; do
|
|
|
+ fn_print_info "Checking for update: ${remotelocation}: checking local build: waiting for local build: ${totalseconds}"
|
|
|
+ if [ -z "${loopignore}" ]; then
|
|
|
+ loopignore=1
|
|
|
+ fn_script_log_info "Waiting for local build to generate"
|
|
|
+ fi
|
|
|
+ localbuild=$(cat $(find ./* -name "ts3server*_0.log" 2> /dev/null | sort | tail -1) | grep -Eo "TeamSpeak 3 Server ((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}" | grep -Eo "((\.)?[0-9]{1,3}){1,3}\.[0-9]{1,3}")
|
|
|
+ if [ "${localbuild}" ]; then
|
|
|
+ break
|
|
|
+ fi
|
|
|
+ sleep 1
|
|
|
+ totalseconds=$((totalseconds + 1))
|
|
|
+ done
|
|
|
+ fi
|
|
|
+
|
|
|
+ if [ -z "${localbuild}" ]; then
|
|
|
+ localbuild="0"
|
|
|
+ fn_print_error "Checking for update: ${remotelocation}: waiting for local build: missing local build info"
|
|
|
+ fn_script_log_error "Missing local build info"
|
|
|
+ fn_script_log_error "Set localbuild to 0"
|
|
|
+ else
|
|
|
+ fn_print_ok "Checking for update: ${remotelocation}: checking local build"
|
|
|
+ fn_script_log_pass "Checking local build"
|
|
|
+ fi
|
|
|
+ sleep 0.5
|
|
|
}
|
|
|
|
|
|
-fn_update_ts3_availablebuild(){
|
|
|
- # Gets latest build info.
|
|
|
+fn_update_ts3_remotebuild(){
|
|
|
+ # Gets remote build info.
|
|
|
if [ "${arch}" == "x86_64" ]; then
|
|
|
- availablebuild="$(${curlpath} -s 'https://www.teamspeak.com/versions/server.json' | jq -r '.linux.x86_64.version')"
|
|
|
+ remotebuild="$(${curlpath} -s "https://www.teamspeak.com/versions/server.json" | jq -r '.linux.x86_64.version')"
|
|
|
elif [ "${arch}" == "x86" ]; then
|
|
|
- availablebuild="$(${curlpath} -s 'https://www.teamspeak.com/versions/server.json' | jq -r '.linux.x86.version')"
|
|
|
+ remotebuild="$(${curlpath} -s "https://www.teamspeak.com/versions/server.json" | jq -r '.linux.x86.version')"
|
|
|
fi
|
|
|
- ts3_version_number="${availablebuild}"
|
|
|
- # Checks if availablebuild variable has been set
|
|
|
- if [ -v "${availablebuild}" ]||[ "${availablebuild}" == "null" ]; then
|
|
|
- fn_print_fail "Checking for update: teamspeak.com"
|
|
|
+ if [ "${installer}" != "1" ]; then
|
|
|
+ fn_print_dots "Checking for update: ${remotelocation}: checking remote build"
|
|
|
sleep 0.5
|
|
|
- fn_print_fail "Checking for update: teamspeak.com: Not returning version info"
|
|
|
- fn_script_log_fatal "Checking for update: teamspeak.com: Not returning version info"
|
|
|
- core_exit.sh
|
|
|
- elif [ "${installer}" == "1" ]; then
|
|
|
- :
|
|
|
+ # Checks if remotebuild variable has been set.
|
|
|
+ if [ -z "${remotebuild}" ]||[ "${remotebuild}" == "null" ]; then
|
|
|
+ fn_print_fail "Checking for update: ${remotelocation}: checking remote build"
|
|
|
+ fn_script_log_fatal "Checking remote build"
|
|
|
+ core_exit.sh
|
|
|
+ else
|
|
|
+ fn_print_ok "Checking for update: ${remotelocation}: checking remote build"
|
|
|
+ fn_script_log_pass "Checking remote build"
|
|
|
+ sleep 0.5
|
|
|
+ fi
|
|
|
else
|
|
|
- fn_print_ok_nl "Checking for update: teamspeak.com"
|
|
|
- fn_script_log_pass "Checking for update: teamspeak.com"
|
|
|
- sleep 0.5
|
|
|
- fi
|
|
|
+ # Checks if remotebuild variable has been set.
|
|
|
+ if [ -z "${remotebuild}" ]||[ "${remotebuild}" == "null" ]; then
|
|
|
+ fn_print_failure "Unable to get remote build"
|
|
|
+ fn_script_log_fatal "Unable to get remote build"
|
|
|
+ core_exit.sh
|
|
|
+ fi
|
|
|
+ fi
|
|
|
}
|
|
|
|
|
|
fn_update_ts3_compare(){
|
|
|
- # Removes dots so if can compare version numbers
|
|
|
- currentbuilddigit=$(echo "${currentbuild}" | tr -cd '[:digit:]')
|
|
|
- availablebuilddigit=$(echo "${availablebuild}" | tr -cd '[:digit:]')
|
|
|
-
|
|
|
- if [ "${currentbuilddigit}" -lt "${availablebuilddigit}" ]; then
|
|
|
- echo -e "\n"
|
|
|
- echo -e "Update available:"
|
|
|
+ # Removes dots so if statement can compare version numbers.
|
|
|
+ fn_print_dots "Checking for update: ${remotelocation}"
|
|
|
+ sleep 0.5
|
|
|
+ localbuilddigit=$(echo "${localbuild}" | tr -cd '[:digit:]')
|
|
|
+ remotebuilddigit=$(echo "${remotebuild}" | tr -cd '[:digit:]')
|
|
|
+ if [ "${localbuilddigit}" -ne "${remotebuilddigit}" ]||[ "${forceupdate}" == "1" ]; then
|
|
|
+ fn_print_ok_nl "Checking for update: ${remotelocation}"
|
|
|
sleep 0.5
|
|
|
- echo -e " Current build: ${red}${currentbuild} ${ts3arch}${default}"
|
|
|
- echo -e " Available build: ${green}${availablebuild} ${ts3arch}${default}"
|
|
|
- echo -e ""
|
|
|
+ echo -en "\n"
|
|
|
+ echo -e "Update available"
|
|
|
+ echo -e "* Local build: ${red}${localbuild}${default}"
|
|
|
+ echo -e "* Remote build: ${green}${remotebuild}${default}"
|
|
|
+ fn_script_log_info "Update available"
|
|
|
+ fn_script_log_info "Local build: ${localbuild}"
|
|
|
+ fn_script_log_info "Remote build: ${remotebuild}"
|
|
|
+ fn_script_log_info "${localbuild} > ${remotebuild}"
|
|
|
sleep 0.5
|
|
|
- echo -en "Applying update.\r"
|
|
|
+ echo -en "\n"
|
|
|
+ echo -en "applying update.\r"
|
|
|
sleep 1
|
|
|
- echo -en "Applying update..\r"
|
|
|
+ echo -en "applying update..\r"
|
|
|
sleep 1
|
|
|
- echo -en "Applying update...\r"
|
|
|
+ echo -en "applying update...\r"
|
|
|
sleep 1
|
|
|
echo -en "\n"
|
|
|
- fn_script_log "Update available"
|
|
|
- fn_script_log "Current build: ${currentbuild}"
|
|
|
- fn_script_log "Available build: ${availablebuild}"
|
|
|
- fn_script_log "${currentbuild} > ${availablebuild}"
|
|
|
|
|
|
unset updateonstart
|
|
|
|
|
|
check_status.sh
|
|
|
+ # If server stopped.
|
|
|
if [ "${status}" == "0" ]; then
|
|
|
+ exitbypass=1
|
|
|
fn_update_ts3_dl
|
|
|
exitbypass=1
|
|
|
command_start.sh
|
|
|
exitbypass=1
|
|
|
command_stop.sh
|
|
|
+ # If server started.
|
|
|
else
|
|
|
exitbypass=1
|
|
|
command_stop.sh
|
|
|
+ exitbypass=1
|
|
|
fn_update_ts3_dl
|
|
|
exitbypass=1
|
|
|
command_start.sh
|
|
|
@@ -157,27 +186,41 @@ fn_update_ts3_compare(){
|
|
|
alert="update"
|
|
|
alert.sh
|
|
|
else
|
|
|
- echo -e "\n"
|
|
|
- echo -e "No update available:"
|
|
|
- echo -e " Current version: ${green}${currentbuild}${default}"
|
|
|
- echo -e " Available version: ${green}${availablebuild}${default}"
|
|
|
- echo -e ""
|
|
|
- fn_print_ok_nl "No update available"
|
|
|
- fn_script_log_info "Current build: ${currentbuild}"
|
|
|
- fn_script_log_info "Available build: ${availablebuild}"
|
|
|
+ fn_print_ok_nl "Checking for update: ${remotelocation}"
|
|
|
+ sleep 0.5
|
|
|
+ echo -en "\n"
|
|
|
+ echo -e "No update available"
|
|
|
+ echo -e "* Local build: ${green}${localbuild}${default}"
|
|
|
+ echo -e "* Remote build: ${green}${remotebuild}${default}"
|
|
|
+ fn_script_log_info "No update available"
|
|
|
+ fn_script_log_info "Local build: ${localbuild}"
|
|
|
+ fn_script_log_info "Remote build: ${remotebuild}"
|
|
|
fi
|
|
|
}
|
|
|
|
|
|
-fn_update_ts3_arch
|
|
|
+# Game server architecture.
|
|
|
+info_distro.sh
|
|
|
+if [ "${arch}" == "x86_64" ]; then
|
|
|
+ ts3arch="amd64"
|
|
|
+elif [ "${arch}" == "i386" ]||[ "${arch}" == "i686" ]; then
|
|
|
+ ts3arch="x86"
|
|
|
+else
|
|
|
+ fn_print_failure "Unknown or unsupported architecture: ${arch}"
|
|
|
+ fn_script_log_fatal "Unknown or unsupported architecture: ${arch}"
|
|
|
+ core_exit.sh
|
|
|
+fi
|
|
|
+
|
|
|
+# The location where the builds are checked and downloaded.
|
|
|
+remotelocation="teamspeak.com"
|
|
|
+
|
|
|
if [ "${installer}" == "1" ]; then
|
|
|
- fn_update_ts3_availablebuild
|
|
|
+ fn_update_ts3_remotebuild
|
|
|
fn_update_ts3_dl
|
|
|
else
|
|
|
- # Checks for server update from teamspeak.com using a mirror dl.4players.de.
|
|
|
- fn_print_dots "Checking for update: teamspeak.com"
|
|
|
- fn_script_log_info "Checking for update: teamspeak.com"
|
|
|
+ fn_print_dots "Checking for update: ${remotelocation}"
|
|
|
+ fn_script_log_info "Checking for update: ${remotelocation}"
|
|
|
sleep 0.5
|
|
|
- fn_update_ts3_currentbuild
|
|
|
- fn_update_ts3_availablebuild
|
|
|
+ fn_update_ts3_localbuild
|
|
|
+ fn_update_ts3_remotebuild
|
|
|
fn_update_ts3_compare
|
|
|
fi
|