diff options
Diffstat (limited to 'kvmd/apps/cleanup')
-rw-r--r-- | kvmd/apps/cleanup/__init__.py | 70 |
1 files changed, 52 insertions, 18 deletions
diff --git a/kvmd/apps/cleanup/__init__.py b/kvmd/apps/cleanup/__init__.py index e97c1329..3314066c 100644 --- a/kvmd/apps/cleanup/__init__.py +++ b/kvmd/apps/cleanup/__init__.py @@ -21,33 +21,27 @@ import os -import subprocess +import signal import time from typing import List from typing import Optional +import psutil + from ...logging import get_logger +from ...yamlconf import Section + from ... import gpio from .. import init # ===== -def main(argv: Optional[List[str]]=None) -> None: - config = init( - prog="kvmd-cleanup", - description="Kill KVMD and clear resources", - argv=argv, - load_hid=True, - load_atx=True, - load_msd=True, - )[2].kvmd - +def _clear_gpio(config: Section) -> None: logger = get_logger(0) - logger.info("Cleaning up ...") with gpio.bcm(): for (name, pin) in [ *([ @@ -74,15 +68,30 @@ def main(argv: Optional[List[str]]=None) -> None: except Exception: logger.exception("Can't clear GPIO pin=%d (%s)", pin, name) + +def _kill_streamer(config: Section) -> None: + logger = get_logger(0) + streamer = os.path.basename(config.streamer.cmd[0]) + logger.info("Trying to find and kill %r ...", streamer) - try: - subprocess.check_output(["killall", streamer], stderr=subprocess.STDOUT) - time.sleep(3) - subprocess.check_output(["killall", "-9", streamer], stderr=subprocess.STDOUT) - except subprocess.CalledProcessError: # pragma: nocover - pass + for proc in psutil.process_iter(): + attrs = proc.as_dict(attrs=["name"]) + if os.path.basename(attrs.get("name", "")) == streamer: + try: + proc.send_signal(signal.SIGTERM) + except Exception: + logger.exception("Can't send SIGTERM to streamer with pid=%d", proc.pid) + time.sleep(3) + if proc.is_running(): + try: + proc.send_signal(signal.SIGKILL) + except Exception: + logger.exception("Can't send SIGKILL to streamer with pid=%d", proc.pid) + +def _remove_sockets(config: Section) -> None: + logger = get_logger(0) for (owner, unix_path) in [ ("KVMD", config.server.unix), ("streamer", config.streamer.unix), @@ -94,4 +103,29 @@ def main(argv: Optional[List[str]]=None) -> None: except Exception: # pragma: nocover logger.exception("Can't remove %s socket %r", owner, unix_path) + +# ===== +def main(argv: Optional[List[str]]=None) -> None: + config = init( + prog="kvmd-cleanup", + description="Kill KVMD and clear resources", + argv=argv, + load_hid=True, + load_atx=True, + load_msd=True, + )[2].kvmd + + logger = get_logger(0) + logger.info("Cleaning up ...") + + for method in [ + _clear_gpio, + _kill_streamer, + _remove_sockets, + ]: + try: + method(config) + except Exception: + pass + logger.info("Bye-bye") |