fix(mta): change updater to use builds (#4310)

https://github.com/multitheftauto/mtasa-blue/issues/3176
This commit is contained in:
Daniel Gibbs 2023-09-08 23:45:59 +01:00 committed by GitHub
parent 6921851da6
commit 9326d48684
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 15 additions and 7 deletions

View File

@ -11,6 +11,7 @@ fn_update_dl() {
# Download and extract files to serverfiles. # Download and extract files to serverfiles.
fn_fetch_file "${remotebuildurl}" "" "" "" "${tmpdir}" "${remotebuildfilename}" "chmodx" "norun" "noforce" "nohash" fn_fetch_file "${remotebuildurl}" "" "" "" "${tmpdir}" "${remotebuildfilename}" "chmodx" "norun" "noforce" "nohash"
cp -f "${tmpdir}/${remotebuildfilename}" "${serverfiles}/${executable#./}" cp -f "${tmpdir}/${remotebuildfilename}" "${serverfiles}/${executable#./}"
fn_clear_tmp
} }
fn_update_localbuild() { fn_update_localbuild() {

View File

@ -23,10 +23,12 @@ fn_update_dl() {
echo -e "${extractcmd}" >> "${lgsmlog}" echo -e "${extractcmd}" >> "${lgsmlog}"
fi fi
echo -e "${extractcmd}" echo -e "${extractcmd}"
fn_clear_tmp
core_exit.sh core_exit.sh
else else
fn_print_ok_eol_nl fn_print_ok_eol_nl
fn_script_log_pass "Extracting ${local_filename}" fn_script_log_pass "Extracting ${local_filename}"
fn_clear_tmp
fi fi
} }

View File

@ -11,13 +11,17 @@ fn_update_dl() {
# Download and extract files to tmpdir. # Download and extract files to tmpdir.
fn_fetch_file "http://linux.mtasa.com/dl/multitheftauto_linux_x64.tar.gz" "" "" "" "${tmpdir}" "multitheftauto_linux_x64.tar.gz" "nochmodx" "norun" "force" "nohash" fn_fetch_file "http://linux.mtasa.com/dl/multitheftauto_linux_x64.tar.gz" "" "" "" "${tmpdir}" "multitheftauto_linux_x64.tar.gz" "nochmodx" "norun" "force" "nohash"
fn_dl_extract "${tmpdir}" "multitheftauto_linux_x64.tar.gz" "${serverfiles}" "multitheftauto_linux_x64" fn_dl_extract "${tmpdir}" "multitheftauto_linux_x64.tar.gz" "${serverfiles}" "multitheftauto_linux_x64"
fn_clear_tmp
} }
fn_update_localbuild() { fn_update_localbuild() {
# Gets local build info. # Gets local build info.
fn_print_dots "Checking local build: ${remotelocation}" fn_print_dots "Checking local build: ${remotelocation}"
# Uses log file to get local build. # Uses executable to get local build.
localbuild=$(grep "= Multi Theft Auto: San Andreas v" "${serverfiles}/mods/deathmatch/logs/server.log" | awk '{ print $7 }' | sed -r 's/^.{1}//' | tail -1) if [ -d "${executabledir}" ]; then
cd "${executabledir}" || exit
localbuild=$(${executable} -v 2> /dev/null)
fi
if [ -z "${localbuild}" ]; then if [ -z "${localbuild}" ]; then
fn_print_error "Checking local build: ${remotelocation}: missing local build info" fn_print_error "Checking local build: ${remotelocation}: missing local build info"
fn_script_log_error "Missing local build info" fn_script_log_error "Missing local build info"
@ -31,11 +35,11 @@ fn_update_localbuild() {
fn_update_remotebuild() { fn_update_remotebuild() {
# Get remote build info. # Get remote build info.
apiurl="https://api.github.com/repos/multitheftauto/mtasa-blue/releases/latest" apiurl="https://linux.multitheftauto.com/revision/latest.txt"
remotebuildresponse=$(curl -s "${apiurl}") remotebuildresponse=$(curl -s "${apiurl}")
remotebuildfilename=$(echo "${remotebuildresponse}" | jq -r '.assets[]|select(.browser_download_url | contains("Linux-amd64")) | .name') remotebuildfilename="multitheftauto_linux_x64.tar.gz"
remotebuildurl=$(echo "${remotebuildresponse}" | jq -r '.assets[]|select(.browser_download_url | contains("Linux-amd64")) | .browser_download_url') remotebuildurl="http://linux.mtasa.com/dl/multitheftauto_linux_x64.tar.gz"
remotebuildversion=$(echo "${remotebuildresponse}" | jq -r '.tag_name') remotebuildversion=$(echo "${remotebuildresponse}")
if [ "${firstcommandname}" != "INSTALL" ]; then if [ "${firstcommandname}" != "INSTALL" ]; then
fn_print_dots "Checking remote build: ${remotelocation}" fn_print_dots "Checking remote build: ${remotelocation}"
# Checks if remotebuildversion variable has been set. # Checks if remotebuildversion variable has been set.

View File

@ -12,6 +12,7 @@ fn_update_dl() {
fn_fetch_file "${remotebuildurl}" "" "" "" "${tmpdir}" "${remotebuildfilename}" "chmodx" "norun" "force" "${remotebuildhash}" fn_fetch_file "${remotebuildurl}" "" "" "" "${tmpdir}" "${remotebuildfilename}" "chmodx" "norun" "force" "${remotebuildhash}"
cp -f "${tmpdir}/${remotebuildfilename}" "${serverfiles}/${executable#./}" cp -f "${tmpdir}/${remotebuildfilename}" "${serverfiles}/${executable#./}"
echo "${remotebuildversion}" > "${serverfiles}/build.txt" echo "${remotebuildversion}" > "${serverfiles}/build.txt"
fn_clear_tmp
} }
fn_update_localbuild() { fn_update_localbuild() {

View File

@ -20,7 +20,7 @@ fn_update_localbuild() {
# Uses executable to get local build. # Uses executable to get local build.
if [ -d "${executabledir}" ]; then if [ -d "${executabledir}" ]; then
cd "${executabledir}" || exit cd "${executabledir}" || exit
localbuild="$(${preexecutable} ${executable} --version | sed '/^[[:space:]]*$/d')" localbuild="$(${preexecutable} ${executable} --version 2> /dev/null | sed '/^[[:space:]]*$/d')"
fi fi
if [ -z "${localbuild}" ]; then if [ -z "${localbuild}" ]; then
fn_print_error "Checking local build: ${remotelocation}: missing local build info" fn_print_error "Checking local build: ${remotelocation}: missing local build info"