From fe473a557f4b674bcc938b06d7fc1bd07befcaa4 Mon Sep 17 00:00:00 2001 From: Lucy Date: Sat, 21 Sep 2024 16:29:53 -0400 Subject: [PATCH] "Get Server Logs" can now jump to a specific round ID --- monkestation/code/__HELPERS/files.dm | 47 +++++++++++++++++++++------- monkestation/code/game/world.dm | 24 +++++++++++++- 2 files changed, 58 insertions(+), 13 deletions(-) diff --git a/monkestation/code/__HELPERS/files.dm b/monkestation/code/__HELPERS/files.dm index be454635ab42..cf17347310ad 100644 --- a/monkestation/code/__HELPERS/files.dm +++ b/monkestation/code/__HELPERS/files.dm @@ -3,7 +3,7 @@ var/regex/whitelist_regex if(whitelist) // try not to look at it too hard. yes i wrote this by hand. - whitelist_regex = new("(?:\[\\/\\\\\]$|(?:^|\\\\|\\/)(?:[regex_quote_list(whitelist)])\\.(?:[regex_quote_list(valid_extensions)])$)", "i") + whitelist_regex = new("(?:\[\\/\\\\\]$|(?:^|\\\\|\\/)(?:[regex_quote_list(whitelist)]|(?:profiler|sendmaps)-\[0-9\]+)\\.(?:[regex_quote_list(valid_extensions)])$)", "i") // wow why was this ever a parameter var/root = "data/logs/" @@ -15,19 +15,18 @@ var/path = root for(var/i in 1 to max_iterations) - var/list/choices + var/list/choices = flist(path) if(whitelist_regex) - choices = list() - for(var/listed_path in flist(path)) - if(whitelist_regex.Find(listed_path)) - choices += listed_path - else - choices = flist(path) + for(var/listed_path in choices) + if(!whitelist_regex.Find(listed_path)) + choices -= listed_path + choices = sort_list(choices) if(path != root) choices.Insert(1, "/") - choices = sort_list(choices) if(allow_folder) - choices += "Download Folder" + choices.Insert(1, "Download Folder") + if(root_type == BROWSE_ROOT_ALL_LOGS && SSdbcore.IsConnected()) + choices.Insert(1, "Choose Round ID") var/choice = tgui_input_list(src, "Choose a file to access", "Download", choices) if(!choice) @@ -36,11 +35,35 @@ if("/") path = root continue + if("Choose Round ID") + var/current_round_id = text2num(GLOB.round_id) + var/target_round = tgui_input_number( + src, + message = "Choose which round ID you wish to go to", + title = "Download", + default = current_round_id, + max_value = current_round_id, + min_value = 1 + ) + if(!target_round) + to_chat(src, span_warning("No round ID chosen."), type = MESSAGE_TYPE_DEBUG, confidential = TRUE) + return + var/round_folder = get_log_directory_by_round_id(target_round) + if(!round_folder) + to_chat(src, span_warning("Could not find log directory for round [target_round]!"), type = MESSAGE_TYPE_DEBUG, confidential = TRUE) + return + path = "[round_folder]/" + continue if("Download Folder") if(!allow_folder) return var/list/comp_flist = flist(path) - var/confirmation = input(src, "Are you SURE you want to download all the files in this folder? (This will open [length(comp_flist)] prompt[length(comp_flist) == 1 ? "" : "s"])", "Confirmation") in list("Yes", "No") + var/confirmation = tgui_input_list( + user = src, + message = "Are you SURE you want to download all the files in this folder? (This will open [length(comp_flist)] prompt[length(comp_flist) == 1 ? "" : "s"])", + title = "Confirmation", + items = list("Yes", "No") + ) if(confirmation != "Yes") continue for(var/file in comp_flist) @@ -50,7 +73,7 @@ if(copytext_char(path, -1) != "/") //didn't choose a directory, no need to iterate again break - if(!fexists(path) || !valid_ext_regex.Find(path)) + if(!rustg_file_exists(path) || !valid_ext_regex.Find(path)) to_chat(src, "Error: browse_files(): File not found/Invalid file([path]).") return diff --git a/monkestation/code/game/world.dm b/monkestation/code/game/world.dm index 40396b385ff9..adea6c02f0a7 100644 --- a/monkestation/code/game/world.dm +++ b/monkestation/code/game/world.dm @@ -7,7 +7,7 @@ if(!GLOB.round_id || !SSdbcore.IsConnected()) return var/datum/db_query/set_log_directory = SSdbcore.NewQuery({" - UPDATE `[format_table_name("round")]` + UPDATE [format_table_name("round")] SET `log_directory` = :log_directory WHERE @@ -15,3 +15,25 @@ "}, list("log_directory" = GLOB.log_directory, "round_id" = GLOB.round_id)) set_log_directory.Execute() QDEL_NULL(set_log_directory) + +/proc/get_log_directory_by_round_id(round_id) + if(!isnum(round_id) || round_id <= 0 || !SSdbcore.IsConnected()) + return + var/datum/db_query/query_log_directory = SSdbcore.NewQuery({" + SELECT `log_directory` + FROM + [format_table_name("round")] + WHERE + `id` = :round_id + "}, list("round_id" = round_id)) + if(!query_log_directory.warn_execute()) + qdel(query_log_directory) + return + if(!query_log_directory.NextRow()) + qdel(query_log_directory) + CRASH("Failed to get log directory for round [round_id]") + var/log_directory = query_log_directory.item[1] + QDEL_NULL(query_log_directory) + if(!rustg_file_exists(log_directory)) + CRASH("Log directory '[log_directory]' for round ID [round_id] doesn't exist!") + return log_directory