From 1133c296b10fde1901fd2a16822edd19e4807f15 Mon Sep 17 00:00:00 2001 From: Eric Callahan Date: Thu, 7 Apr 2022 18:01:50 -0400 Subject: [PATCH] websockets: implement notification masking Signed-off-by: Eric Callahan --- moonraker/websockets.py | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/moonraker/websockets.py b/moonraker/websockets.py index 99d8410..5564ea5 100644 --- a/moonraker/websockets.py +++ b/moonraker/websockets.py @@ -20,6 +20,7 @@ from typing import ( Optional, Callable, Coroutine, + Tuple, Type, TypeVar, Union, @@ -323,7 +324,7 @@ class WebsocketManager(APITransport): notify_name = event_name.split(':')[-1] def notify_handler(*args): - self.notify_websockets(notify_name, *args) + self.notify_websockets(notify_name, args) self.server.register_event_handler( event_name, notify_handler) @@ -450,12 +451,15 @@ class WebsocketManager(APITransport): def notify_websockets(self, name: str, - data: Any = SENTINEL + data: Union[List, Tuple] = [], + mask: List[int] = [] ) -> None: msg: Dict[str, Any] = {'jsonrpc': "2.0", 'method': "notify_" + name} - if data != SENTINEL: - msg['params'] = [data] + if data: + msg['params'] = data for ws in list(self.websockets.values()): + if ws.uid in mask: + continue ws.queue_message(msg) def get_count(self) -> int: @@ -598,6 +602,9 @@ class WebSocket(WebSocketHandler, Subscribable): self.queue_message(msg) return fut + def send_notification(self, name: str, data: List) -> None: + self.wsm.notify_websockets(name, data, [self._uid]) + def resolve_pending_response( self, response_id: int, result: Any ) -> bool: