summaryrefslogtreecommitdiff
path: root/kvmd
diff options
context:
space:
mode:
authorMaxim Devaev <[email protected]>2024-02-01 17:26:08 +0200
committerMaxim Devaev <[email protected]>2024-02-01 17:26:08 +0200
commit7141eebbf8e25438eb2953a88e0cc4e49b28f309 (patch)
treebbd0c3a477ae599cf45140d8fe4588fe25d30307 /kvmd
parent74d2d7466779b4c3367dd0677a5072f982061931 (diff)
check if ipv6 enabled before listen
Diffstat (limited to 'kvmd')
-rw-r--r--kvmd/apps/__init__.py4
-rw-r--r--kvmd/apps/ipmi/server.py3
-rw-r--r--kvmd/apps/vnc/server.py3
-rw-r--r--kvmd/network.py48
4 files changed, 55 insertions, 3 deletions
diff --git a/kvmd/apps/__init__.py b/kvmd/apps/__init__.py
index 74adeaec..8e504ed1 100644
--- a/kvmd/apps/__init__.py
+++ b/kvmd/apps/__init__.py
@@ -656,7 +656,7 @@ def _get_config_scheme() -> dict:
"ipmi": {
"server": {
- "host": Option("::", type=valid_ip_or_host),
+ "host": Option("", type=valid_ip_or_host, if_empty=""),
"port": Option(623, type=valid_port),
"timeout": Option(10.0, type=valid_float_f01),
},
@@ -684,7 +684,7 @@ def _get_config_scheme() -> dict:
"keymap": Option("/usr/share/kvmd/keymaps/en-us", type=valid_abs_file),
"server": {
- "host": Option("::", type=valid_ip_or_host),
+ "host": Option("", type=valid_ip_or_host, if_empty=""),
"port": Option(5900, type=valid_port),
"max_clients": Option(10, type=valid_int_f1),
diff --git a/kvmd/apps/ipmi/server.py b/kvmd/apps/ipmi/server.py
index 3679ce10..47d3950e 100644
--- a/kvmd/apps/ipmi/server.py
+++ b/kvmd/apps/ipmi/server.py
@@ -41,6 +41,7 @@ from ...logging import get_logger
from ...clients.kvmd import KvmdClient
from ... import aiotools
+from ... import network
from .auth import IpmiAuthManager
@@ -65,6 +66,8 @@ class IpmiServer(BaseIpmiServer): # pylint: disable=too-many-instance-attribute
sol_proxy_port: int,
) -> None:
+ host = network.get_listen_host(host)
+
super().__init__(authdata=auth_manager, address=host, port=port)
self.__auth_manager = auth_manager
diff --git a/kvmd/apps/vnc/server.py b/kvmd/apps/vnc/server.py
index c7d943d2..6ec3960e 100644
--- a/kvmd/apps/vnc/server.py
+++ b/kvmd/apps/vnc/server.py
@@ -47,6 +47,7 @@ from ...clients.streamer import BaseStreamerClient
from ... import tools
from ... import aiotools
+from ... import network
from .rfb import RfbClient
from .rfb.stream import rfb_format_remote
@@ -444,7 +445,7 @@ class VncServer: # pylint: disable=too-many-instance-attributes
vnc_auth_manager: VncAuthManager,
) -> None:
- self.__host = host
+ self.__host = network.get_listen_host(host)
self.__port = port
self.__max_clients = max_clients
diff --git a/kvmd/network.py b/kvmd/network.py
new file mode 100644
index 00000000..a65a12a7
--- /dev/null
+++ b/kvmd/network.py
@@ -0,0 +1,48 @@
+# ========================================================================== #
+# #
+# KVMD - The main PiKVM daemon. #
+# #
+# Copyright (C) 2018-2023 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 socket
+import errno
+
+
+# =====
+def is_ipv6_enabled() -> bool:
+ if not socket.has_ipv6:
+ # If the socket library has no support for IPv6,
+ # then the question is moot as we can't use IPv6 anyways.
+ return False
+ try:
+ with socket.socket(socket.AF_INET6, socket.SOCK_STREAM) as sock:
+ sock.bind(("::1", 0))
+ return True
+ except OSError as err:
+ if err.errno in [errno.EADDRNOTAVAIL, errno.EAFNOSUPPORT]:
+ return False
+ if err.errno == errno.EADDRINUSE:
+ return True
+ raise
+
+
+def get_listen_host(host: str) -> str:
+ if len(host) == 0:
+ return ("::" if is_ipv6_enabled() else "0.0.0.0")
+ return host