summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--configs/kvmd/main/v0-hdmi.yaml6
-rw-r--r--configs/kvmd/main/v0-vga.yaml6
-rw-r--r--configs/kvmd/main/v1-hdmi.yaml6
-rw-r--r--configs/kvmd/main/v1-vga.yaml6
-rw-r--r--kvmd/apps/__init__.py21
-rw-r--r--kvmd/apps/cleanup/__init__.py2
-rw-r--r--kvmd/apps/htpasswd/__init__.py4
-rw-r--r--kvmd/apps/kvmd/__init__.py12
-rw-r--r--kvmd/apps/kvmd/auth.py6
-rw-r--r--kvmd/yamlconf/__init__.py17
-rw-r--r--testenv/main.yaml8
-rw-r--r--testenv/tests/apps/htpasswd/test_main.py2
-rw-r--r--testenv/tests/apps/kvmd/test_auth.py4
13 files changed, 46 insertions, 54 deletions
diff --git a/configs/kvmd/main/v0-hdmi.yaml b/configs/kvmd/main/v0-hdmi.yaml
index 7137877a..2271c757 100644
--- a/configs/kvmd/main/v0-hdmi.yaml
+++ b/configs/kvmd/main/v0-hdmi.yaml
@@ -15,10 +15,8 @@ kvmd:
auth: !include auth.yaml
hid:
- type: tty
- params:
- reset_pin: 4
- device: /dev/kvmd-hid
+ reset_pin: 4
+ device: /dev/kvmd-hid
atx:
power_led_pin: 24
diff --git a/configs/kvmd/main/v0-vga.yaml b/configs/kvmd/main/v0-vga.yaml
index ac687336..9f2d895c 100644
--- a/configs/kvmd/main/v0-vga.yaml
+++ b/configs/kvmd/main/v0-vga.yaml
@@ -15,10 +15,8 @@ kvmd:
auth: !include auth.yaml
hid:
- type: tty
- params:
- reset_pin: 4
- device: /dev/kvmd-hid
+ reset_pin: 4
+ device: /dev/kvmd-hid
atx:
power_led_pin: 24
diff --git a/configs/kvmd/main/v1-hdmi.yaml b/configs/kvmd/main/v1-hdmi.yaml
index 108e2da4..6bfb1672 100644
--- a/configs/kvmd/main/v1-hdmi.yaml
+++ b/configs/kvmd/main/v1-hdmi.yaml
@@ -15,10 +15,8 @@ kvmd:
auth: !include auth.yaml
hid:
- type: tty
- params:
- reset_pin: 4
- device: /dev/kvmd-hid
+ reset_pin: 4
+ device: /dev/kvmd-hid
atx:
power_led_pin: 24
diff --git a/configs/kvmd/main/v1-vga.yaml b/configs/kvmd/main/v1-vga.yaml
index c99d89c6..8593a377 100644
--- a/configs/kvmd/main/v1-vga.yaml
+++ b/configs/kvmd/main/v1-vga.yaml
@@ -15,10 +15,8 @@ kvmd:
auth: !include auth.yaml
hid:
- type: tty
- params:
- reset_pin: 4
- device: /dev/kvmd-hid
+ reset_pin: 4
+ device: /dev/kvmd-hid
atx:
power_led_pin: 24
diff --git a/kvmd/apps/__init__.py b/kvmd/apps/__init__.py
index 974a7d70..7b8f2ef2 100644
--- a/kvmd/apps/__init__.py
+++ b/kvmd/apps/__init__.py
@@ -112,11 +112,11 @@ def _init_config(config_path: str, sections: List[str], override_options: List[s
config = make_config(raw_config, scheme)
if "kvmd" in sections:
- scheme["kvmd"]["auth"]["internal"] = get_auth_service_class(config.kvmd.auth.internal_type).get_plugin_options()
- if config.kvmd.auth.external_type:
- scheme["kvmd"]["auth"]["external"] = get_auth_service_class(config.kvmd.auth.external_type).get_plugin_options()
+ scheme["kvmd"]["auth"]["internal"].update(get_auth_service_class(config.kvmd.auth.internal.type).get_plugin_options())
+ if config.kvmd.auth.external.type:
+ scheme["kvmd"]["auth"]["external"].update(get_auth_service_class(config.kvmd.auth.external.type).get_plugin_options())
- scheme["kvmd"]["hid"]["params"] = get_hid_class(config.kvmd.hid.type).get_plugin_options()
+ scheme["kvmd"]["hid"].update(get_hid_class(config.kvmd.hid.type).get_plugin_options())
config = make_config(raw_config, scheme)
@@ -164,11 +164,13 @@ def _get_config_scheme(sections: List[str]) -> Dict:
},
"auth": {
- "internal_type": Option("htpasswd"),
- # "internal": {},
- "external_type": Option(""),
- # "external": {},
- "internal_users": Option([], type=valid_users_list),
+ "internal": {
+ "type": Option("htpasswd"),
+ "force_users": Option([], type=valid_users_list),
+ },
+ "external": {
+ "type": Option(""),
+ },
},
"info": {
@@ -178,7 +180,6 @@ def _get_config_scheme(sections: List[str]) -> Dict:
"hid": {
"type": Option("tty"),
- # "params": {},
},
"atx": {
diff --git a/kvmd/apps/cleanup/__init__.py b/kvmd/apps/cleanup/__init__.py
index 8aaf3452..f25e679a 100644
--- a/kvmd/apps/cleanup/__init__.py
+++ b/kvmd/apps/cleanup/__init__.py
@@ -49,7 +49,7 @@ def main(argv: Optional[List[str]]=None) -> None:
with gpio.bcm():
for (name, pin, enabled) in [
*([
- ("hid_reset_pin", config.hid.params.reset_pin, True),
+ ("hid_reset_pin", config.hid.reset_pin, True),
] if config.hid.type == "tty" else []),
("atx_power_switch_pin", config.atx.power_switch_pin, config.atx.enabled),
("atx_reset_switch_pin", config.atx.reset_switch_pin, config.atx.enabled),
diff --git a/kvmd/apps/htpasswd/__init__.py b/kvmd/apps/htpasswd/__init__.py
index 1a666d0f..385de75c 100644
--- a/kvmd/apps/htpasswd/__init__.py
+++ b/kvmd/apps/htpasswd/__init__.py
@@ -44,9 +44,9 @@ from .. import init
# =====
def _get_htpasswd_path(config: Section) -> str:
- if config.kvmd.auth.internal_type != "htpasswd":
+ if config.kvmd.auth.internal.type != "htpasswd":
raise SystemExit(f"Error: KVMD internal auth not using 'htpasswd'"
- f" (now configured {config.kvmd.auth.internal_type!r})")
+ f" (now configured {config.kvmd.auth.internal.type!r})")
return config.kvmd.auth.internal.file
diff --git a/kvmd/apps/kvmd/__init__.py b/kvmd/apps/kvmd/__init__.py
index 203b741e..f9e46b84 100644
--- a/kvmd/apps/kvmd/__init__.py
+++ b/kvmd/apps/kvmd/__init__.py
@@ -53,16 +53,16 @@ def main(argv: Optional[List[str]]=None) -> None:
# pylint: disable=protected-access
Server(
auth_manager=AuthManager(
- internal_type=config.auth.internal_type,
- internal_kwargs=config.auth.internal._unpack(),
- external_type=config.auth.external_type,
- external_kwargs=(config.auth.external._unpack() if config.auth.external_type else {}),
- internal_users=config.auth.internal_users,
+ internal_type=config.auth.internal.type,
+ internal_kwargs=config.auth.internal._unpack(ignore=["type", "force_users"]),
+ external_type=config.auth.external.type,
+ external_kwargs=(config.auth.external._unpack(ignore=["type"]) if config.auth.external.type else {}),
+ force_internal_users=config.auth.internal.force_users,
),
info_manager=InfoManager(**config.info._unpack()),
log_reader=LogReader(),
- hid=get_hid_class(config.hid.type)(**config.hid.params._unpack()),
+ hid=get_hid_class(config.hid.type)(**config.hid._unpack(ignore=["type"])),
atx=Atx(**config.atx._unpack()),
msd=MassStorageDevice(**config.msd._unpack()),
streamer=Streamer(**config.streamer._unpack()),
diff --git a/kvmd/apps/kvmd/auth.py b/kvmd/apps/kvmd/auth.py
index e4268e74..6a26bbc6 100644
--- a/kvmd/apps/kvmd/auth.py
+++ b/kvmd/apps/kvmd/auth.py
@@ -45,7 +45,7 @@ class AuthManager:
external_type: str,
external_kwargs: Dict,
- internal_users: List[str],
+ force_internal_users: List[str],
) -> None:
self.__internal_service = get_auth_service_class(internal_type)(**internal_kwargs)
@@ -56,12 +56,12 @@ class AuthManager:
self.__external_service = get_auth_service_class(external_type)(**external_kwargs)
get_logger().info("Using external auth service %r", self.__external_service.get_plugin_name())
- self.__internal_users = internal_users
+ self.__force_internal_users = force_internal_users
self.__tokens: Dict[str, str] = {} # {token: user}
async def authorize(self, user: str, passwd: str) -> bool:
- if user not in self.__internal_users and self.__external_service:
+ if user not in self.__force_internal_users and self.__external_service:
service = self.__external_service
else:
service = self.__internal_service
diff --git a/kvmd/yamlconf/__init__.py b/kvmd/yamlconf/__init__.py
index 123dc915..b0bc356f 100644
--- a/kvmd/yamlconf/__init__.py
+++ b/kvmd/yamlconf/__init__.py
@@ -71,15 +71,16 @@ class Section(dict):
dict.__init__(self)
self.__meta: Dict[str, Dict[str, Any]] = {}
- def _unpack(self, _section: Optional["Section"]=None) -> Dict[str, Any]:
- if _section is None:
- _section = self
+ def _unpack(self, ignore: Optional[List[str]]=None) -> Dict[str, Any]:
+ if ignore is None:
+ ignore = []
unpacked: Dict[str, Any] = {}
- for (key, value) in _section.items():
- if isinstance(value, Section):
- unpacked[key] = value._unpack() # pylint: disable=protected-access
- else: # Option
- unpacked[_section._get_unpack_as(key)] = value # pylint: disable=protected-access
+ for (key, value) in self.items():
+ if key not in ignore:
+ if isinstance(value, Section):
+ unpacked[key] = value._unpack() # pylint: disable=protected-access
+ else: # Option
+ unpacked[self._get_unpack_as(key)] = value # pylint: disable=protected-access
return unpacked
def _set_meta(self, key: str, default: Any, unpack_as: str, help: str) -> None: # pylint: disable=redefined-builtin
diff --git a/testenv/main.yaml b/testenv/main.yaml
index 6c6c9bbd..4ff88d94 100644
--- a/testenv/main.yaml
+++ b/testenv/main.yaml
@@ -7,11 +7,9 @@ kvmd:
auth: !include auth.yaml
hid:
- type: tty
- params:
- reset_pin: 4
- device: /dev/ttyS10
- noop: true
+ reset_pin: 4
+ device: /dev/ttyS10
+ noop: true
atx:
power_led_pin: 24
diff --git a/testenv/tests/apps/htpasswd/test_main.py b/testenv/tests/apps/htpasswd/test_main.py
index 52a38640..dd1d9c8d 100644
--- a/testenv/tests/apps/htpasswd/test_main.py
+++ b/testenv/tests/apps/htpasswd/test_main.py
@@ -57,7 +57,7 @@ def _htpasswd_fixture(request) -> Generator[passlib.apache.HtpasswdFile, None, N
def _run_htpasswd(cmd: List[str], htpasswd_path: str, internal_type: str="htpasswd") -> None:
cmd = ["kvmd-htpasswd", *cmd, "--set-options"]
if internal_type != "htpasswd": # By default
- cmd.append("kvmd/auth/internal_type=" + internal_type)
+ cmd.append("kvmd/auth/internal/type=" + internal_type)
if htpasswd_path:
cmd.append("kvmd/auth/internal/file=" + htpasswd_path)
main(cmd)
diff --git a/testenv/tests/apps/kvmd/test_auth.py b/testenv/tests/apps/kvmd/test_auth.py
index be6b6455..fca156ad 100644
--- a/testenv/tests/apps/kvmd/test_auth.py
+++ b/testenv/tests/apps/kvmd/test_auth.py
@@ -50,7 +50,7 @@ def _make_service_kwargs(path: str) -> Dict:
async def _get_configured_manager(
internal_path: str,
external_path: str="",
- internal_users: Optional[List[str]]=None,
+ force_internal_users: Optional[List[str]]=None,
) -> AsyncGenerator[AuthManager, None]:
manager = AuthManager(
@@ -58,7 +58,7 @@ async def _get_configured_manager(
internal_kwargs=_make_service_kwargs(internal_path),
external_type=("htpasswd" if external_path else ""),
external_kwargs=(_make_service_kwargs(external_path) if external_path else {}),
- internal_users=(internal_users or []),
+ force_internal_users=(force_internal_users or []),
)
try: