summaryrefslogtreecommitdiff
path: root/kvmd
diff options
context:
space:
mode:
authorDevaev Maxim <[email protected]>2019-05-11 21:36:22 +0300
committerDevaev Maxim <[email protected]>2019-05-11 21:36:22 +0300
commitcf2ed326a3d2f5ccdab2778f3603bfe31c58c556 (patch)
tree4b6cc288b3bd494827c5aba1e2892d4e69e4386a /kvmd
parent447e3c2d9ec2c75f58cee1399655027150394864 (diff)
handle disabled services
Diffstat (limited to 'kvmd')
-rw-r--r--kvmd/apps/kvmd/info.py16
1 files changed, 14 insertions, 2 deletions
diff --git a/kvmd/apps/kvmd/info.py b/kvmd/apps/kvmd/info.py
index 905cf46e..5e76e3c8 100644
--- a/kvmd/apps/kvmd/info.py
+++ b/kvmd/apps/kvmd/info.py
@@ -27,6 +27,7 @@ import contextlib
from typing import Dict
import dbus # pylint: disable=import-error
+import dbus.exceptions
from ...logging import get_logger
@@ -63,11 +64,22 @@ class InfoManager:
def __is_daemon_enabled(self, name: str) -> bool:
if not name.startswith(".service"):
name += ".service"
+
try:
with contextlib.closing(dbus.SystemBus()) as bus:
systemd = bus.get_object("org.freedesktop.systemd1", "/org/freedesktop/systemd1") # pylint: disable=no-member
- get_unit_state = systemd.get_dbus_method("GetUnitFileState", "org.freedesktop.systemd1.Manager")
- return (get_unit_state(name) in ["enabled", "enabled-runtime", "static", "indirect", "generated"])
+ manager = dbus.Interface(systemd, dbus_interface="org.freedesktop.systemd1.Manager")
+
+ try:
+ unit_proxy = bus.get_object("org.freedesktop.systemd1", manager.GetUnit(name)) # pylint: disable=no-member
+ unit_properties = dbus.Interface(unit_proxy, dbus_interface="org.freedesktop.DBus.Properties")
+ enabled = (unit_properties.Get("org.freedesktop.systemd1.Unit", "ActiveState") == "active")
+ except dbus.exceptions.DBusException as err:
+ if "NoSuchUnit" not in str(err):
+ raise
+ enabled = False
+
+ return (enabled or (manager.GetUnitFileState(name) in ["enabled", "enabled-runtime", "static", "indirect", "generated"]))
except Exception as err:
get_logger(0).error("Can't get info about the service %r: %s: %s", name, type(err).__name__, str(err))
return True