mirror of
https://github.com/vgstation-coders/vgstation13.git
synced 2025-12-09 07:57:50 +00:00
133 lines
3.3 KiB
Plaintext
133 lines
3.3 KiB
Plaintext
|
|
|
|
var/jobban_runonce // Updates legacy bans with new info
|
|
var/jobban_keylist[0] //to store the keys & ranks
|
|
|
|
/proc/jobban_fullban(mob/M, rank, reason)
|
|
if (!M || !M.key)
|
|
return
|
|
jobban_keylist.Add(text("[M.ckey] - [rank] ## [reason]"))
|
|
jobban_savebanfile()
|
|
|
|
/proc/jobban_client_fullban(ckey, rank)
|
|
if (!ckey || !rank)
|
|
return
|
|
jobban_keylist.Add(text("[ckey] - [rank]"))
|
|
jobban_savebanfile()
|
|
|
|
//returns a reason if M is banned from rank, returns 0 otherwise
|
|
/proc/jobban_isbanned(mob/M, rank)
|
|
if(M && rank)
|
|
/*
|
|
if(_jobban_isbanned(M, rank))
|
|
return "Reason Unspecified" //for old jobban
|
|
if (guest_jobbans(rank))
|
|
if(config.guest_jobban && IsGuestKey(M.key))
|
|
return "Guest Job-ban"
|
|
if(config.usewhitelist && !check_whitelist(M))
|
|
return "Whitelisted Job"
|
|
*/
|
|
for (var/s in jobban_keylist)
|
|
if( findtext(s,"[M.ckey] - [rank]") == 1 )
|
|
var/startpos = findtext(s, "## ")+3
|
|
if(startpos && startpos<length(s))
|
|
var/text = copytext(s, startpos, 0)
|
|
if(text)
|
|
return text
|
|
return "Reason Unspecified"
|
|
return 0
|
|
|
|
/*
|
|
DEBUG
|
|
/mob/verb/list_all_jobbans()
|
|
set name = "list all jobbans"
|
|
|
|
for(var/s in jobban_keylist)
|
|
to_chat(world, s)
|
|
|
|
/mob/verb/reload_jobbans()
|
|
set name = "reload jobbans"
|
|
|
|
jobban_loadbanfile()
|
|
*/
|
|
|
|
/proc/jobban_loadbanfile()
|
|
if(config.ban_legacy_system)
|
|
var/savefile/S=new("data/job_full.ban")
|
|
S["keys[0]"] >> jobban_keylist
|
|
log_admin("Loading jobban_rank")
|
|
S["runonce"] >> jobban_runonce
|
|
|
|
if (!length(jobban_keylist))
|
|
jobban_keylist=list()
|
|
log_admin("jobban_keylist was empty")
|
|
else
|
|
if(!SSdbcore.Connect())
|
|
diary << "Database connection failed. Reverting to the legacy ban system."
|
|
config.ban_legacy_system = 1
|
|
jobban_loadbanfile()
|
|
return
|
|
|
|
//Job permabans
|
|
var/datum/DBQuery/query = SSdbcore.NewQuery("SELECT ckey, job FROM erro_ban WHERE bantype = :bantype AND isnull(unbanned)",
|
|
list(
|
|
"bantype" = "JOB_PERMABAN"
|
|
))
|
|
if(!query.Execute(FALSE))
|
|
message_admins("Error: [query.ErrorMsg()]")
|
|
log_sql("Error: [query.ErrorMsg()]")
|
|
qdel(query)
|
|
return
|
|
|
|
while(query.NextRow())
|
|
var/ckey = query.item[1]
|
|
var/job = query.item[2]
|
|
jobban_keylist.Add("[ckey] - [job]")
|
|
qdel(query)
|
|
//Job tempbans
|
|
var/datum/DBQuery/query1 = SSdbcore.NewQuery("SELECT ckey, job FROM erro_ban WHERE bantype = :bantype AND isnull(unbanned) AND expiration_time > Now()",
|
|
list(
|
|
"bantype" = "JOB_TEMPBAN",
|
|
))
|
|
if(!query1.Execute(FALSE))
|
|
log_sql("Error: [query1.ErrorMsg()]")
|
|
qdel(query1)
|
|
return
|
|
|
|
while(query1.NextRow())
|
|
var/ckey = query1.item[1]
|
|
var/job = query1.item[2]
|
|
jobban_keylist.Add("[ckey] - [job]")
|
|
qdel(query1)
|
|
|
|
/proc/jobban_savebanfile()
|
|
var/savefile/S = new("data/job_full.ban")
|
|
S["keys[0]"] << jobban_keylist
|
|
|
|
/proc/jobban_unban(mob/M, rank)
|
|
jobban_remove("[M.ckey] - [rank]")
|
|
jobban_savebanfile()
|
|
|
|
|
|
/proc/ban_unban_log_save(var/formatted_log)
|
|
text2file(formatted_log,"data/ban_unban_log.txt")
|
|
|
|
|
|
/proc/jobban_updatelegacybans()
|
|
if(!jobban_runonce)
|
|
log_admin("Updating jobbanfile!")
|
|
// Updates bans.. Or fixes them. Either way.
|
|
for(var/T in jobban_keylist)
|
|
if(!T)
|
|
continue
|
|
jobban_runonce++ //don't run this update again
|
|
|
|
|
|
/proc/jobban_remove(X)
|
|
for (var/i = 1; i <= length(jobban_keylist); i++)
|
|
if( findtext(jobban_keylist[i], "[X]") )
|
|
jobban_keylist.Remove(jobban_keylist[i])
|
|
jobban_savebanfile()
|
|
return 1
|
|
return 0
|