summaryrefslogtreecommitdiff
path: root/kvmd
diff options
context:
space:
mode:
authorDevaev Maxim <[email protected]>2020-09-22 01:20:23 +0300
committerDevaev Maxim <[email protected]>2020-09-22 04:42:39 +0300
commitf4eabde86eb8b3e5894c8cd47228a944e6fc5c73 (patch)
treecdb120bafb79e583f6aa1d023f7f7fd75748126d /kvmd
parentc86b20f1b1b248c8688ede9dbb4115d199236fa6 (diff)
removed unnecessary broadcasting
Diffstat (limited to 'kvmd')
-rw-r--r--kvmd/apps/kvmd/server.py17
1 files changed, 10 insertions, 7 deletions
diff --git a/kvmd/apps/kvmd/server.py b/kvmd/apps/kvmd/server.py
index 4003bf2b..6f753418 100644
--- a/kvmd/apps/kvmd/server.py
+++ b/kvmd/apps/kvmd/server.py
@@ -250,9 +250,9 @@ class KvmdServer(HttpServer): # pylint: disable=too-many-arguments,too-many-ins
await client.ws.prepare(request)
await self.__register_ws_client(client)
try:
- await self.__broadcast_event("gpio_model_state", await self.__user_gpio.get_model())
+ await self.__send_event(client.ws, "gpio_model_state", await self.__user_gpio.get_model())
await asyncio.gather(*[
- self.__broadcast_event(component.event_type, await component.get_state())
+ self.__send_event(client.ws, component.event_type, await component.get_state())
for component in self.__components
if component.get_state
])
@@ -278,7 +278,7 @@ class KvmdServer(HttpServer): # pylint: disable=too-many-arguments,too-many-ins
@exposed_ws("ping")
async def __ws_ping_handler(self, ws: aiohttp.web.WebSocketResponse, _: Dict) -> None:
- await ws.send_str(json.dumps({"event_type": "pong", "event": {}}))
+ await self.__send_event(ws, "pong", {})
# ===== SYSTEM STUFF
@@ -363,13 +363,16 @@ class KvmdServer(HttpServer): # pylint: disable=too-many-arguments,too-many-ins
except Exception:
logger.exception("Cleanup error on %s", component.name)
+ async def __send_event(self, ws: aiohttp.web.WebSocketResponse, event_type: str, event: Optional[Dict]) -> None:
+ await ws.send_str(json.dumps({
+ "event_type": event_type,
+ "event": event,
+ }))
+
async def __broadcast_event(self, event_type: str, event: Optional[Dict]) -> None:
if self.__ws_clients:
await asyncio.gather(*[
- client.ws.send_str(json.dumps({
- "event_type": event_type,
- "event": event,
- }))
+ self.__send_event(client.ws, event_type, event)
for client in list(self.__ws_clients)
if (
not client.ws.closed