summaryrefslogtreecommitdiff
path: root/kvmd/apps
diff options
context:
space:
mode:
Diffstat (limited to 'kvmd/apps')
-rw-r--r--kvmd/apps/__init__.py17
-rw-r--r--kvmd/apps/kvmd/streamer.py6
-rw-r--r--kvmd/apps/otgnet/__init__.py16
3 files changed, 27 insertions, 12 deletions
diff --git a/kvmd/apps/__init__.py b/kvmd/apps/__init__.py
index 80fc82ec..ed6a3101 100644
--- a/kvmd/apps/__init__.py
+++ b/kvmd/apps/__init__.py
@@ -516,7 +516,10 @@ def _get_config_scheme() -> Dict:
},
"commands": {
- "pre_start_cmd": Option(["/bin/true", "pre-start"], type=valid_command),
+ "pre_start_cmd": Option(["/bin/true", "pre-start"], type=valid_command),
+ "pre_start_cmd_remove": Option([], type=valid_options),
+ "pre_start_cmd_append": Option([], type=valid_options),
+
"post_start_cmd": Option([
"/usr/bin/systemd-run",
"--unit=kvmd-otgnet-dnsmasq",
@@ -532,12 +535,20 @@ def _get_config_scheme() -> Dict:
"--dhcp-option=6",
"--keep-in-foreground",
], type=valid_command),
- "pre_stop_cmd": Option([
+ "post_start_cmd_remove": Option([], type=valid_options),
+ "post_start_cmd_append": Option([], type=valid_options),
+
+ "pre_stop_cmd": Option([
"/usr/bin/systemctl",
"stop",
"kvmd-otgnet-dnsmasq",
], type=valid_command),
- "post_stop_cmd": Option(["/bin/true", "post-stop"], type=valid_command),
+ "pre_stop_cmd_remove": Option([], type=valid_options),
+ "pre_stop_cmd_append": Option([], type=valid_options),
+
+ "post_stop_cmd": Option(["/bin/true", "post-stop"], type=valid_command),
+ "post_stop_cmd_remove": Option([], type=valid_options),
+ "post_stop_cmd_append": Option([], type=valid_options),
},
},
diff --git a/kvmd/apps/kvmd/streamer.py b/kvmd/apps/kvmd/streamer.py
index b7f57797..ea14e41a 100644
--- a/kvmd/apps/kvmd/streamer.py
+++ b/kvmd/apps/kvmd/streamer.py
@@ -179,11 +179,7 @@ class Streamer: # pylint: disable=too-many-instance-attributes
self.__process_name_prefix = process_name_prefix
- self.__cmd = [
- cmd[0], # Executable
- *filter((lambda item: item not in cmd_remove), cmd[1:]),
- *cmd_append,
- ]
+ self.__cmd = tools.build_cmd(cmd, cmd_remove, cmd_append)
self.__params = _StreamerParams(**params_kwargs)
diff --git a/kvmd/apps/otgnet/__init__.py b/kvmd/apps/otgnet/__init__.py
index d3b32549..ac5b007e 100644
--- a/kvmd/apps/otgnet/__init__.py
+++ b/kvmd/apps/otgnet/__init__.py
@@ -35,6 +35,7 @@ from ...logging import get_logger
from ...yamlconf import Section
from ... import env
+from ... import tools
from ... import aioproc
from .. import init
@@ -74,10 +75,17 @@ class _Service: # pylint: disable=too-many-instance-attributes
self.__forward_iface: str = config.otgnet.firewall.forward_iface
self.__iptables_cmd: List[str] = config.otgnet.firewall.iptables_cmd
- self.__pre_start_cmd: List[str] = config.otgnet.commands.pre_start_cmd
- self.__post_start_cmd: List[str] = config.otgnet.commands.post_start_cmd
- self.__pre_stop_cmd: List[str] = config.otgnet.commands.pre_stop_cmd
- self.__post_stop_cmd: List[str] = config.otgnet.commands.post_stop_cmd
+ def build_cmd(key: str) -> List[str]:
+ return tools.build_cmd(
+ getattr(config.otgnet.commands, key),
+ getattr(config.otgnet.commands, f"{key}_remove"),
+ getattr(config.otgnet.commands, f"{key}_append"),
+ )
+
+ self.__pre_start_cmd: List[str] = build_cmd("pre_start_cmd")
+ self.__post_start_cmd: List[str] = build_cmd("post_start_cmd")
+ self.__pre_stop_cmd: List[str] = build_cmd("pre_stop_cmd")
+ self.__post_stop_cmd: List[str] = build_cmd("post_stop_cmd")
self.__gadget: str = config.otg.gadget
self.__driver: str = config.otg.devices.ethernet.driver