diff options
author | Devaev Maxim <[email protected]> | 2020-09-08 10:05:29 +0300 |
---|---|---|
committer | Devaev Maxim <[email protected]> | 2020-09-08 10:05:29 +0300 |
commit | 7990bf7e54fe7655816700701524a62787956b27 (patch) | |
tree | 5acc25a54667d082333a4ea546493d24a9dc0023 /kvmd | |
parent | ea09cc93babd56c908e964f8a03820107c75d1a0 (diff) |
refactoring
Diffstat (limited to 'kvmd')
-rw-r--r-- | kvmd/apps/__init__.py | 19 | ||||
-rw-r--r-- | kvmd/tools.py | 43 |
2 files changed, 49 insertions, 13 deletions
diff --git a/kvmd/apps/__init__.py b/kvmd/apps/__init__.py index e431dc6e..b20e0f12 100644 --- a/kvmd/apps/__init__.py +++ b/kvmd/apps/__init__.py @@ -35,6 +35,8 @@ import pygments import pygments.lexers.data import pygments.formatters +from .. import tools + from ..plugins import UnknownPluginError from ..plugins.auth import get_auth_service_class from ..plugins.hid import get_hid_class @@ -134,8 +136,8 @@ def _init_config(config_path: str, override_options: List[str], **load_flags: bo scheme = _get_config_scheme() try: - _merge_dicts(raw_config, (raw_config.pop("override", {}) or {})) - _merge_dicts(raw_config, build_raw_from_options(override_options)) + tools.merge(raw_config, (raw_config.pop("override", {}) or {})) + tools.merge(raw_config, build_raw_from_options(override_options)) config = make_config(raw_config, scheme) if _patch_dynamic(raw_config, config, scheme, **load_flags): @@ -177,7 +179,7 @@ def _patch_dynamic( # pylint: disable=too-many-locals if load_gpio: for (driver, params) in { # type: ignore "gpio": {}, - **(raw_config.get("kvmd", {}).get("gpio", {}).get("drivers", {})), + **tools.rget(raw_config, "kvmd", "gpio", "drivers"), }.items(): driver_type = valid_stripped_string_not_empty(params.get("type", "gpio")) scheme["kvmd"]["gpio"]["drivers"][driver] = { @@ -185,7 +187,7 @@ def _patch_dynamic( # pylint: disable=too-many-locals **get_ugpio_driver_class(driver_type).get_plugin_options() } - for (channel, params) in raw_config.get("kvmd", {}).get("gpio", {}).get("scheme", {}).items(): + for (channel, params) in tools.rget(raw_config, "kvmd", "gpio", "scheme").items(): try: mode = valid_ugpio_mode(params.get("mode", "")) except Exception: @@ -225,15 +227,6 @@ def _dump_config(config: Section) -> None: print(dump) -def _merge_dicts(dest: Dict, src: Dict) -> None: - for key in src: - if key in dest: - if isinstance(dest[key], dict) and isinstance(src[key], dict): - _merge_dicts(dest[key], src[key]) - continue - dest[key] = src[key] - - def _get_config_scheme() -> Dict: return { "logging": Option({}), diff --git a/kvmd/tools.py b/kvmd/tools.py new file mode 100644 index 00000000..1259893c --- /dev/null +++ b/kvmd/tools.py @@ -0,0 +1,43 @@ +# ========================================================================== # +# # +# KVMD - The main Pi-KVM daemon. # +# # +# Copyright (C) 2018 Maxim Devaev <[email protected]> # +# # +# 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 functools + +from typing import Dict +from typing import Hashable + + +# ===== +def merge(dest: Dict, src: Dict) -> None: + for key in src: + if key in dest: + if isinstance(dest[key], dict) and isinstance(src[key], dict): + merge(dest[key], src[key]) + continue + dest[key] = src[key] + + +def rget(dct: Dict, *keys: Hashable) -> Dict: + result = functools.reduce((lambda nxt, key: nxt.get(key, {})), keys, dct) + if not isinstance(result, dict): + raise TypeError(f"Not a dict as result: {result!r} from {dct!r} at {list(keys)}") + return result |