mirror of
https://github.com/mofeng-git/One-KVM.git
synced 2025-12-13 09:40:30 +08:00
refactoring
This commit is contained in:
parent
294a94fc0c
commit
447e3c2d9e
@ -22,11 +22,11 @@
|
|||||||
|
|
||||||
import os
|
import os
|
||||||
import asyncio
|
import asyncio
|
||||||
|
import contextlib
|
||||||
|
|
||||||
from typing import Dict
|
from typing import Dict
|
||||||
|
|
||||||
import dbus # pylint: disable=import-error
|
import dbus # pylint: disable=import-error
|
||||||
import dbus.exceptions # pylint: disable=import-error
|
|
||||||
|
|
||||||
from ...logging import get_logger
|
from ...logging import get_logger
|
||||||
|
|
||||||
@ -48,26 +48,26 @@ class InfoManager:
|
|||||||
return (await asyncio.get_running_loop().run_in_executor(None, load_yaml_file, self.__meta_path))
|
return (await asyncio.get_running_loop().run_in_executor(None, load_yaml_file, self.__meta_path))
|
||||||
|
|
||||||
async def get_extras(self) -> Dict:
|
async def get_extras(self) -> Dict:
|
||||||
return (await asyncio.get_running_loop().run_in_executor(None, self.__sync_get_extras))
|
return (await asyncio.get_running_loop().run_in_executor(None, self.__inner_get_extras))
|
||||||
|
|
||||||
def __sync_get_extras(self) -> Dict:
|
|
||||||
try:
|
|
||||||
bus = dbus.SystemBus()
|
|
||||||
|
|
||||||
def is_enabled(daemon: str) -> bool:
|
|
||||||
obj = bus.get_object("org.freedesktop.systemd1", "/org/freedesktop/systemd1")
|
|
||||||
get_unit_state = obj.get_dbus_method("GetUnitFileState", "org.freedesktop.systemd1.Manager")
|
|
||||||
return (get_unit_state(daemon + ".service") in ["enabled", "enabled-runtime", "static", "indirect", "generated"])
|
|
||||||
|
|
||||||
except dbus.exceptions.DBusException as err:
|
|
||||||
get_logger(0).error("Can't get services info: %s: %s", type(err).__name__, str(err))
|
|
||||||
is_enabled = (lambda daemon: True)
|
|
||||||
|
|
||||||
|
def __inner_get_extras(self) -> Dict:
|
||||||
extras: Dict[str, Dict] = {}
|
extras: Dict[str, Dict] = {}
|
||||||
for app in os.listdir(self.__extras_path):
|
for app in os.listdir(self.__extras_path):
|
||||||
if app[0] != "." and os.path.isdir(os.path.join(self.__extras_path, app)):
|
if app[0] != "." and os.path.isdir(os.path.join(self.__extras_path, app)):
|
||||||
extras[app] = load_yaml_file(os.path.join(self.__extras_path, app, "manifest.yaml"))
|
extras[app] = load_yaml_file(os.path.join(self.__extras_path, app, "manifest.yaml"))
|
||||||
daemon = extras[app].get("daemon", "")
|
daemon = extras[app].get("daemon", "")
|
||||||
if isinstance(daemon, str) and daemon.strip():
|
if isinstance(daemon, str) and daemon.strip():
|
||||||
extras[app]["enabled"] = is_enabled(daemon.strip())
|
extras[app]["enabled"] = self.__is_daemon_enabled(daemon)
|
||||||
return extras
|
return extras
|
||||||
|
|
||||||
|
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"])
|
||||||
|
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
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user