diff --git a/jetty-websocket/websocket-javax-client/src/main/java/org/eclipse/jetty/websocket/javax/client/internal/JavaxClientUpgradeRequest.java b/jetty-websocket/websocket-javax-client/src/main/java/org/eclipse/jetty/websocket/javax/client/internal/JavaxClientUpgradeRequest.java index b2fd4d5ae521..d2c8856db665 100644 --- a/jetty-websocket/websocket-javax-client/src/main/java/org/eclipse/jetty/websocket/javax/client/internal/JavaxClientUpgradeRequest.java +++ b/jetty-websocket/websocket-javax-client/src/main/java/org/eclipse/jetty/websocket/javax/client/internal/JavaxClientUpgradeRequest.java @@ -64,4 +64,10 @@ public URI getRequestURI() { return getURI(); } + + @Override + public String getPathInContext() + { + throw new UnsupportedOperationException(); + } } diff --git a/jetty-websocket/websocket-javax-client/src/main/java/org/eclipse/jetty/websocket/javax/client/internal/JavaxWebSocketClientFrameHandlerFactory.java b/jetty-websocket/websocket-javax-client/src/main/java/org/eclipse/jetty/websocket/javax/client/internal/JavaxWebSocketClientFrameHandlerFactory.java index 39f3221b8772..5a1b5252e0ea 100644 --- a/jetty-websocket/websocket-javax-client/src/main/java/org/eclipse/jetty/websocket/javax/client/internal/JavaxWebSocketClientFrameHandlerFactory.java +++ b/jetty-websocket/websocket-javax-client/src/main/java/org/eclipse/jetty/websocket/javax/client/internal/JavaxWebSocketClientFrameHandlerFactory.java @@ -40,7 +40,7 @@ public JavaxWebSocketClientFrameHandlerFactory(JavaxWebSocketContainer container } @Override - public EndpointConfig newDefaultEndpointConfig(Class endpointClass, String path) + public EndpointConfig newDefaultEndpointConfig(Class endpointClass) { return new BasicClientEndpointConfig(); } diff --git a/jetty-websocket/websocket-javax-common/src/main/java/org/eclipse/jetty/websocket/javax/common/JavaxWebSocketFrameHandlerFactory.java b/jetty-websocket/websocket-javax-common/src/main/java/org/eclipse/jetty/websocket/javax/common/JavaxWebSocketFrameHandlerFactory.java index 5eeea2518089..eb51e98d4fa8 100644 --- a/jetty-websocket/websocket-javax-common/src/main/java/org/eclipse/jetty/websocket/javax/common/JavaxWebSocketFrameHandlerFactory.java +++ b/jetty-websocket/websocket-javax-common/src/main/java/org/eclipse/jetty/websocket/javax/common/JavaxWebSocketFrameHandlerFactory.java @@ -144,7 +144,7 @@ public JavaxWebSocketFrameHandlerFactory(JavaxWebSocketContainer container, Invo public abstract JavaxWebSocketFrameHandlerMetadata getMetadata(Class endpointClass, EndpointConfig endpointConfig); - public abstract EndpointConfig newDefaultEndpointConfig(Class endpointClass, String path); + public abstract EndpointConfig newDefaultEndpointConfig(Class endpointClass); public JavaxWebSocketFrameHandler newJavaxWebSocketFrameHandler(Object endpointInstance, UpgradeRequest upgradeRequest) { @@ -160,8 +160,7 @@ public JavaxWebSocketFrameHandler newJavaxWebSocketFrameHandler(Object endpointI else { endpoint = endpointInstance; - String path = (upgradeRequest.getRequestURI() == null) ? null : upgradeRequest.getRequestURI().getPath(); - config = newDefaultEndpointConfig(endpoint.getClass(), path); + config = newDefaultEndpointConfig(endpoint.getClass()); } JavaxWebSocketFrameHandlerMetadata metadata = getMetadata(endpoint.getClass(), config); @@ -180,7 +179,7 @@ public JavaxWebSocketFrameHandler newJavaxWebSocketFrameHandler(Object endpointI if (templatePathSpec != null) { String[] namedVariables = templatePathSpec.getVariables(); - Map pathParams = templatePathSpec.getPathParams(upgradeRequest.getRequestURI().getRawPath()); + Map pathParams = templatePathSpec.getPathParams(upgradeRequest.getPathInContext()); // Handle parameterized @PathParam entries openHandle = bindTemplateVariables(openHandle, namedVariables, pathParams); diff --git a/jetty-websocket/websocket-javax-common/src/main/java/org/eclipse/jetty/websocket/javax/common/UpgradeRequest.java b/jetty-websocket/websocket-javax-common/src/main/java/org/eclipse/jetty/websocket/javax/common/UpgradeRequest.java index 90de5c9c4923..5764910685a8 100644 --- a/jetty-websocket/websocket-javax-common/src/main/java/org/eclipse/jetty/websocket/javax/common/UpgradeRequest.java +++ b/jetty-websocket/websocket-javax-common/src/main/java/org/eclipse/jetty/websocket/javax/common/UpgradeRequest.java @@ -31,9 +31,14 @@ public interface UpgradeRequest Principal getUserPrincipal(); /** - * For obtaining {@link javax.websocket.server.PathParam} values from Request URI path - * - * @return the request URI + * @return the full URI of this request. */ URI getRequestURI(); + + /** + * For obtaining {@link javax.websocket.server.PathParam} values from the Request context path. + * + * @return the path in Context. + */ + String getPathInContext(); } diff --git a/jetty-websocket/websocket-javax-common/src/main/java/org/eclipse/jetty/websocket/javax/common/UpgradeRequestAdapter.java b/jetty-websocket/websocket-javax-common/src/main/java/org/eclipse/jetty/websocket/javax/common/UpgradeRequestAdapter.java index 4ab2345d6695..42e2f94e7fab 100644 --- a/jetty-websocket/websocket-javax-common/src/main/java/org/eclipse/jetty/websocket/javax/common/UpgradeRequestAdapter.java +++ b/jetty-websocket/websocket-javax-common/src/main/java/org/eclipse/jetty/websocket/javax/common/UpgradeRequestAdapter.java @@ -24,16 +24,18 @@ public class UpgradeRequestAdapter implements UpgradeRequest { private final URI requestURI; + private final String pathInContext; public UpgradeRequestAdapter() { /* anonymous, no requestURI, upgrade request */ - this(null); + this(null, null); } - public UpgradeRequestAdapter(URI uri) + public UpgradeRequestAdapter(URI uri, String pathInContext) { this.requestURI = uri; + this.pathInContext = pathInContext; } @Override @@ -47,4 +49,10 @@ public URI getRequestURI() { return requestURI; } + + @Override + public String getPathInContext() + { + return pathInContext; + } } diff --git a/jetty-websocket/websocket-javax-common/src/test/java/org/eclipse/jetty/websocket/javax/common/AbstractSessionTest.java b/jetty-websocket/websocket-javax-common/src/test/java/org/eclipse/jetty/websocket/javax/common/AbstractSessionTest.java index e425420c99b9..c96927c7dc64 100644 --- a/jetty-websocket/websocket-javax-common/src/test/java/org/eclipse/jetty/websocket/javax/common/AbstractSessionTest.java +++ b/jetty-websocket/websocket-javax-common/src/test/java/org/eclipse/jetty/websocket/javax/common/AbstractSessionTest.java @@ -41,7 +41,7 @@ public static void initSession() throws Exception JavaxWebSocketFrameHandler frameHandler = container.newFrameHandler(websocketPojo, upgradeRequest); CoreSession coreSession = new CoreSession.Empty(); session = new JavaxWebSocketSession(container, coreSession, frameHandler, container.getFrameHandlerFactory() - .newDefaultEndpointConfig(websocketPojo.getClass(), null)); + .newDefaultEndpointConfig(websocketPojo.getClass())); } @AfterAll diff --git a/jetty-websocket/websocket-javax-common/src/test/java/org/eclipse/jetty/websocket/javax/common/DummyFrameHandlerFactory.java b/jetty-websocket/websocket-javax-common/src/test/java/org/eclipse/jetty/websocket/javax/common/DummyFrameHandlerFactory.java index d7468d6a2d0a..12d00d0c67d8 100644 --- a/jetty-websocket/websocket-javax-common/src/test/java/org/eclipse/jetty/websocket/javax/common/DummyFrameHandlerFactory.java +++ b/jetty-websocket/websocket-javax-common/src/test/java/org/eclipse/jetty/websocket/javax/common/DummyFrameHandlerFactory.java @@ -33,7 +33,7 @@ public DummyFrameHandlerFactory(JavaxWebSocketContainer container) } @Override - public EndpointConfig newDefaultEndpointConfig(Class endpointClass, String path) + public EndpointConfig newDefaultEndpointConfig(Class endpointClass) { return ClientEndpointConfig.Builder.create().build(); } diff --git a/jetty-websocket/websocket-javax-server/src/main/java/org/eclipse/jetty/websocket/javax/server/internal/JavaxServerUpgradeRequest.java b/jetty-websocket/websocket-javax-server/src/main/java/org/eclipse/jetty/websocket/javax/server/internal/JavaxServerUpgradeRequest.java index 9b4d4d559393..69624723ec89 100644 --- a/jetty-websocket/websocket-javax-server/src/main/java/org/eclipse/jetty/websocket/javax/server/internal/JavaxServerUpgradeRequest.java +++ b/jetty-websocket/websocket-javax-server/src/main/java/org/eclipse/jetty/websocket/javax/server/internal/JavaxServerUpgradeRequest.java @@ -42,6 +42,12 @@ public Principal getUserPrincipal() @Override public URI getRequestURI() { - return this.servletRequest.getRequestURI(); + return servletRequest.getRequestURI(); + } + + @Override + public String getPathInContext() + { + return servletRequest.getPathInContext(); } } diff --git a/jetty-websocket/websocket-javax-tests/src/test/java/org/eclipse/jetty/websocket/javax/tests/PathParamTest.java b/jetty-websocket/websocket-javax-tests/src/test/java/org/eclipse/jetty/websocket/javax/tests/PathParamTest.java index 2b3e28eeff84..b67e44a462aa 100644 --- a/jetty-websocket/websocket-javax-tests/src/test/java/org/eclipse/jetty/websocket/javax/tests/PathParamTest.java +++ b/jetty-websocket/websocket-javax-tests/src/test/java/org/eclipse/jetty/websocket/javax/tests/PathParamTest.java @@ -53,7 +53,7 @@ public void startContainer() throws Exception _server.addConnector(_connector); _context = new ServletContextHandler(ServletContextHandler.SESSIONS); - _context.setContextPath("/"); + _context.setContextPath("/context"); _server.setHandler(_context); JavaxWebSocketServletContainerInitializer.configure(_context, (context, container) -> @@ -68,7 +68,7 @@ public void stopContainer() throws Exception _server.stop(); } - @ServerEndpoint("/pathparam/echo/{name}") + @ServerEndpoint("/pathParam/echo/{name}") public static class EchoParamSocket { private Session session; @@ -92,7 +92,7 @@ public void testBasicPathParamSocket() throws Exception WebSocketContainer container = ContainerProvider.getWebSocketContainer(); EventSocket clientEndpoint = new EventSocket(); - URI serverUri = URI.create("ws://localhost:" + _connector.getLocalPort() + "/pathparam/echo/myParam"); + URI serverUri = URI.create("ws://localhost:" + _connector.getLocalPort() + "/context/pathParam/echo/myParam"); Session session = container.connectToServer(clientEndpoint, serverUri); session.getBasicRemote().sendText("echo"); diff --git a/jetty-websocket/websocket-javax-tests/src/test/java/org/eclipse/jetty/websocket/javax/tests/server/JavaxWebSocketFrameHandlerOnMessageTextStreamTest.java b/jetty-websocket/websocket-javax-tests/src/test/java/org/eclipse/jetty/websocket/javax/tests/server/JavaxWebSocketFrameHandlerOnMessageTextStreamTest.java index 781172066728..3b1b6b5abe43 100644 --- a/jetty-websocket/websocket-javax-tests/src/test/java/org/eclipse/jetty/websocket/javax/tests/server/JavaxWebSocketFrameHandlerOnMessageTextStreamTest.java +++ b/jetty-websocket/websocket-javax-tests/src/test/java/org/eclipse/jetty/websocket/javax/tests/server/JavaxWebSocketFrameHandlerOnMessageTextStreamTest.java @@ -46,7 +46,8 @@ public class JavaxWebSocketFrameHandlerOnMessageTextStreamTest extends AbstractJ @SuppressWarnings("Duplicates") private T performOnMessageInvocation(T socket, Consumer func) throws Exception { - UpgradeRequest request = new UpgradeRequestAdapter(URI.create("http://localhost:8080/msg/foo")); + URI uri = URI.create("http://localhost:8080/msg/foo"); + UpgradeRequest request = new UpgradeRequestAdapter(uri, uri.getPath()); // Establish endpoint function JavaxWebSocketFrameHandler frameHandler = container.newFrameHandler(socket, request); diff --git a/jetty-websocket/websocket-servlet/src/main/java/org/eclipse/jetty/websocket/servlet/ServletUpgradeRequest.java b/jetty-websocket/websocket-servlet/src/main/java/org/eclipse/jetty/websocket/servlet/ServletUpgradeRequest.java index ef81155a00b9..f327a424a958 100644 --- a/jetty-websocket/websocket-servlet/src/main/java/org/eclipse/jetty/websocket/servlet/ServletUpgradeRequest.java +++ b/jetty-websocket/websocket-servlet/src/main/java/org/eclipse/jetty/websocket/servlet/ServletUpgradeRequest.java @@ -38,6 +38,7 @@ import org.eclipse.jetty.http.BadMessageException; import org.eclipse.jetty.http.HttpHeader; +import org.eclipse.jetty.util.URIUtil; import org.eclipse.jetty.websocket.core.ExtensionConfig; import org.eclipse.jetty.websocket.core.WebSocketConstants; import org.eclipse.jetty.websocket.core.server.Negotiation; @@ -314,6 +315,14 @@ public URI getRequestURI() return requestURI; } + /** + * @return the path within the context, combination of the ServletPath with the PathInfo. + */ + public String getPathInContext() + { + return URIUtil.addPaths(request.getServletPath(), request.getPathInfo()); + } + /** * @param name Attribute name * @return Attribute value or null