This is an automated email from the ASF dual-hosted git repository.

mgrigorov pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/wicket.git


The following commit(s) were added to refs/heads/master by this push:
     new 6d453fa  WICKET-6759 Add `shouldNotifyOnErrorEvent` filter function to 
`WebSocketSettings` (#416)
6d453fa is described below

commit 6d453fa39978d921f15dfdba8f1a515b86feb0d0
Author: Thomas <[email protected]>
AuthorDate: Fri Mar 20 13:52:13 2020 +0100

    WICKET-6759 Add `shouldNotifyOnErrorEvent` filter function to 
`WebSocketSettings` (#416)
---
 .../org/apache/wicket/protocol/ws/WebSocketSettings.java | 16 ++++++++++++++++
 .../protocol/ws/api/AbstractWebSocketProcessor.java      |  6 ++++--
 2 files changed, 20 insertions(+), 2 deletions(-)

diff --git 
a/wicket-native-websocket/wicket-native-websocket-core/src/main/java/org/apache/wicket/protocol/ws/WebSocketSettings.java
 
b/wicket-native-websocket/wicket-native-websocket-core/src/main/java/org/apache/wicket/protocol/ws/WebSocketSettings.java
index d6967a6..b755c18 100644
--- 
a/wicket-native-websocket/wicket-native-websocket-core/src/main/java/org/apache/wicket/protocol/ws/WebSocketSettings.java
+++ 
b/wicket-native-websocket/wicket-native-websocket-core/src/main/java/org/apache/wicket/protocol/ws/WebSocketSettings.java
@@ -149,6 +149,22 @@ public class WebSocketSettings
        }
 
        /**
+        * A function that decides whether to notify the page/resource on
+        * web socket error event.
+        * The page notification leads to deserialization of the page instance 
from
+        * the page store and sometimes this is not wanted.
+        */
+       private Function<Throwable, Boolean> notifyOnErrorEvent = (throwable) 
-> true;
+
+       public boolean shouldNotifyOnErrorEvent(Throwable throwable) {
+               return notifyOnErrorEvent == null || 
notifyOnErrorEvent.apply(throwable);
+       }
+
+       public void setNotifyOnErrorEvent(Function<Throwable, Boolean> 
notifyOnErrorEvent) {
+               this.notifyOnErrorEvent = notifyOnErrorEvent;
+       }
+
+       /**
         * Set the executor for processing websocket push messages broadcasted 
to all sessions.
         * Default executor does all the processing in the caller thread. Using 
a proper thread pool is adviced
         * for applications that send push events from ajax calls to avoid page 
level deadlocks.
diff --git 
a/wicket-native-websocket/wicket-native-websocket-core/src/main/java/org/apache/wicket/protocol/ws/api/AbstractWebSocketProcessor.java
 
b/wicket-native-websocket/wicket-native-websocket-core/src/main/java/org/apache/wicket/protocol/ws/api/AbstractWebSocketProcessor.java
index 2505278..c533858 100644
--- 
a/wicket-native-websocket/wicket-native-websocket-core/src/main/java/org/apache/wicket/protocol/ws/api/AbstractWebSocketProcessor.java
+++ 
b/wicket-native-websocket/wicket-native-websocket-core/src/main/java/org/apache/wicket/protocol/ws/api/AbstractWebSocketProcessor.java
@@ -194,8 +194,10 @@ public abstract class AbstractWebSocketProcessor 
implements IWebSocketProcessor
        @Override
        public void onError(Throwable t)
        {
-               IKey key = getRegistryKey();
-               broadcastMessage(new ErrorMessage(getApplication(), 
getSessionId(), key, t));
+               if (webSocketSettings.shouldNotifyOnErrorEvent(t)) {
+                       IKey key = getRegistryKey();
+                       broadcastMessage(new ErrorMessage(getApplication(), 
getSessionId(), key, t));
+               }
        }
 
        /**

Reply via email to