summaryrefslogtreecommitdiff
path: root/kvmd/apps/vnc/rfb/__init__.py
diff options
context:
space:
mode:
authorMaxim Devaev <[email protected]>2024-11-04 18:59:50 +0200
committerMaxim Devaev <[email protected]>2024-11-04 18:59:50 +0200
commit0010dd1d114d5c03b7397394b8e12dee5908669d (patch)
tree06c0f368984ea69d041ad518dc15638db8036f96 /kvmd/apps/vnc/rfb/__init__.py
parent7ef2e16b51eab24897cc6447c826a5a1c2b8efed (diff)
pikvm/pikvm#1420: VNC: Ignore CUT event 3 seconds after connection
Diffstat (limited to 'kvmd/apps/vnc/rfb/__init__.py')
-rw-r--r--kvmd/apps/vnc/rfb/__init__.py13
1 files changed, 12 insertions, 1 deletions
diff --git a/kvmd/apps/vnc/rfb/__init__.py b/kvmd/apps/vnc/rfb/__init__.py
index c145b4b3..d2c6b50b 100644
--- a/kvmd/apps/vnc/rfb/__init__.py
+++ b/kvmd/apps/vnc/rfb/__init__.py
@@ -22,6 +22,7 @@
import asyncio
import ssl
+import time
from typing import Callable
from typing import Coroutine
@@ -64,6 +65,7 @@ class RfbClient(RfbClientStream): # pylint: disable=too-many-instance-attribute
width: int,
height: int,
name: str,
+ allow_cut_after: float,
vnc_passwds: list[str],
vencrypt: bool,
none_auth_only: bool,
@@ -79,6 +81,7 @@ class RfbClient(RfbClientStream): # pylint: disable=too-many-instance-attribute
self._width = width
self._height = height
self.__name = name
+ self.__allow_cut_after = allow_cut_after
self.__vnc_passwds = vnc_passwds
self.__vencrypt = vencrypt
self.__none_auth_only = none_auth_only
@@ -90,6 +93,8 @@ class RfbClient(RfbClientStream): # pylint: disable=too-many-instance-attribute
self.__fb_cont_updates = False
self.__fb_reset_h264 = False
+ self.__allow_cut_since_ts = 0.0
+
self.__lock = asyncio.Lock()
# =====
@@ -414,6 +419,7 @@ class RfbClient(RfbClientStream): # pylint: disable=too-many-instance-attribute
# =====
async def __main_loop(self) -> None:
+ self.__allow_cut_since_ts = time.monotonic() + self.__allow_cut_after
handlers = {
0: self.__handle_set_pixel_format,
2: self.__handle_set_encodings,
@@ -499,7 +505,12 @@ class RfbClient(RfbClientStream): # pylint: disable=too-many-instance-attribute
async def __handle_client_cut_text(self) -> None:
length = (await self._read_struct("cut text length", "xxx L"))[0]
text = await self._read_text("cut text data", length)
- await self._on_cut_event(text)
+ if self.__allow_cut_since_ts > 0 and time.monotonic() >= self.__allow_cut_since_ts:
+ # We should ignore cut event a few seconds after handshake
+ # because bVNC, AVNC and maybe some other clients perform
+ # it right after the connection automatically.
+ # - https://github.com/pikvm/pikvm/issues/1420
+ await self._on_cut_event(text)
async def __handle_enable_cont_updates(self) -> None:
enabled = bool((await self._read_struct("enabled ContUpdates", "B HH HH"))[0])