From f8d038e6dead0fd5b6e95cfd8a4a0a3aef94b5c7 Mon Sep 17 00:00:00 2001 From: Iampete1 Date: Thu, 5 Sep 2024 15:45:21 +0100 Subject: [PATCH] mavutil: WebSockets: fix wsproto import for newer python versions --- mavutil.py | 35 +++++++++++++++++++++-------------- 1 file changed, 21 insertions(+), 14 deletions(-) diff --git a/mavutil.py b/mavutil.py index b40ac7c2c..607183cf3 100644 --- a/mavutil.py +++ b/mavutil.py @@ -1738,13 +1738,8 @@ def write(self, buf): class mavwebsocket(mavfile): '''Mavlink WebSocket server, single client only''' def __init__(self, device, source_system=255, source_component=0, use_native=default_native): - from wsproto import ConnectionType, WSConnection, utilities - from wsproto.events import ( - AcceptConnection, - CloseConnection, - Request, - BytesMessage, - ) + # Try importing wsproto, we don't need it here but it means we fail early if its missing + import wsproto self.ws = None @@ -1775,6 +1770,14 @@ def close(self): self.listen.close() def recv(self,n=None): + from wsproto import ConnectionType, WSConnection, utilities + from wsproto.events import ( + AcceptConnection, + CloseConnection, + Request, + BytesMessage, + ) + # Based on: https://github.com/python-hyper/wsproto/blob/main/example/synchronous_server.py if not self.port: try: @@ -1787,7 +1790,7 @@ def recv(self,n=None): self.fd = self.port.fileno() # Start server - self.ws = self.WSConnection(self.ConnectionType.SERVER) + self.ws = WSConnection(ConnectionType.SERVER) if not self.ws: # Should probbily raise a exception of some sort @@ -1803,7 +1806,7 @@ def recv(self,n=None): return '' self.close_port() return '' - except self.utilities.RemoteProtocolError: + except utilities.RemoteProtocolError: self.close_port() return '' @@ -1812,16 +1815,16 @@ def recv(self,n=None): reply = b"" keep_running = True for event in self.ws.events(): - if isinstance(event, self.Request): + if isinstance(event, Request): # Negotiate new WebSocket connection - reply += self.ws.send(self.AcceptConnection()) + reply += self.ws.send(AcceptConnection()) - elif isinstance(event, self.CloseConnection): + elif isinstance(event, CloseConnection): # Request to close reply += self.ws.send(event.response()) keep_running = False - elif isinstance(event, self.BytesMessage): + elif isinstance(event, BytesMessage): # Some actual MAVLink data data += event.data @@ -1839,8 +1842,12 @@ def write(self, buf): if self.port is None or self.ws is None: return + from wsproto.events import ( + BytesMessage, + ) + # Pack buf into WebSocket binary message - packed = self.ws.send(self.BytesMessage(data = buf)) + packed = self.ws.send(BytesMessage(data = buf)) try: self.port.send(packed)