summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--kvmd/apps/kvmd/hid.py14
-rw-r--r--kvmd/apps/kvmd/streamer.py22
2 files changed, 26 insertions, 10 deletions
diff --git a/kvmd/apps/kvmd/hid.py b/kvmd/apps/kvmd/hid.py
index d7eb47cf..26cfa898 100644
--- a/kvmd/apps/kvmd/hid.py
+++ b/kvmd/apps/kvmd/hid.py
@@ -1,3 +1,5 @@
+import os
+import signal
import asyncio
import multiprocessing
import multiprocessing.queues
@@ -135,13 +137,15 @@ class Hid(multiprocessing.Process): # pylint: disable=too-many-instance-attribu
self.__pressed_keys.clear()
def __emergency_clear_events(self) -> None:
- try:
- with serial.Serial(self.__device_path, self.__speed) as tty:
- self.__send_clear_hid(tty)
- except Exception:
- get_logger().exception("Can't execute emergency clear HID events")
+ if os.path.exists(self.__device_path):
+ try:
+ with serial.Serial(self.__device_path, self.__speed) as tty:
+ self.__send_clear_hid(tty)
+ except Exception:
+ get_logger().exception("Can't execute emergency clear HID events")
def run(self) -> None: # pylint: disable=too-many-branches
+ signal.signal(signal.SIGINT, signal.SIG_IGN)
setproctitle.setproctitle("[hid] " + setproctitle.getproctitle())
try:
with serial.Serial(self.__device_path, self.__speed) as tty:
diff --git a/kvmd/apps/kvmd/streamer.py b/kvmd/apps/kvmd/streamer.py
index 2527d4e9..c3d9bbe8 100644
--- a/kvmd/apps/kvmd/streamer.py
+++ b/kvmd/apps/kvmd/streamer.py
@@ -1,4 +1,5 @@
import os
+import signal
import asyncio
import asyncio.subprocess
@@ -61,13 +62,11 @@ class Streamer: # pylint: disable=too-many-instance-attributes
self.__cmd = cmd
self.__loop = loop
- if self.__unix_path:
- self.__http_session = aiohttp.ClientSession(connector=aiohttp.UnixConnector(path=self.__unix_path))
- else:
- self.__http_session = aiohttp.ClientSession()
self.__proc_task: Optional[asyncio.Task] = None
+ self.__http_session: Optional[aiohttp.ClientSession] = None
+
async def start(self, params: Dict, no_init_restart: bool=False) -> None:
logger = get_logger()
logger.info("Starting streamer ...")
@@ -94,10 +93,11 @@ class Streamer: # pylint: disable=too-many-instance-attributes
return dict(self.__params)
async def get_state(self) -> Dict:
+ self.__ensure_session()
url = "http://%s:%d/state" % (self.__host, self.__port)
state = None
try:
- async with self.__http_session.get(url, timeout=self.__timeout) as response:
+ async with self.__http_session.get(url, timeout=self.__timeout) as response: # type: ignore
response.raise_for_status()
state = (await response.json())["result"]
except aiohttp.ClientConnectorError:
@@ -122,6 +122,7 @@ class Streamer: # pylint: disable=too-many-instance-attributes
*[self.__cmd[0], "--version"],
stdout=asyncio.subprocess.PIPE,
stderr=asyncio.subprocess.DEVNULL,
+ preexec_fn=(lambda: signal.signal(signal.SIGINT, signal.SIG_IGN)),
)
(stdout, _) = await proc.communicate()
return stdout.decode(errors="ignore").strip()
@@ -129,6 +130,16 @@ class Streamer: # pylint: disable=too-many-instance-attributes
async def cleanup(self) -> None:
if self.is_running():
await self.stop()
+ if self.__http_session:
+ await self.__http_session.close()
+ self.__http_session = None
+
+ def __ensure_session(self) -> None:
+ if not self.__http_session:
+ if self.__unix_path:
+ self.__http_session = aiohttp.ClientSession(connector=aiohttp.UnixConnector(path=self.__unix_path))
+ else:
+ self.__http_session = aiohttp.ClientSession()
async def __inner_start(self) -> None:
assert not self.__proc_task
@@ -172,6 +183,7 @@ class Streamer: # pylint: disable=too-many-instance-attributes
*cmd,
stdout=asyncio.subprocess.PIPE,
stderr=asyncio.subprocess.STDOUT,
+ preexec_fn=(lambda: signal.signal(signal.SIGINT, signal.SIG_IGN)),
)
logger.info("Started streamer pid=%d: %s", proc.pid, cmd)