diff options
Diffstat (limited to 'kvmd')
-rw-r--r-- | kvmd/apps/__init__.py | 22 | ||||
-rw-r--r-- | kvmd/validators/net.py | 26 |
2 files changed, 48 insertions, 0 deletions
diff --git a/kvmd/apps/__init__.py b/kvmd/apps/__init__.py index 10a331da..a882e0d7 100644 --- a/kvmd/apps/__init__.py +++ b/kvmd/apps/__init__.py @@ -77,7 +77,9 @@ from ..validators.os import valid_command from ..validators.net import valid_ip_or_host from ..validators.net import valid_ip +from ..validators.net import valid_net from ..validators.net import valid_port +from ..validators.net import valid_ports_list from ..validators.net import valid_mac from ..validators.net import valid_ssl_ciphers @@ -426,6 +428,26 @@ def _get_config_scheme() -> Dict: }, }, + "otgnet": { + "iface": { + "net": Option("169.254.0.100/31", type=functools.partial(valid_net, v6=False)), + }, + + "firewall": { + "allow_tcp": Option([], type=valid_ports_list), + "allow_udp": Option([], type=valid_ports_list), + }, + + "dhcp": { + "enabled": Option(True, type=valid_bool), + }, + + "commands": { + "ip_cmd": Option(["/usr/bin/ip"], type=valid_command), + "iptables_cmd": Option(["/usr/bin/iptables"], type=valid_command), + }, + }, + "ipmi": { "server": { "host": Option("::", type=valid_ip_or_host), diff --git a/kvmd/validators/net.py b/kvmd/validators/net.py index 4197ac8e..f4019272 100644 --- a/kvmd/validators/net.py +++ b/kvmd/validators/net.py @@ -28,11 +28,13 @@ from typing import Callable from typing import Any from . import ValidatorError +from . import raise_error from . import check_re_match from . import check_any from .basic import valid_number from .basic import valid_stripped_string_not_empty +from .basic import valid_string_list # ===== @@ -66,6 +68,26 @@ def valid_ip(arg: Any, v4: bool=True, v6: bool=True) -> str: ) +def valid_net(arg: Any, v4: bool=True, v6: bool=True) -> str: + assert v4 or v6 + validators: List[Callable] = [] + versions: List[str] = [] + if v4: + validators.append(lambda arg: str(ipaddress.IPv4Network(arg))) + versions.append("4") + if v6: + validators.append(lambda arg: str(ipaddress.IPv6Network(arg))) + versions.append("6") + name = f"IPv{'/'.join(versions)} network" + if "/" not in str(arg): + raise_error(arg, name) + return check_any( + arg=valid_stripped_string_not_empty(arg, name), + name=name, + validators=validators, + ) + + def valid_rfc_host(arg: Any) -> str: # http://stackoverflow.com/questions/106179/regular-expression-to-match-hostname-or-ip-address pattern = r"^(([a-zA-Z0-9]|[a-zA-Z0-9][a-zA-Z0-9\-]*[a-zA-Z0-9])\.)*" \ @@ -77,6 +99,10 @@ def valid_port(arg: Any) -> int: return int(valid_number(arg, min=0, max=65535, name="network port")) +def valid_ports_list(arg: Any) -> List[int]: + return list(map(int, valid_string_list(arg, subval=valid_port, name="ports list"))) + + def valid_mac(arg: Any) -> str: pattern = ":".join([r"[0-9a-fA-F]{2}"] * 6) return check_re_match(arg, "MAC address", pattern).lower() |