Experimental implementation of automated role pings

This commit is contained in:
Casey
2022-08-16 04:01:02 -04:00
committed by CHOMPStation2
parent 329b651700
commit 796ae69274
8 changed files with 141 additions and 6 deletions

View File

@@ -131,12 +131,13 @@ SUBSYSTEM_DEF(job)
return department_datums[primary_department] return department_datums[primary_department]
/datum/controller/subsystem/job/proc/get_ping_role(var/role)
var/datum/job/J = get_job(role)
if(J.requestable)
return get_primary_department_of_job(J)
// Someday it might be good to port code/game/jobs/job_controller.dm to here and clean it up. // Someday it might be good to port code/game/jobs/job_controller.dm to here and clean it up.
/datum/controller/subsystem/job/proc/job_debug_message(message) /datum/controller/subsystem/job/proc/job_debug_message(message)
if(debug_messages) if(debug_messages)
log_debug("JOB DEBUG: [message]") log_debug("JOB DEBUG: [message]")

View File

@@ -27,6 +27,7 @@
job_description = "An Intern does whatever is requested of them, often doing so in process of learning \ job_description = "An Intern does whatever is requested of them, often doing so in process of learning \
another job. Though they are part of the crew, they have no real authority." another job. Though they are part of the crew, they have no real authority."
timeoff_factor = 0 // Interns, noh timeoff_factor = 0 // Interns, noh
requestable = FALSE
/datum/alt_title/intern_eng /datum/alt_title/intern_eng
title = "Apprentice Engineer" title = "Apprentice Engineer"
@@ -96,6 +97,7 @@
supervisors = "nobody! You don't work here" supervisors = "nobody! You don't work here"
job_description = "A Visitor is just there to visit the place. They have no real authority or responsibility." job_description = "A Visitor is just there to visit the place. They have no real authority or responsibility."
timeoff_factor = 0 timeoff_factor = 0
requestable = FALSE
alt_titles = list("Guest" = /datum/alt_title/guest, "Traveler" = /datum/alt_title/traveler) alt_titles = list("Guest" = /datum/alt_title/guest, "Traveler" = /datum/alt_title/traveler)
/datum/job/assistant/New() /datum/job/assistant/New()

View File

@@ -23,6 +23,9 @@
/datum/alt_title/maintenance_manager /datum/alt_title/maintenance_manager
title = "Maintenance Manager" title = "Maintenance Manager"
/datum/job/chief_engineer/get_request_reasons()
return list("Engine setup", "Construction project", "Repairs necessary")
/datum/job/engineer /datum/job/engineer
pto_type = PTO_ENGINEERING pto_type = PTO_ENGINEERING
@@ -38,6 +41,9 @@
title = "Engineering Contractor" title = "Engineering Contractor"
title_blurb = "An Engineering Contractor fulfills similar duties to other engineers, but isn't directly employed by NT proper." title_blurb = "An Engineering Contractor fulfills similar duties to other engineers, but isn't directly employed by NT proper."
/datum/job/engineer/get_request_reasons()
return list("Engine setup", "Construction project", "Repairs necessary")
@@ -55,3 +61,6 @@
/datum/alt_title/disposals_tech /datum/alt_title/disposals_tech
title = "Disposals Technician" title = "Disposals Technician"
title_blurb = "A Disposals Technician is an Atmospheric Technician still and can fulfill all the same duties, although specializes more in disposals delivery system's operations and configurations." title_blurb = "A Disposals Technician is an Atmospheric Technician still and can fulfill all the same duties, although specializes more in disposals delivery system's operations and configurations."
/datum/job/atmos/get_request_reasons()
return list("Construction project", "Repairs necessary")

View File

@@ -20,6 +20,8 @@
//Do we forbid ourselves from earning PTO? //Do we forbid ourselves from earning PTO?
var/playtime_only = FALSE var/playtime_only = FALSE
var/requestable = TRUE
// Check client-specific availability rules. // Check client-specific availability rules.
/datum/job/proc/player_has_enough_pto(client/C) /datum/job/proc/player_has_enough_pto(client/C)
return timeoff_factor >= 0 || (C && LAZYACCESS(C.department_hours, pto_type) > 0) return timeoff_factor >= 0 || (C && LAZYACCESS(C.department_hours, pto_type) > 0)
@@ -58,4 +60,7 @@
if(isnum(C.play_hours[PTO_EXPLORATION])) if(isnum(C.play_hours[PTO_EXPLORATION]))
remaining_time_needed = max(0, remaining_time_needed - C.play_hours[PTO_EXPLORATION]) remaining_time_needed = max(0, remaining_time_needed - C.play_hours[PTO_EXPLORATION])
return remaining_time_needed return remaining_time_needed
return 0 return 0
/datum/job/proc/get_request_reasons()
return list()

View File

@@ -21,6 +21,9 @@
/datum/alt_title/healthcare_manager /datum/alt_title/healthcare_manager
title = "Healthcare Manager" title = "Healthcare Manager"
/datum/job/cmo/get_request_reasons()
return list("Surgery pending", "Viral outbreak")
/datum/job/doctor /datum/job/doctor
spawn_positions = 5 spawn_positions = 5
@@ -29,7 +32,6 @@
"Emergency Physician" = /datum/alt_title/emergency_physician, "Nurse" = /datum/alt_title/nurse, "Orderly" = /datum/alt_title/orderly, "Emergency Physician" = /datum/alt_title/emergency_physician, "Nurse" = /datum/alt_title/nurse, "Orderly" = /datum/alt_title/orderly,
"Virologist" = /datum/alt_title/virologist, "Medical Contractor" = /datum/alt_title/medical_contractor) "Virologist" = /datum/alt_title/virologist, "Medical Contractor" = /datum/alt_title/medical_contractor)
/datum/alt_title/physician /datum/alt_title/physician
title = "Physician" title = "Physician"
@@ -46,6 +48,9 @@
title = "Medical Contractor" title = "Medical Contractor"
title_blurb = "A Medical Contractor can be anything from a full-blown doctor to the likes of a nurse or orderly, but isn't directly employed by NT proper." title_blurb = "A Medical Contractor can be anything from a full-blown doctor to the likes of a nurse or orderly, but isn't directly employed by NT proper."
/datum/job/doctor/get_request_reasons()
return list("Surgery pending", "Viral outbreak")
/datum/job/chemist /datum/job/chemist
pto_type = PTO_MEDICAL pto_type = PTO_MEDICAL

View File

@@ -16,6 +16,9 @@
/datum/alt_title/security_manager /datum/alt_title/security_manager
title = "Security Manager" title = "Security Manager"
/datum/job/hos/get_request_reasons()
return list("Wildlife management", "Forensic investigation")
/datum/job/warden /datum/job/warden
pto_type = PTO_SECURITY pto_type = PTO_SECURITY
@@ -28,6 +31,9 @@
/datum/alt_title/armory_superintendent /datum/alt_title/armory_superintendent
title = "Armory Superintendent" title = "Armory Superintendent"
/datum/job/warden/get_request_reasons()
return list("Wildlife management")
/datum/job/detective /datum/job/detective
pto_type = PTO_SECURITY pto_type = PTO_SECURITY
@@ -39,6 +45,9 @@
/datum/alt_title/security_inspector /datum/alt_title/security_inspector
title = "Security Inspector" title = "Security Inspector"
/datum/job/detective/get_request_reasons()
return list("Forensic investigation")
/datum/job/officer /datum/job/officer
total_positions = 5 total_positions = 5
@@ -58,3 +67,9 @@
/datum/alt_title/security_contractor /datum/alt_title/security_contractor
title = "Security Contractor" title = "Security Contractor"
<<<<<<< HEAD
=======
/datum/job/officer/get_request_reasons()
return list("Wildlife management")
>>>>>>> 38423301cb... Merge pull request #13492 from Heroman3003/role-pings

View File

@@ -113,6 +113,7 @@
job_description = "A Clown is there to entertain the crew and keep high morale using various harmless pranks and ridiculous jokes!" job_description = "A Clown is there to entertain the crew and keep high morale using various harmless pranks and ridiculous jokes!"
whitelist_only = 1 whitelist_only = 1
latejoin_only = 0 latejoin_only = 0
requestable = FALSE
outfit_type = /decl/hierarchy/outfit/job/clown outfit_type = /decl/hierarchy/outfit/job/clown
pto_type = PTO_CIVILIAN pto_type = PTO_CIVILIAN
alt_titles = list("Jester" = /datum/alt_title/jester, "Fool" = /datum/alt_title/fool) alt_titles = list("Jester" = /datum/alt_title/jester, "Fool" = /datum/alt_title/fool)
@@ -144,6 +145,7 @@
alt_titles = list("Poseur" = /datum/alt_title/poseur) alt_titles = list("Poseur" = /datum/alt_title/poseur)
whitelist_only = 1 whitelist_only = 1
latejoin_only = 0 latejoin_only = 0
requestable = FALSE
outfit_type = /decl/hierarchy/outfit/job/mime outfit_type = /decl/hierarchy/outfit/job/mime
pto_type = PTO_CIVILIAN pto_type = PTO_CIVILIAN

View File

@@ -1,3 +1,5 @@
var/global/last_fax_role_request
/obj/machinery/photocopier/faxmachine /obj/machinery/photocopier/faxmachine
req_one_access = list() req_one_access = list()
@@ -94,6 +96,20 @@
world.TgsTargetedChatBroadcast("FAX: [sanitize(faxname)] / [sanitize(sent.name)] - SENT BY: [sanitize(sender.name)] - FAXID: **[sanitize(faxid)]** [contents]", TRUE) world.TgsTargetedChatBroadcast("FAX: [sanitize(faxname)] / [sanitize(sent.name)] - SENT BY: [sanitize(sender.name)] - FAXID: **[sanitize(faxid)]** [contents]", TRUE)
//YW EDIT END //YW EDIT END
/**
* Call the chat webhook to transmit a notification of a job request
*/
/obj/machinery/photocopier/faxmachine/proc/message_chat_rolerequest(var/font_colour="#006100", var/role_to_ping, var/reason, var/jobname)
if(config.chat_webhook_url)
spawn(0)
var/query_string = "type=rolerequest"
query_string += "&key=[url_encode(config.chat_webhook_key)]"
query_string += "&ping=[url_encode(role_to_ping)]"
query_string += "&color=[url_encode(font_colour)]"
query_string += "&reason=[url_encode(reason)]"
query_string += "&job=[url_encode(jobname)]"
world.Export("[config.chat_webhook_url]?[query_string]")
// //
// Overrides/additions to stock defines go here, as well as hooks. Sort them by // Overrides/additions to stock defines go here, as well as hooks. Sort them by
// the object they are overriding. So all /mob/living together, etc. // the object they are overriding. So all /mob/living together, etc.
@@ -102,3 +118,83 @@
var/chat_webhook_url = "" // URL of the webhook for sending announcements/faxes to discord chat. var/chat_webhook_url = "" // URL of the webhook for sending announcements/faxes to discord chat.
var/chat_webhook_key = "" // Shared secret for authenticating to the chat webhook var/chat_webhook_key = "" // Shared secret for authenticating to the chat webhook
var/fax_export_dir = "data/faxes" // Directory in which to write exported fax HTML files. var/fax_export_dir = "data/faxes" // Directory in which to write exported fax HTML files.
/obj/machinery/photocopier/faxmachine/verb/request_roles()
set name = "Staff Request Form"
set category = "Object"
set src in oview(1)
var/mob/living/L = usr
if(!L || !isturf(L.loc) || !isliving(L))
return
if(!ishuman(L) && !issilicon(L))
return
if(L.stat || L.restrained())
return
if(last_fax_role_request && (world.time - last_fax_role_request < 5 MINUTES))
to_chat(L, "<span class='warning'>The global automated relays are still recalibrating. Try again later or relay your request in written form for processing.</span>")
return
var/confirmation = tgui_alert(L, "Are you sure you want to send automated crew request?", "Confirmation", list("Yes", "No", "Cancel"))
if(confirmation != "Yes")
return
var/list/jobs = list()
for(var/datum/department/dept as anything in SSjob.get_all_department_datums())
if(!dept.assignable || dept.centcom_only)
continue
for(var/job in SSjob.get_job_titles_in_department(dept.name))
var/datum/job/J = SSjob.get_job(job)
if(J.requestable)
jobs |= job
var/role = tgui_input_list(L, "Pick the job to request.", "Job Request", jobs)
if(!role)
return
var/datum/job/job_to_request = SSjob.get_job(role)
var/reason = "Unspecified"
var/list/possible_reasons = list("Unspecified", "General duties", "Emergency situation")
possible_reasons += job_to_request.get_request_reasons()
reason = tgui_input_list(L, "Pick request reason.", "Request reason", possible_reasons)
var/final_conf = tgui_alert(L, "You are about to request [role]. Are you sure?", "Confirmation", list("Yes", "No", "Cancel"))
if(final_conf != "Yes")
return
var/datum/department/ping_dept = SSjob.get_ping_role(role)
if(!ping_dept)
to_chat(L, "<span class='warning'>Selected job cannot be requested for \[ERRORDEPTNOTFOUND] reason. Please report this to system administrator.</span>")
return
var/message_color = "#FFFFFF"
var/ping_name = null
switch(ping_dept.name)
if(DEPARTMENT_COMMAND)
ping_name = "Command"
if(DEPARTMENT_SECURITY)
ping_name = "Security"
if(DEPARTMENT_ENGINEERING)
ping_name = "Engineering"
if(DEPARTMENT_MEDICAL)
ping_name = "Medical"
if(DEPARTMENT_RESEARCH)
ping_name = "Research"
if(DEPARTMENT_CARGO)
ping_name = "Supply"
if(DEPARTMENT_CIVILIAN)
ping_name = "Service"
if(DEPARTMENT_PLANET)
ping_name = "Expedition"
if(DEPARTMENT_SYNTHETIC)
ping_name = "Silicon"
//if(DEPARTMENT_TALON)
// ping_name = "Offmap"
if(!ping_name)
to_chat(L, "<span class='warning'>Selected job cannot be requested for \[ERRORUNKNOWNDEPT] reason. Please report this to system administrator.</span>")
return
message_color = ping_dept.color
message_chat_rolerequest(message_color, ping_name, reason, role)
last_fax_role_request = world.time