diff options
author | Maxim Devaev <[email protected]> | 2022-03-27 22:00:23 +0300 |
---|---|---|
committer | Maxim Devaev <[email protected]> | 2022-03-27 22:00:23 +0300 |
commit | 8775cd22860a21d5b93dc3c691e25d33571e02eb (patch) | |
tree | 5e28e73f39b7879ca6f3e2544ff9e98c1655790b | |
parent | 6dc1b758b525581f1ee1caa0a013a1018b62915e (diff) |
don't spam about stopped kvmd-fan
-rw-r--r-- | kvmd/apps/__init__.py | 1 | ||||
-rw-r--r-- | kvmd/apps/kvmd/info/fan.py | 16 |
2 files changed, 15 insertions, 2 deletions
diff --git a/kvmd/apps/__init__.py b/kvmd/apps/__init__.py index 75600390..59490fc5 100644 --- a/kvmd/apps/__init__.py +++ b/kvmd/apps/__init__.py @@ -376,6 +376,7 @@ def _get_config_scheme() -> Dict: "state_poll": Option(10.0, type=valid_float_f01), }, "fan": { + "daemon": Option("kvmd-fan", type=valid_stripped_string), "unix": Option("", type=valid_abs_path, if_empty="", unpack_as="unix_path"), "timeout": Option(5.0, type=valid_float_f01), "state_poll": Option(5.0, type=valid_float_f01), diff --git a/kvmd/apps/kvmd/info/fan.py b/kvmd/apps/kvmd/info/fan.py index d4529150..1e323d04 100644 --- a/kvmd/apps/kvmd/info/fan.py +++ b/kvmd/apps/kvmd/info/fan.py @@ -34,6 +34,8 @@ from ....logging import get_logger from .... import aiotools from .... import htclient +from ..sysunit import get_service_status + from .base import BaseInfoSubmanager @@ -41,19 +43,22 @@ from .base import BaseInfoSubmanager class FanInfoSubmanager(BaseInfoSubmanager): def __init__( self, + daemon: str, unix_path: str, timeout: float, state_poll: float, ) -> None: + self.__daemon = daemon self.__unix_path = unix_path self.__timeout = timeout self.__state_poll = state_poll async def get_state(self) -> Dict: + monitored = await self.__get_monitored() return { - "monitored": bool(self.__unix_path), - "state": ((await self.__get_fan_state() if self.__unix_path else None)), + "monitored": monitored, + "state": ((await self.__get_fan_state() if monitored else None)), } async def poll_state(self) -> AsyncGenerator[Dict, None]: @@ -77,6 +82,13 @@ class FanInfoSubmanager(BaseInfoSubmanager): # ===== + async def __get_monitored(self) -> bool: + if self.__unix_path: + status = await aiotools.run_async(get_service_status, self.__daemon) + if status is not None: + return (status[0] or status[1]) + return False + async def __get_fan_state(self) -> Optional[Dict]: try: async with self.__make_http_session() as session: |