|
@@ -9,63 +9,64 @@ local commandaction="Update"
|
|
|
local function_selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))"
|
|
local function_selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))"
|
|
|
|
|
|
|
|
fn_update_mta_dl(){
|
|
fn_update_mta_dl(){
|
|
|
- fn_fetch_file "http://linux.mtasa.com/dl/${numversion}/multitheftauto_linux_x64-${fullversion}.tar.gz" "${tmpdir}" "multitheftauto_linux_x64-${fullversion}.tar.gz"
|
|
|
|
|
- fn_dl_extract "${tmpdir}" "multitheftauto_linux_x64-${fullversion}.tar.gz" "${tmpdir}"
|
|
|
|
|
- echo -e "copying to ${serverfiles}...\c"
|
|
|
|
|
- fn_script_log "Copying to ${serverfiles}"
|
|
|
|
|
- cp -R "${tmpdir}/multitheftauto_linux_x64-${fullversion}/"* "${serverfiles}"
|
|
|
|
|
- local exitcode=$?
|
|
|
|
|
- if [ "${exitcode}" == "0" ]; then
|
|
|
|
|
- fn_print_ok_eol_nl
|
|
|
|
|
- else
|
|
|
|
|
- fn_print_fail_eol_nl
|
|
|
|
|
- fi
|
|
|
|
|
|
|
+ fn_fetch_file "http://linux.mtasa.com/dl/${numversion}/multitheftauto_linux_x64-${fullversion}.tar.gz" "${tmpdir}" "multitheftauto_linux_x64-${fullversion}.tar.gz"
|
|
|
|
|
+ mkdir "${tmpdir}/multitheftauto_linux_x64-${fullversion}"
|
|
|
|
|
+ fn_dl_extract "${tmpdir}" "multitheftauto_linux_x64-${fullversion}.tar.gz" "${tmpdir}/multitheftauto_linux_x64-${fullversion}"
|
|
|
|
|
+ echo -e "copying to ${filesdir}...\c"
|
|
|
|
|
+ fn_script_log "Copying to ${filesdir}"
|
|
|
|
|
+ cp -R "${tmpdir}/multitheftauto_linux_x64-${fullversion}/multitheftauto_linux_x64-${fullversion}/"* "${filesdir}"
|
|
|
|
|
+ local exitcode=$?
|
|
|
|
|
+ if [ "${exitcode}" == "0" ]; then
|
|
|
|
|
+ fn_print_ok_eol_nl
|
|
|
|
|
+ else
|
|
|
|
|
+ fn_print_fail_eol_nl
|
|
|
|
|
+ fi
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
fn_update_mta_currentbuild(){
|
|
fn_update_mta_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.
|
|
|
|
|
- if [ ! -f "${consolelogdir}/${servicename}-console.log" ]; then
|
|
|
|
|
- fn_print_error "Checking for update: linux.mtasa.com"
|
|
|
|
|
- sleep 1
|
|
|
|
|
- fn_print_error_nl "Checking for update: linux.mtasa.com: No logs with server version found"
|
|
|
|
|
- fn_script_log_error "Checking for update: linux.mtasa.com: No logs with server version found"
|
|
|
|
|
- sleep 1
|
|
|
|
|
- fn_print_info_nl "Checking for update: linux.mtasa.com: Forcing server restart"
|
|
|
|
|
- fn_script_log_info "Checking for update: linux.mtasa.com: Forcing server restart"
|
|
|
|
|
- sleep 1
|
|
|
|
|
- exitbypass=1
|
|
|
|
|
- command_stop.sh
|
|
|
|
|
- exitbypass=1
|
|
|
|
|
- command_start.sh
|
|
|
|
|
- sleep 1
|
|
|
|
|
- # Check again and exit on failure.
|
|
|
|
|
- if [ ! -f "${consolelogdir}/${servicename}-console.log" ]; then
|
|
|
|
|
- fn_print_fail_nl "Checking for update: linux.mtasa.com: Still No logs with server version found"
|
|
|
|
|
- fn_script_log_fatal "Checking for update: linux.mtasa.com: Still No logs with server version found"
|
|
|
|
|
- core_exit.sh
|
|
|
|
|
- fi
|
|
|
|
|
- fi
|
|
|
|
|
|
|
+ # Gets current build info
|
|
|
|
|
+ # Checks if current build info is available. If it fails, then a server restart will be forced to generate logs.
|
|
|
|
|
+ if [ ! -f "${gamelogdir}"/server.log ]; then
|
|
|
|
|
+ fn_print_error "Checking for update: linux.mtasa.com"
|
|
|
|
|
+ sleep 1
|
|
|
|
|
+ fn_print_error_nl "Checking for update: linux.mtasa.com: No logs with server version found"
|
|
|
|
|
+ fn_script_log_error "Checking for update: linux.mtasa.com: No logs with server version found"
|
|
|
|
|
+ sleep 1
|
|
|
|
|
+ fn_print_info_nl "Checking for update: linux.mtasa.com: Forcing server restart"
|
|
|
|
|
+ fn_script_log_info "Checking for update: linux.mtasa.com: Forcing server restart"
|
|
|
|
|
+ sleep 1
|
|
|
|
|
+ exitbypass=1
|
|
|
|
|
+ command_stop.sh
|
|
|
|
|
+ exitbypass=1
|
|
|
|
|
+ command_start.sh
|
|
|
|
|
+ sleep 1
|
|
|
|
|
+ # Check again and exit on failure.
|
|
|
|
|
+ if [ ! -f "${gamelogdir}"/server.log ]; then
|
|
|
|
|
+ fn_print_fail_nl "Checking for update: linux.mtasa.com: Still No logs with server version found"
|
|
|
|
|
+ fn_script_log_fatal "Checking for update: linux.mtasa.com: Still No logs with server version found"
|
|
|
|
|
+ core_exit.sh
|
|
|
|
|
+ fi
|
|
|
|
|
+ fi
|
|
|
|
|
|
|
|
- # Get current build from logs
|
|
|
|
|
- currentbuild=$(awk -F"= Multi Theft Auto: San Andreas v" '{print $2}' "${consolelogdir}"/"${servicename}"-console.log | awk '{print $1}')
|
|
|
|
|
- if [ -z "${currentbuild}" ]; then
|
|
|
|
|
- fn_print_error_nl "Checking for update: linux.mtasa.com: Current build version not found"
|
|
|
|
|
- fn_script_log_error "Checking for update: linux.mtasa.com: Current build version not found"
|
|
|
|
|
- sleep 1
|
|
|
|
|
- fn_print_info_nl "Checking for update: linux.mtasa.com: Forcing server restart"
|
|
|
|
|
- fn_script_log_info "Checking for update: linux.mtasa.com: Forcing server restart"
|
|
|
|
|
- exitbypass=1
|
|
|
|
|
- command_stop.sh
|
|
|
|
|
- exitbypass=1
|
|
|
|
|
- command_start.sh
|
|
|
|
|
- currentbuild=$(awk -F"= Multi Theft Auto: San Andreas v" '{print $2}' "${consolelogdir}"/"${servicename}"-console.log | awk '{print $1}')
|
|
|
|
|
- if [ -z "${currentbuild}" ]; then
|
|
|
|
|
- fn_print_fail_nl "Checking for update: linux.mtasa.com: Current build version still not found"
|
|
|
|
|
- fn_script_log_fatal "Checking for update: linux.mtasa.com: Current build version still not found"
|
|
|
|
|
- core_exit.sh
|
|
|
|
|
- fi
|
|
|
|
|
- fi
|
|
|
|
|
|
|
+ # Get current build from logs
|
|
|
|
|
+ currentbuild=$(cat "${gamelogdir}"/server.log | grep "= Multi Theft Auto: San Andreas v" | awk '{ print $7 }'| sed -r 's/^.{1}//' | tail -1)
|
|
|
|
|
+ if [ -z "${currentbuild}" ]; then
|
|
|
|
|
+ fn_print_error_nl "Checking for update: linux.mtasa.com: Current build version not found"
|
|
|
|
|
+ fn_script_log_error "Checking for update: linux.mtasa.com: Current build version not found"
|
|
|
|
|
+ sleep 1
|
|
|
|
|
+ fn_print_info_nl "Checking for update: linux.mtasa.com: Forcing server restart"
|
|
|
|
|
+ fn_script_log_info "Checking for update: linux.mtasa.com: Forcing server restart"
|
|
|
|
|
+ exitbypass=1
|
|
|
|
|
+ command_stop.sh
|
|
|
|
|
+ exitbypass=1
|
|
|
|
|
+ command_start.sh
|
|
|
|
|
+ currentbuild=$(cat "${gamelogdir}"/server.log | grep "= Multi Theft Auto: San Andreas v" | awk '{ print $7 }'| sed -r 's/^.{1}//' | tail -1)
|
|
|
|
|
+ if [ -z "${currentbuild}" ]; then
|
|
|
|
|
+ fn_print_fail_nl "Checking for update: linux.mtasa.com: Current build version still not found"
|
|
|
|
|
+ fn_script_log_fatal "Checking for update: linux.mtasa.com: Current build version still not found"
|
|
|
|
|
+ core_exit.sh
|
|
|
|
|
+ fi
|
|
|
|
|
+ fi
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
fn_mta_get_availablebuild(){
|
|
fn_mta_get_availablebuild(){
|
|
@@ -79,74 +80,75 @@ fn_mta_get_availablebuild(){
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
fn_update_mta_compare(){
|
|
fn_update_mta_compare(){
|
|
|
- # Removes dots so if can compare version numbers
|
|
|
|
|
- currentbuilddigit=$(echo "${currentbuild}"|tr -cd '[:digit:]')
|
|
|
|
|
- if [ "${currentbuilddigit}" -ne "${numversion}" ]||[ "${forceupdate}" == "1" ]; then
|
|
|
|
|
- if [ "${forceupdate}" == "1" ]; then
|
|
|
|
|
- # forceupdate bypasses checks, useful for small build changes
|
|
|
|
|
- mta_update_string="forced"
|
|
|
|
|
- else
|
|
|
|
|
- mta_update_string="available"
|
|
|
|
|
- fi
|
|
|
|
|
- echo -e "\n"
|
|
|
|
|
- echo -e "Update ${mta_update_string}:"
|
|
|
|
|
- sleep 1
|
|
|
|
|
- echo -e " Current build: ${red}${currentbuild} ${default}"
|
|
|
|
|
- echo -e " Available build: ${green}${fullversion} ${default}"
|
|
|
|
|
- echo -e ""
|
|
|
|
|
- sleep 1
|
|
|
|
|
- echo ""
|
|
|
|
|
- echo -en "Applying update.\r"
|
|
|
|
|
- sleep 1
|
|
|
|
|
- echo -en "Applying update..\r"
|
|
|
|
|
- sleep 1
|
|
|
|
|
- echo -en "Applying update...\r"
|
|
|
|
|
- sleep 1
|
|
|
|
|
- echo -en "\n"
|
|
|
|
|
- fn_script_log "Update ${mta_update_string}"
|
|
|
|
|
- fn_script_log "Current build: ${currentbuild}"
|
|
|
|
|
- fn_script_log "Available build: ${fullversion}"
|
|
|
|
|
- fn_script_log "${currentbuild} > ${fullversion}"
|
|
|
|
|
|
|
+ # Removes dots so if can compare version numbers
|
|
|
|
|
+ currentbuilddigit=$(echo "${currentbuild}"|tr -cd '[:digit:]')
|
|
|
|
|
+ if [ "${currentbuilddigit}" -ne "${numversion}" ]||[ "${forceupdate}" == "1" ]; then
|
|
|
|
|
+ if [ "${forceupdate}" == "1" ]; then
|
|
|
|
|
+ # forceupdate bypasses checks, useful for small build changes
|
|
|
|
|
+ mta_update_string="forced"
|
|
|
|
|
+ else
|
|
|
|
|
+ mta_update_string="available"
|
|
|
|
|
+ fi
|
|
|
|
|
+ echo -e "\n"
|
|
|
|
|
+ echo -e "Update ${mta_update_string}:"
|
|
|
|
|
+ sleep 1
|
|
|
|
|
+ echo -e " Current build: ${red}${currentbuild} ${default}"
|
|
|
|
|
+ echo -e " Available build: ${green}${fullversion} ${default}"
|
|
|
|
|
+ echo -e ""
|
|
|
|
|
+ sleep 1
|
|
|
|
|
+ echo ""
|
|
|
|
|
+ echo -en "Applying update.\r"
|
|
|
|
|
+ sleep 1
|
|
|
|
|
+ echo -en "Applying update..\r"
|
|
|
|
|
+ sleep 1
|
|
|
|
|
+ echo -en "Applying update...\r"
|
|
|
|
|
+ sleep 1
|
|
|
|
|
+ echo -en "\n"
|
|
|
|
|
+ fn_script_log "Update ${mta_update_string}"
|
|
|
|
|
+ fn_script_log "Current build: ${currentbuild}"
|
|
|
|
|
+ fn_script_log "Available build: ${fullversion}"
|
|
|
|
|
+ fn_script_log "${currentbuild} > ${fullversion}"
|
|
|
|
|
|
|
|
- unset updateonstart
|
|
|
|
|
|
|
+ unset updateonstart
|
|
|
|
|
|
|
|
- check_status.sh
|
|
|
|
|
- if [ "${status}" == "0" ]; then
|
|
|
|
|
- fn_update_mta_dl
|
|
|
|
|
- exitbypass=1
|
|
|
|
|
- command_start.sh
|
|
|
|
|
- exitbypass=1
|
|
|
|
|
- command_stop.sh
|
|
|
|
|
- else
|
|
|
|
|
- exitbypass=1
|
|
|
|
|
- command_stop.sh
|
|
|
|
|
- fn_update_mta_dl
|
|
|
|
|
- exitbypass=1
|
|
|
|
|
- command_start.sh
|
|
|
|
|
- fi
|
|
|
|
|
- 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}${fullversion}${default}"
|
|
|
|
|
- echo -e ""
|
|
|
|
|
- fn_print_ok_nl "No update available"
|
|
|
|
|
- fn_script_log_info "Current build: ${currentbuild}"
|
|
|
|
|
- fn_script_log_info "Available build: ${fullversion}"
|
|
|
|
|
- fi
|
|
|
|
|
|
|
+ check_status.sh
|
|
|
|
|
+ if [ "${status}" == "0" ]; then
|
|
|
|
|
+ fn_update_mta_dl
|
|
|
|
|
+ exitbypass=1
|
|
|
|
|
+ command_start.sh
|
|
|
|
|
+ exitbypass=1
|
|
|
|
|
+ command_stop.sh
|
|
|
|
|
+ else
|
|
|
|
|
+ exitbypass=1
|
|
|
|
|
+ command_stop.sh
|
|
|
|
|
+ fn_update_mta_dl
|
|
|
|
|
+ exitbypass=1
|
|
|
|
|
+ command_start.sh
|
|
|
|
|
+ fi
|
|
|
|
|
+ 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}${fullversion}${default}"
|
|
|
|
|
+ echo -e ""
|
|
|
|
|
+ fn_print_ok_nl "No update available"
|
|
|
|
|
+ fn_script_log_info "Current build: ${currentbuild}"
|
|
|
|
|
+ fn_script_log_info "Available build: ${fullversion}"
|
|
|
|
|
+ fi
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+
|
|
|
if [ "${installer}" == "1" ]; then
|
|
if [ "${installer}" == "1" ]; then
|
|
|
- fn_mta_get_availablebuild
|
|
|
|
|
- fn_update_mta_dl
|
|
|
|
|
|
|
+ fn_mta_get_availablebuild
|
|
|
|
|
+ fn_update_mta_dl
|
|
|
else
|
|
else
|
|
|
- # Checks for server update from linux.mtasa.com using the github repo.
|
|
|
|
|
- fn_print_dots "Checking for update: linux.mtasa.com"
|
|
|
|
|
- fn_script_log_info "Checking for update: linux.mtasa.com"
|
|
|
|
|
- sleep 1
|
|
|
|
|
- fn_update_mta_currentbuild
|
|
|
|
|
- fn_mta_get_availablebuild
|
|
|
|
|
- fn_update_mta_compare
|
|
|
|
|
|
|
+ # Checks for server update from linux.mtasa.com using the github repo.
|
|
|
|
|
+ fn_print_dots "Checking for update: linux.mtasa.com"
|
|
|
|
|
+ fn_script_log_info "Checking for update: linux.mtasa.com"
|
|
|
|
|
+ sleep 1
|
|
|
|
|
+ fn_update_mta_currentbuild
|
|
|
|
|
+ fn_mta_get_availablebuild
|
|
|
|
|
+ fn_update_mta_compare
|
|
|
fi
|
|
fi
|