aboutsummaryrefslogtreecommitdiffstats
path: root/server/src/main
diff options
context:
space:
mode:
authorMartin Vysny <martin@vysny.me>2020-10-12 15:38:22 +0300
committerGitHub <noreply@github.com>2020-10-12 15:38:22 +0300
commite3b0a113b112724923f326806c7e618e1f01cee0 (patch)
tree8888be44e27209d5df72c213c61917259eee565b /server/src/main
parentb817d61d6ab3f22057a85018a68701cb9ed5473f (diff)
downloadvaadin-framework-e3b0a113b112724923f326806c7e618e1f01cee0.tar.gz
vaadin-framework-e3b0a113b112724923f326806c7e618e1f01cee0.zip
Log informative message instead of failing with ClassCastException when polling an obsolete resource (#12115)
https://github.com/vaadin/framework/issues/12113
Diffstat (limited to 'server/src/main')
-rw-r--r--server/src/main/java/com/vaadin/server/AbstractClientConnector.java20
1 files changed, 18 insertions, 2 deletions
diff --git a/server/src/main/java/com/vaadin/server/AbstractClientConnector.java b/server/src/main/java/com/vaadin/server/AbstractClientConnector.java
index fe16736465..1a16743105 100644
--- a/server/src/main/java/com/vaadin/server/AbstractClientConnector.java
+++ b/server/src/main/java/com/vaadin/server/AbstractClientConnector.java
@@ -31,6 +31,8 @@ import java.util.List;
import java.util.Map;
import java.util.NoSuchElementException;
import java.util.WeakHashMap;
+import java.util.logging.Level;
+import java.util.logging.Logger;
import com.vaadin.event.EventRouter;
import com.vaadin.event.MethodEventSource;
@@ -50,6 +52,8 @@ import com.vaadin.util.ReflectTools;
import elemental.json.JsonObject;
import elemental.json.JsonValue;
+import javax.servlet.http.HttpServletResponse;
+
/**
* An abstract base class for ClientConnector implementations. This class
* provides all the basic functionality required for connectors.
@@ -59,6 +63,11 @@ import elemental.json.JsonValue;
*/
public abstract class AbstractClientConnector
implements ClientConnector, MethodEventSource {
+
+ private static Logger getLogger() {
+ return Logger.getLogger(AbstractClientConnector.class.getName());
+ }
+
/**
* A map from client to server RPC interface class name to the RPC call
* manager that handles incoming RPC calls for that interface.
@@ -669,11 +678,18 @@ public abstract class AbstractClientConnector
VaadinSession session = getSession();
session.lock();
try {
- ConnectorResource resource = (ConnectorResource) getResource(key);
+ Resource resource = getResource(key);
if (resource == null) {
return false;
+ } else if (!(resource instanceof ConnectorResource)) {
+ response.sendError(HttpServletResponse.SC_NOT_FOUND,
+ "Resource is no longer present");
+ getLogger().log(Level.INFO, "The resource '" + key + "' is a "
+ + resource.getClass().getSimpleName()
+ + " now; it is no longer a ConnectorResource and request could not be handled");
+ return true;
}
- stream = resource.getStream();
+ stream = ((ConnectorResource) resource).getStream();
} finally {
session.unlock();
}