diff options
Diffstat (limited to 'kvmd')
-rw-r--r-- | kvmd/apps/__init__.py | 12 | ||||
-rw-r--r-- | kvmd/apps/kvmd/__init__.py | 4 | ||||
-rw-r--r-- | kvmd/apps/kvmd/api/hid.py | 24 | ||||
-rw-r--r-- | kvmd/apps/kvmd/server.py | 7 | ||||
-rw-r--r-- | kvmd/validators/hid.py | 4 |
5 files changed, 40 insertions, 11 deletions
diff --git a/kvmd/apps/__init__.py b/kvmd/apps/__init__.py index ed6a3101..aa724979 100644 --- a/kvmd/apps/__init__.py +++ b/kvmd/apps/__init__.py @@ -363,7 +363,19 @@ def _get_config_scheme() -> Dict: "hid": { "type": Option("", type=valid_stripped_string_not_empty), + "keymap": Option("/usr/share/kvmd/keymaps/en-us", type=valid_abs_file), + + "mouse_x_range": { + "min": Option(-32768, type=valid_hid_mouse_move), + "max": Option(32767, type=valid_hid_mouse_move), + }, + + "mouse_y_range": { + "min": Option(-32768, type=valid_hid_mouse_move), + "max": Option(32767, type=valid_hid_mouse_move), + }, + # Dynamic content }, diff --git a/kvmd/apps/kvmd/__init__.py b/kvmd/apps/kvmd/__init__.py index 2a6dbeef..7b2b5e6e 100644 --- a/kvmd/apps/kvmd/__init__.py +++ b/kvmd/apps/kvmd/__init__.py @@ -59,7 +59,7 @@ def main(argv: Optional[List[str]]=None) -> None: if config.kvmd.msd.type == "otg": msd_kwargs["gadget"] = config.otg.gadget # XXX: Small crutch to pass gadget name to the plugin - hid_kwargs = config.kvmd.hid._unpack(ignore=["type", "keymap"]) + hid_kwargs = config.kvmd.hid._unpack(ignore=["type", "keymap", "mouse_x_range", "mouse_y_range"]) if config.kvmd.hid.type == "otg": hid_kwargs["udc"] = config.otg.udc # XXX: Small crutch to pass UDC to the plugin @@ -104,6 +104,8 @@ def main(argv: Optional[List[str]]=None) -> None: sync_chunk_size=config.server.sync_chunk_size, keymap_path=config.hid.keymap, + mouse_x_range=(config.hid.mouse_x_range.min, config.hid.mouse_x_range.max), + mouse_y_range=(config.hid.mouse_y_range.min, config.hid.mouse_y_range.max), stream_forever=config.streamer.forever, ).run(**config.server._unpack(ignore=["heartbeat", "sync_chunk_size"])) diff --git a/kvmd/apps/kvmd/api/hid.py b/kvmd/apps/kvmd/api/hid.py index b865b6a8..d9a39a00 100644 --- a/kvmd/apps/kvmd/api/hid.py +++ b/kvmd/apps/kvmd/api/hid.py @@ -24,6 +24,7 @@ import os import stat import functools +from typing import Tuple from typing import Dict from typing import Set from typing import Callable @@ -55,14 +56,25 @@ from ..http import make_json_response # ===== class HidApi: - def __init__(self, hid: BaseHid, keymap_path: str) -> None: + def __init__( + self, + hid: BaseHid, + + keymap_path: str, + + mouse_x_range: Tuple[int, int], + mouse_y_range: Tuple[int, int], + ) -> None: + self.__hid = hid self.__keymaps_dir_path = os.path.dirname(keymap_path) self.__default_keymap_name = os.path.basename(keymap_path) - self.__ensure_symmap(self.__default_keymap_name) + self.__mouse_x_range = mouse_x_range + self.__mouse_y_range = mouse_y_range + # ===== @exposed_http("GET", "/hid") @@ -157,8 +169,8 @@ class HidApi: @exposed_ws("mouse_move") async def __ws_mouse_move_handler(self, _: WebSocketResponse, event: Dict) -> None: try: - to_x = valid_hid_mouse_move(event["to"]["x"]) - to_y = valid_hid_mouse_move(event["to"]["y"]) + to_x = valid_hid_mouse_move(event["to"]["x"], *self.__mouse_x_range) + to_y = valid_hid_mouse_move(event["to"]["y"], *self.__mouse_y_range) except Exception: return self.__hid.send_mouse_move_event(to_x, to_y) @@ -220,8 +232,8 @@ class HidApi: @exposed_http("POST", "/hid/events/send_mouse_move") async def __events_send_mouse_move_handler(self, request: Request) -> Response: - to_x = valid_hid_mouse_move(request.query.get("to_x")) - to_y = valid_hid_mouse_move(request.query.get("to_y")) + to_x = valid_hid_mouse_move(request.query.get("to_x"), *self.__mouse_x_range) + to_y = valid_hid_mouse_move(request.query.get("to_y"), *self.__mouse_y_range) self.__hid.send_mouse_move_event(to_x, to_y) return make_json_response() diff --git a/kvmd/apps/kvmd/server.py b/kvmd/apps/kvmd/server.py index 71d9a5fa..84f21c08 100644 --- a/kvmd/apps/kvmd/server.py +++ b/kvmd/apps/kvmd/server.py @@ -27,6 +27,7 @@ import operator import dataclasses import json +from typing import Tuple from typing import List from typing import Dict from typing import Set @@ -142,7 +143,7 @@ class _WsClient: class KvmdServer(HttpServer): # pylint: disable=too-many-arguments,too-many-instance-attributes - def __init__( # pylint: disable=too-many-arguments + def __init__( # pylint: disable=too-many-arguments,too-many-locals self, auth_manager: AuthManager, info_manager: InfoManager, @@ -160,6 +161,8 @@ class KvmdServer(HttpServer): # pylint: disable=too-many-arguments,too-many-ins sync_chunk_size: int, keymap_path: str, + mouse_x_range: Tuple[int, int], + mouse_y_range: Tuple[int, int], stream_forever: bool, ) -> None: @@ -199,7 +202,7 @@ class KvmdServer(HttpServer): # pylint: disable=too-many-arguments,too-many-ins LogApi(log_reader), WolApi(wol), UserGpioApi(user_gpio), - HidApi(hid, keymap_path), + HidApi(hid, keymap_path, mouse_x_range, mouse_y_range), AtxApi(atx), MsdApi(msd, sync_chunk_size), StreamerApi(streamer), diff --git a/kvmd/validators/hid.py b/kvmd/validators/hid.py index b51ff88a..bb7e26e1 100644 --- a/kvmd/validators/hid.py +++ b/kvmd/validators/hid.py @@ -42,9 +42,9 @@ def valid_hid_key(arg: Any) -> str: return check_string_in_list(arg, "Keyboard key", KEYMAP, lower=False) -def valid_hid_mouse_move(arg: Any) -> int: +def valid_hid_mouse_move(arg: Any, move_min: int=-32768, move_max: int=32767) -> int: arg = valid_number(arg, name="Mouse move") - return min(max(-32768, arg), 32767) + return min(max(move_min, arg), move_max) def valid_hid_mouse_button(arg: Any) -> str: |