mirror of
https://github.com/mofeng-git/One-KVM.git
synced 2025-12-12 01:00:29 +08:00
refactoring
This commit is contained in:
parent
8bc00a4dff
commit
03d339e49f
@ -21,23 +21,19 @@
|
|||||||
|
|
||||||
|
|
||||||
import os
|
import os
|
||||||
import contextlib
|
|
||||||
|
|
||||||
from typing import Tuple
|
|
||||||
from typing import Dict
|
from typing import Dict
|
||||||
from typing import Optional
|
from typing import Optional
|
||||||
|
|
||||||
import dbus # pylint: disable=import-error
|
|
||||||
import dbus.exceptions
|
|
||||||
|
|
||||||
from ....logging import get_logger
|
from ....logging import get_logger
|
||||||
|
|
||||||
from ....yamlconf import Section
|
from ....yamlconf import Section
|
||||||
from ....yamlconf.loader import load_yaml_file
|
from ....yamlconf.loader import load_yaml_file
|
||||||
|
|
||||||
from .... import tools
|
|
||||||
from .... import aiotools
|
from .... import aiotools
|
||||||
|
|
||||||
|
from ..sysunit import get_service_status
|
||||||
|
|
||||||
from .base import BaseInfoSubmanager
|
from .base import BaseInfoSubmanager
|
||||||
|
|
||||||
|
|
||||||
@ -68,7 +64,8 @@ class ExtrasInfoSubmanager(BaseInfoSubmanager):
|
|||||||
def __rewrite_app_daemon(self, extras: Dict) -> None:
|
def __rewrite_app_daemon(self, extras: Dict) -> None:
|
||||||
daemon = extras.get("daemon", "")
|
daemon = extras.get("daemon", "")
|
||||||
if isinstance(daemon, str) and daemon.strip():
|
if isinstance(daemon, str) and daemon.strip():
|
||||||
(extras["enabled"], extras["started"]) = self.__get_daemon_status(daemon)
|
status = get_service_status(daemon)
|
||||||
|
(extras["enabled"], extras["started"]) = (status if status is not None else (True, True))
|
||||||
|
|
||||||
def __rewrite_app_port(self, extras: Dict) -> None:
|
def __rewrite_app_port(self, extras: Dict) -> None:
|
||||||
port_path = extras.get("port", "")
|
port_path = extras.get("port", "")
|
||||||
@ -79,24 +76,3 @@ class ExtrasInfoSubmanager(BaseInfoSubmanager):
|
|||||||
config = getattr(config, item, None)
|
config = getattr(config, item, None)
|
||||||
if isinstance(config, int):
|
if isinstance(config, int):
|
||||||
extras["port"] = config
|
extras["port"] = config
|
||||||
|
|
||||||
def __get_daemon_status(self, name: str) -> Tuple[bool, bool]:
|
|
||||||
if not name.endswith(".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
|
|
||||||
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")
|
|
||||||
started = (unit_properties.Get("org.freedesktop.systemd1.Unit", "ActiveState") == "active")
|
|
||||||
except dbus.exceptions.DBusException as err:
|
|
||||||
if "NoSuchUnit" not in str(err):
|
|
||||||
raise
|
|
||||||
started = False
|
|
||||||
enabled = (manager.GetUnitFileState(name) in ["enabled", "enabled-runtime", "static", "indirect", "generated"])
|
|
||||||
return (enabled, started)
|
|
||||||
except Exception as err:
|
|
||||||
get_logger(0).error("Can't get info about the service %r: %s", name, tools.efmt(err))
|
|
||||||
return (True, True)
|
|
||||||
|
|||||||
56
kvmd/apps/kvmd/sysunit.py
Normal file
56
kvmd/apps/kvmd/sysunit.py
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
# ========================================================================== #
|
||||||
|
# #
|
||||||
|
# KVMD - The main Pi-KVM daemon. #
|
||||||
|
# #
|
||||||
|
# Copyright (C) 2018-2021 Maxim Devaev <mdevaev@gmail.com> #
|
||||||
|
# #
|
||||||
|
# This program is free software: you can redistribute it and/or modify #
|
||||||
|
# it under the terms of the GNU General Public License as published by #
|
||||||
|
# the Free Software Foundation, either version 3 of the License, or #
|
||||||
|
# (at your option) any later version. #
|
||||||
|
# #
|
||||||
|
# This program is distributed in the hope that it will be useful, #
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
|
||||||
|
# GNU General Public License for more details. #
|
||||||
|
# #
|
||||||
|
# You should have received a copy of the GNU General Public License #
|
||||||
|
# along with this program. If not, see <https://www.gnu.org/licenses/>. #
|
||||||
|
# #
|
||||||
|
# ========================================================================== #
|
||||||
|
|
||||||
|
|
||||||
|
import contextlib
|
||||||
|
|
||||||
|
from typing import Tuple
|
||||||
|
from typing import Optional
|
||||||
|
|
||||||
|
import dbus # pylint: disable=import-error
|
||||||
|
import dbus.exceptions
|
||||||
|
|
||||||
|
from ...logging import get_logger
|
||||||
|
|
||||||
|
from ... import tools
|
||||||
|
|
||||||
|
|
||||||
|
# =====
|
||||||
|
def get_service_status(name: str) -> Optional[Tuple[bool, bool]]:
|
||||||
|
if not name.endswith(".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
|
||||||
|
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")
|
||||||
|
started = (unit_properties.Get("org.freedesktop.systemd1.Unit", "ActiveState") == "active")
|
||||||
|
except dbus.exceptions.DBusException as err:
|
||||||
|
if "NoSuchUnit" not in str(err):
|
||||||
|
raise
|
||||||
|
started = False
|
||||||
|
enabled = (manager.GetUnitFileState(name) in ["enabled", "enabled-runtime", "static", "indirect", "generated"])
|
||||||
|
return (enabled, started)
|
||||||
|
except Exception as err:
|
||||||
|
get_logger(0).error("Can't get info about the service %r: %s", name, tools.efmt(err))
|
||||||
|
return None
|
||||||
Loading…
x
Reference in New Issue
Block a user