From 5a6a5adc145cdcaac91e3d26ef05b642807625bf Mon Sep 17 00:00:00 2001 From: Lucy Date: Sun, 1 Dec 2024 21:22:19 -0500 Subject: [PATCH] Use normal config entries for Plexora (instead of its own .json file) --- .../configuration/entries/monkestation.dm | 10 +++++ config/config.txt | 1 + config/plexora.json | 5 --- config/plexora.txt | 5 +++ .../code/controllers/subsystem/plexora.dm | 44 +++++++++---------- 5 files changed, 38 insertions(+), 27 deletions(-) delete mode 100644 config/plexora.json create mode 100644 config/plexora.txt diff --git a/code/controllers/configuration/entries/monkestation.dm b/code/controllers/configuration/entries/monkestation.dm index c49237131fec..988fae0853c4 100644 --- a/code/controllers/configuration/entries/monkestation.dm +++ b/code/controllers/configuration/entries/monkestation.dm @@ -62,3 +62,13 @@ . = ..() if(.) config_entry_value *= 600 // documented as minutes + +/datum/config_entry/flag/plexora_enabled + +/datum/config_entry/string/plexora_url + default = "http://127.0.0.1:1330" + +/datum/config_entry/string/plexora_url/ValidateAndSet(str_val) + if(!findtext(str_val, GLOB.is_http_protocol)) + return FALSE + return ..() diff --git a/config/config.txt b/config/config.txt index 464b95aa5078..1078e1d6e593 100644 --- a/config/config.txt +++ b/config/config.txt @@ -8,6 +8,7 @@ $include resources.txt $include interviews.txt $include lua.txt $include auxtools.txt +$include plexora.txt # You can use the @ character at the beginning of a config option to lock it from being edited in-game # Example usage: diff --git a/config/plexora.json b/config/plexora.json deleted file mode 100644 index cac6b9114fca..000000000000 --- a/config/plexora.json +++ /dev/null @@ -1,5 +0,0 @@ -{ - "enabled": true, - "ip": "127.0.0.1", - "port": 1330 -} diff --git a/config/plexora.txt b/config/plexora.txt new file mode 100644 index 000000000000..b7ceb1904d69 --- /dev/null +++ b/config/plexora.txt @@ -0,0 +1,5 @@ +# Uncomment this to enable Plexora. You probably won't need this, this is really only used by the main Monkestation server. +#PLEXORA_ENABLED + +# The base URL for the Plexora instance. +PLEXORA_URL http://127.0.0.1:1330 diff --git a/monkestation/code/controllers/subsystem/plexora.dm b/monkestation/code/controllers/subsystem/plexora.dm index 3068facc39dd..47a10705a989 100644 --- a/monkestation/code/controllers/subsystem/plexora.dm +++ b/monkestation/code/controllers/subsystem/plexora.dm @@ -20,8 +20,8 @@ INVOKE_ASYNC(SSplexora, TYPE_PROC_REF(/datum/controller/subsystem/plexora, topic_listener_response), input["emitter_token"], returning); \ return; \ }; - #define AUTH_HEADER ("Basic " + CONFIG_GET(string/comms_key)) +#define OLD_PLEXORA_CONFIG "config/plexora.json" SUBSYSTEM_DEF(plexora) name = "Plexora" @@ -36,11 +36,9 @@ SUBSYSTEM_DEF(plexora) // MUST INCREMENT BY ONE FOR EVERY CHANGE MADE TO PLEXORA var/version_increment_counter = 2 - var/configuration_path = "config/plexora.json" var/plexora_is_alive = FALSE var/vanderlin_available = FALSE - var/http_root = "" - var/http_port = 0 + var/base_url = "" var/enabled = TRUE var/tripped_bad_version = FALSE var/list/default_headers @@ -49,16 +47,7 @@ SUBSYSTEM_DEF(plexora) var/hrp_available = FALSE /datum/controller/subsystem/plexora/Initialize() - if (!rustg_file_exists(configuration_path)) - stack_trace("SSplexora has no configuration file! (missing: [configuration_path])") - enabled = FALSE - flags |= SS_NO_FIRE - return SS_INIT_FAILURE - - // Get config - var/list/config = json_decode(rustg_file_read(configuration_path)) - - if (!config["enabled"]) + if(!CONFIG_GET(flag/plexora_enabled) && !load_old_plexora_config()) enabled = FALSE flags |= SS_NO_FIRE return SS_INIT_NO_NEED @@ -70,8 +59,7 @@ SUBSYSTEM_DEF(plexora) flags |= SS_NO_FIRE return SS_INIT_FAILURE - http_root = config["ip"] - http_port = config["port"] + base_url = CONFIG_GET(string/plexora_url) // Do a ping test to check if Plexora is actually running if (!is_plexora_alive()) @@ -91,19 +79,30 @@ SUBSYSTEM_DEF(plexora) flags |= SS_NO_INIT // Make extra sure we don't initialize twice. initialized = SSplexora.initialized plexora_is_alive = SSplexora.plexora_is_alive - http_root = SSplexora.http_root - http_port = SSplexora.http_port + base_url = SSplexora.base_url enabled = SSplexora.enabled tripped_bad_version = SSplexora.tripped_bad_version default_headers = SSplexora.default_headers if(initialized && !enabled) flags |= SS_NO_FIRE +// compat thing so that it'll load plexora.json if it's still used +/datum/controller/subsystem/plexora/proc/load_old_plexora_config() + if(!rustg_file_exists(OLD_PLEXORA_CONFIG)) + return FALSE + var/list/old_config = json_decode(rustg_file_read(OLD_PLEXORA_CONFIG)) + if(!old_config["enabled"]) + return FALSE + stack_trace("Falling back to [OLD_PLEXORA_CONFIG], you should really migrate to the PLEXORA_ENABLED and PLEXORA_URL config entries!") + CONFIG_SET(flag/plexora_enabled, TRUE) + CONFIG_SET(string/plexora_url, "http://[old_config["ip"]]:[old_config["port"]]") + return TRUE + /datum/controller/subsystem/plexora/proc/is_plexora_alive() . = FALSE if(!enabled) return - var/datum/http_request/request = new(RUSTG_HTTP_METHOD_GET, "http://[http_root]:[http_port]/alive") + var/datum/http_request/request = new(RUSTG_HTTP_METHOD_GET, "[base_url]/alive") request.begin_async() UNTIL_OR_TIMEOUT(request.is_complete(), 10 SECONDS) var/datum/http_response/response = request.into_response() @@ -132,7 +131,7 @@ SUBSYSTEM_DEF(plexora) http_request( RUSTG_HTTP_METHOD_POST, - "http://[http_root]:[http_port]/status", + "[base_url]/status", json_encode(status), default_headers ).begin_async() @@ -209,7 +208,7 @@ SUBSYSTEM_DEF(plexora) "id" = id ) - var/datum/http_request/request = new(RUSTG_HTTP_METHOD_GET, "http://[http_root]:[http_port]/byondserver_alive", json_encode(body)) + var/datum/http_request/request = new(RUSTG_HTTP_METHOD_GET, "[base_url]/byondserver_alive", json_encode(body)) request.begin_async() UNTIL_OR_TIMEOUT(request.is_complete(), 5 SECONDS) var/datum/http_response/response = request.into_response() @@ -360,7 +359,7 @@ SUBSYSTEM_DEF(plexora) var/datum/http_request/request = new( RUSTG_HTTP_METHOD_POST, - "http://[http_root]:[http_port]/[path]", + "[base_url]/[path]", json_encode(body), default_headers, "tmp/response.json" @@ -977,5 +976,6 @@ SUBSYSTEM_DEF(plexora) html = "Mentor PM: [key_name_mentor(sender, honked_client, FALSE, FALSE)]->[key_name_mentor(recipient, honked_client, FALSE, FALSE)]: [message]", confidential = TRUE) +#undef OLD_PLEXORA_CONFIG #undef AUTH_HEADER #undef TOPIC_EMITTER