From 88bd9dab5fce9e85972818400a827701caacd467 Mon Sep 17 00:00:00 2001 From: David Härdeman Date: Tue, 9 Jun 2020 12:11:06 +0200 Subject: Add config parameters for stop and start methods --- cfgdir.c | 49 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) (limited to 'cfgdir.c') diff --git a/cfgdir.c b/cfgdir.c index a43988e..6f01189 100644 --- a/cfgdir.c +++ b/cfgdir.c @@ -26,6 +26,15 @@ enum scfg_keys { SCFG_KEY_LOCAL, SCFG_KEY_REMOTE, SCFG_KEY_IDLE_TIMEOUT, + SCFG_KEY_STOP_METHOD, + SCFG_KEY_START_METHOD, + SCFG_KEY_STOP_EXEC, + SCFG_KEY_START_EXEC, + /* + SCFG_KEY_SYSTEMD_SERVICE, + SCFG_KEY_RCON, + SCFG_KEY_RCON_PASSWORD, + */ }; struct cfg_key_value_map scfg_key_map[] = { @@ -53,6 +62,22 @@ struct cfg_key_value_map scfg_key_map[] = { .key_name = "idle_timeout", .key_value = SCFG_KEY_IDLE_TIMEOUT, .value_type = CFG_VAL_TYPE_UINT16, + }, { + .key_name = "stop_method", + .key_value = SCFG_KEY_STOP_METHOD, + .value_type = CFG_VAL_TYPE_STRING, + }, { + .key_name = "start_method", + .key_value = SCFG_KEY_START_METHOD, + .value_type = CFG_VAL_TYPE_STRING, + }, { + .key_name = "stop_exec", + .key_value = SCFG_KEY_STOP_EXEC, + .value_type = CFG_VAL_TYPE_STRING, + }, { + .key_name = "start_exec", + .key_value = SCFG_KEY_START_EXEC, + .value_type = CFG_VAL_TYPE_STRING, }, { .key_name = NULL, .key_value = SCFG_KEY_INVALID, @@ -126,6 +151,30 @@ scfg_parse(struct cfg *cfg, struct server *scfg) return; break; + case SCFG_KEY_STOP_METHOD: + if (!strcmp(value.str, "exec")) { + if (server_set_stop_method(cfg, scfg, SERVER_STOP_METHOD_EXEC)) + break; + } + return; + + case SCFG_KEY_START_METHOD: + if (!strcmp(value.str, "exec")) { + if (server_set_start_method(cfg, scfg, SERVER_START_METHOD_EXEC)) + break; + } + return; + + case SCFG_KEY_STOP_EXEC: + if (!server_set_stop_exec(cfg, scfg, value.str)) + return; + break; + + case SCFG_KEY_START_EXEC: + if (!server_set_start_exec(cfg, scfg, value.str)) + return; + break; + case SCFG_KEY_INVALID: default: break; -- cgit v1.2.3