// Security helpers to ensure you cant arbitrarily load stuff from disk /proc/wrap_file(filepath) if(IsAdminAdvancedProcCall()) // Admins shouldnt fuck with this to_chat(usr, "File load blocked: Advanced ProcCall detected.") message_admins("[key_name(usr)] attempted to load files via advanced proc-call") log_admin("[key_name(usr)] attempted to load files via advanced proc-call") return return file(filepath) /proc/wrap_file2text(filepath) if(IsAdminAdvancedProcCall()) // Admins shouldnt fuck with this to_chat(usr, "File load blocked: Advanced ProcCall detected.") message_admins("[key_name(usr)] attempted to load files via advanced proc-call") log_admin("[key_name(usr)] attempted to load files via advanced proc-call") return return file2text(filepath) //checks if a file exists and contains text //returns text as a string if these conditions are met /proc/return_file_text(filename) if(fexists(filename) == 0) error("File not found ([filename])") return var/text = wrap_file2text(filename) if(!text) error("File empty ([filename])") return return text /client/proc/browse_files(root="data/logs/", max_iterations=10, list/valid_extensions=list("txt", "log", "htm", "json")) // wow why was this ever a parameter root = "data/logs/" var/path = root for(var/i=0, iError: browse_files(): File not found/Invalid file([path]).") return return path #define FTPDELAY 200 //200 tick delay to discourage spam /* This proc is a failsafe to prevent spamming of file requests. It is just a timer that only permits a download every [FTPDELAY] ticks. This can be changed by modifying FTPDELAY's value above. PLEASE USE RESPONSIBLY, Some log files canr each sizes of 4MB! */ /client/proc/file_spam_check() var/time_to_wait = GLOB.fileaccess_timer - world.time if(time_to_wait > 0) to_chat(src, "Error: file_spam_check(): Spam. Please wait [round(time_to_wait/10)] seconds.") return 1 GLOB.fileaccess_timer = world.time + FTPDELAY return 0 #undef FTPDELAY