diff options
author | Maxim Devaev <[email protected]> | 2024-08-30 19:52:11 +0300 |
---|---|---|
committer | Maxim Devaev <[email protected]> | 2024-08-30 19:52:11 +0300 |
commit | fb9d860cf2594797aefff817c04e8c0f26712bf6 (patch) | |
tree | 02091f2266a57c9473fed668a534a0f64f969159 /kvmd/apps | |
parent | 5045d8b3d70cc558908e8da479ee2664e7ab9c65 (diff) |
pikvm/kvmd#182: improved dbus_next fix
Diffstat (limited to 'kvmd/apps')
-rw-r--r-- | kvmd/apps/kvmd/sysunit.py | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/kvmd/apps/kvmd/sysunit.py b/kvmd/apps/kvmd/sysunit.py index 11207230..eea397ed 100644 --- a/kvmd/apps/kvmd/sysunit.py +++ b/kvmd/apps/kvmd/sysunit.py @@ -35,6 +35,7 @@ class SystemdUnitInfo: self.__bus: (dbus_next.aio.MessageBus | None) = None self.__intr: (dbus_next.introspection.Node | None) = None self.__manager: (dbus_next.aio.proxy_object.ProxyInterface | None) = None + self.__requested = False async def get_status(self, name: str) -> tuple[bool, bool]: assert self.__bus is not None @@ -49,6 +50,7 @@ class SystemdUnitInfo: unit = self.__bus.get_proxy_object("org.freedesktop.systemd1", unit_p, self.__intr) unit_props = unit.get_interface("org.freedesktop.DBus.Properties") started = ((await unit_props.call_get("org.freedesktop.systemd1.Unit", "ActiveState")).value == "active") # type: ignore + self.__requested = True except dbus_next.errors.DBusError as err: if err.type != "org.freedesktop.systemd1.NoSuchUnit": raise @@ -76,11 +78,12 @@ class SystemdUnitInfo: try: if self.__bus is not None: try: - await self.__manager.call_get_default_target() - except: - pass - self.__bus.disconnect() - await self.__bus.wait_for_disconnect() + # XXX: Workaround for dbus_next bug: https://github.com/pikvm/kvmd/pull/182 + if not self.__requested: + await self.__manager.call_get_default_target() # type: ignore + finally: + self.__bus.disconnect() + await self.__bus.wait_for_disconnect() except Exception: pass self.__manager = None |