summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorArtur Signell <artur@vaadin.com>2013-04-03 18:17:32 +0300
committerArtur Signell <artur@vaadin.com>2013-04-03 18:37:59 +0300
commitb6928fde240d5b660a4a7be1076e7c58584b3303 (patch)
tree973081208bcbbd89076bfd46cc5711cfea865f82
parent3c479dd00b24acad23e7c97e7283e31299d771d1 (diff)
downloadvaadin-framework-b6928fde240d5b660a4a7be1076e7c58584b3303.tar.gz
vaadin-framework-b6928fde240d5b660a4a7be1076e7c58584b3303.zip
Reworked fix for ignoring /APP/ (#11192)
* Fixed potential NPE by using existing helper method * Pass /APP/ urls also to session handlers as at least GlobalResourceHandler requires it * Fixed test to test /APP/ instead of /APP Change-Id: I8d913e6a5509c63f8e47813fce5751f5279ed4fc
-rw-r--r--server/src/com/vaadin/server/BootstrapHandler.java3
-rw-r--r--server/src/com/vaadin/server/communication/SessionRequestHandler.java8
-rw-r--r--uitest/src/com/vaadin/tests/requesthandlers/AppResource404.java4
3 files changed, 3 insertions, 12 deletions
diff --git a/server/src/com/vaadin/server/BootstrapHandler.java b/server/src/com/vaadin/server/BootstrapHandler.java
index 80cadb02c1..671279219e 100644
--- a/server/src/com/vaadin/server/BootstrapHandler.java
+++ b/server/src/com/vaadin/server/BootstrapHandler.java
@@ -115,8 +115,7 @@ public abstract class BootstrapHandler extends SynchronizedRequestHandler {
@Override
public boolean synchronizedHandleRequest(VaadinSession session,
VaadinRequest request, VaadinResponse response) throws IOException {
- String pathInfo = request.getPathInfo();
- if (pathInfo.startsWith("/" + ApplicationConstants.APP_PATH + "/")) {
+ if (ServletPortletHelper.isAppRequest(request)) {
// We do not want to handle /APP requests here, instead let it fall
// through and produce a 404
return false;
diff --git a/server/src/com/vaadin/server/communication/SessionRequestHandler.java b/server/src/com/vaadin/server/communication/SessionRequestHandler.java
index 14c940acf5..244cb0121d 100644
--- a/server/src/com/vaadin/server/communication/SessionRequestHandler.java
+++ b/server/src/com/vaadin/server/communication/SessionRequestHandler.java
@@ -22,7 +22,6 @@ import com.vaadin.server.RequestHandler;
import com.vaadin.server.VaadinRequest;
import com.vaadin.server.VaadinResponse;
import com.vaadin.server.VaadinSession;
-import com.vaadin.shared.ApplicationConstants;
/**
* Handles a request by passing it to each registered {@link RequestHandler} in
@@ -51,13 +50,6 @@ public class SessionRequestHandler implements RequestHandler {
@Override
public boolean handleRequest(VaadinSession session, VaadinRequest request,
VaadinResponse response) throws IOException {
- String pathInfo = request.getPathInfo();
- if (pathInfo.startsWith("/" + ApplicationConstants.APP_PATH + "/")) {
- // /<APP_PATH>/ is reserved for Vaadin internal use and these
- // requests should not be passed to session request handlers
- return false;
- }
-
// Use a copy to avoid ConcurrentModificationException
session.lock();
ArrayList<RequestHandler> requestHandlers;
diff --git a/uitest/src/com/vaadin/tests/requesthandlers/AppResource404.java b/uitest/src/com/vaadin/tests/requesthandlers/AppResource404.java
index dfd664c9cf..a6a5a5a084 100644
--- a/uitest/src/com/vaadin/tests/requesthandlers/AppResource404.java
+++ b/uitest/src/com/vaadin/tests/requesthandlers/AppResource404.java
@@ -23,8 +23,8 @@ public class AppResource404 extends TestBase {
addComponent(new Link("Existing resource", resource));
addComponent(new Link("Non-existing resource", new ExternalResource(
baseUrl + "/APP/connector/0/4/asdfasdf")));
- addComponent(new Link("/APP url that should give 404",
- new ExternalResource(baseUrl + "/APP")));
+ addComponent(new Link("/APP/ url that should give 404",
+ new ExternalResource(baseUrl + "/APP/")));
addComponent(new Link("/APPLE url that should go to UI providers",
new ExternalResource(baseUrl + "/APPLE")));
}