From eda6136f46ec88247097887abe6395cda304f867 Mon Sep 17 00:00:00 2001 From: Erik Sundell Date: Thu, 22 Feb 2024 12:04:23 +0100 Subject: [PATCH] Warn if proxied websockets' selected subprotocols mismatch --- jupyter_server_proxy/handlers.py | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/jupyter_server_proxy/handlers.py b/jupyter_server_proxy/handlers.py index 3d155a1a..a0e12260 100644 --- a/jupyter_server_proxy/handlers.py +++ b/jupyter_server_proxy/handlers.py @@ -500,6 +500,16 @@ async def start_websocket_connection(): ) self._record_activity() self.log.info(f"Websocket connection established to {client_uri}") + if ( + subprotocols + and self.ws.selected_subprotocol != self.selected_subprotocol + ): + self.log.warn( + f"Websocket subprotocol between proxy/server ({self.ws.selected_subprotocol}) " + f"became different than for client/proxy ({self.selected_subprotocol}) " + "due to https://github.com/jupyterhub/jupyter-server-proxy/issues/459. " + f"Requested subprotocols were {subprotocols}." + ) # Wait for the WebSocket to be connected before resolving. # Otherwise, messages sent by the client before the @@ -539,7 +549,8 @@ def select_subprotocol(self, subprotocols): Note that this subprotocol selection should really be delegated to the server we proxy to, but we don't! For this to happen, we would need to delay accepting the handshake with the client until we have successfully - handshaked with the server. + handshaked with the server. This issue is tracked via + https://github.com/jupyterhub/jupyter-server-proxy/issues/459. Overrides `tornado.websocket.WebSocketHandler.select_subprotocol` that includes an informative docstring: @@ -549,7 +560,6 @@ def select_subprotocol(self, subprotocols): self.log.debug( f"Client sent subprotocols: {subprotocols}, selecting the first" ) - # TODO: warn if we select one out of multiple! return subprotocols[0] return None