diff options
Diffstat (limited to 'kvmd/apps')
-rw-r--r-- | kvmd/apps/__init__.py | 17 | ||||
-rw-r--r-- | kvmd/apps/kvmd/streamer.py | 6 | ||||
-rw-r--r-- | kvmd/apps/otgnet/__init__.py | 16 |
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 |