From 0f4294e95a99bf5fc5e528c35554852811dae29a Mon Sep 17 00:00:00 2001 From: Joakim Erdfelt Date: Thu, 21 Feb 2019 10:05:36 -0500 Subject: [PATCH] Issue #3380 - Adding configured Connection.Listeners to WebSocket Connections Signed-off-by: Joakim Erdfelt --- .../core/client/ClientUpgradeRequest.java | 5 +++++ .../core/server/internal/RFC6455Handshaker.java | 14 +++++++++----- 2 files changed, 14 insertions(+), 5 deletions(-) diff --git a/jetty-websocket/websocket-core/src/main/java/org/eclipse/jetty/websocket/core/client/ClientUpgradeRequest.java b/jetty-websocket/websocket-core/src/main/java/org/eclipse/jetty/websocket/core/client/ClientUpgradeRequest.java index 42b0a485b55..13a35c5a554 100644 --- a/jetty-websocket/websocket-core/src/main/java/org/eclipse/jetty/websocket/core/client/ClientUpgradeRequest.java +++ b/jetty-websocket/websocket-core/src/main/java/org/eclipse/jetty/websocket/core/client/ClientUpgradeRequest.java @@ -46,6 +46,7 @@ import org.eclipse.jetty.http.HttpScheme; import org.eclipse.jetty.http.HttpStatus; import org.eclipse.jetty.http.HttpVersion; import org.eclipse.jetty.io.ByteBufferPool; +import org.eclipse.jetty.io.Connection; import org.eclipse.jetty.io.EndPoint; import org.eclipse.jetty.util.B64Code; import org.eclipse.jetty.util.QuotedStringTokenizer; @@ -338,6 +339,10 @@ public abstract class ClientUpgradeRequest extends HttpRequest implements Respon WebSocketChannel wsChannel = newWebSocketChannel(frameHandler, negotiated); WebSocketConnection wsConnection = newWebSocketConnection(endp, httpClient.getExecutor(), httpClient.getByteBufferPool(), wsChannel); + + for (Connection.Listener listener : wsClient.getBeans(Connection.Listener.class)) + wsConnection.addListener(listener); + wsChannel.setWebSocketConnection(wsConnection); wsClient.customize(wsChannel); diff --git a/jetty-websocket/websocket-core/src/main/java/org/eclipse/jetty/websocket/core/server/internal/RFC6455Handshaker.java b/jetty-websocket/websocket-core/src/main/java/org/eclipse/jetty/websocket/core/server/internal/RFC6455Handshaker.java index 5b92c472f32..e2c2ff9822e 100644 --- a/jetty-websocket/websocket-core/src/main/java/org/eclipse/jetty/websocket/core/server/internal/RFC6455Handshaker.java +++ b/jetty-websocket/websocket-core/src/main/java/org/eclipse/jetty/websocket/core/server/internal/RFC6455Handshaker.java @@ -18,12 +18,18 @@ package org.eclipse.jetty.websocket.core.server.internal; +import java.io.IOException; +import java.util.concurrent.Executor; +import javax.servlet.http.HttpServletRequest; +import javax.servlet.http.HttpServletResponse; + import org.eclipse.jetty.http.HttpField; import org.eclipse.jetty.http.HttpHeader; import org.eclipse.jetty.http.HttpMethod; import org.eclipse.jetty.http.HttpVersion; import org.eclipse.jetty.http.PreEncodedHttpField; import org.eclipse.jetty.io.ByteBufferPool; +import org.eclipse.jetty.io.Connection; import org.eclipse.jetty.io.EndPoint; import org.eclipse.jetty.server.ConnectionFactory; import org.eclipse.jetty.server.Connector; @@ -46,11 +52,6 @@ import org.eclipse.jetty.websocket.core.server.Handshaker; import org.eclipse.jetty.websocket.core.server.Negotiation; import org.eclipse.jetty.websocket.core.server.WebSocketNegotiator; -import javax.servlet.http.HttpServletRequest; -import javax.servlet.http.HttpServletResponse; -import java.io.IOException; -import java.util.concurrent.Executor; - public final class RFC6455Handshaker implements Handshaker { static final Logger LOG = Log.getLogger(RFC6455Handshaker.class); @@ -193,6 +194,9 @@ public final class RFC6455Handshaker implements Handshaker return false; } + for (Connection.Listener listener : connector.getBeans(Connection.Listener.class)) + connection.addListener(listener); + channel.setWebSocketConnection(connection); if (defaultCustomizer!=null) defaultCustomizer.customize(channel);