From d64dc9a0462ce25ddf6cf820f438d76faf52fbe9 Mon Sep 17 00:00:00 2001 From: Wouter Born Date: Tue, 10 Oct 2023 09:44:37 +0200 Subject: [PATCH] [shelly] Always try to stop WebSocketClient (#15721) If the client is not stopped it will not be garbage collected because the ShutdownThread keeps a reference to the client so it can be stopped on shutdowns. See: https://github.com/eclipse/jetty.project/blob/jetty-9.4.x/jetty-websocket/websocket-client/src/main/java/org/eclipse/jetty/websocket/client/WebSocketClient.java#L420-L433 Signed-off-by: Wouter Born --- .../binding/shelly/internal/api2/Shelly2ApiRpc.java | 10 +++------- .../binding/shelly/internal/api2/Shelly2RpcSocket.java | 4 +--- 2 files changed, 4 insertions(+), 10 deletions(-) diff --git a/bundles/org.openhab.binding.shelly/src/main/java/org/openhab/binding/shelly/internal/api2/Shelly2ApiRpc.java b/bundles/org.openhab.binding.shelly/src/main/java/org/openhab/binding/shelly/internal/api2/Shelly2ApiRpc.java index de378fedab8..d6d049d9b37 100644 --- a/bundles/org.openhab.binding.shelly/src/main/java/org/openhab/binding/shelly/internal/api2/Shelly2ApiRpc.java +++ b/bundles/org.openhab.binding.shelly/src/main/java/org/openhab/binding/shelly/internal/api2/Shelly2ApiRpc.java @@ -141,10 +141,8 @@ public class Shelly2ApiRpc extends Shelly2ApiClient implements ShellyApiInterfac rpcSocket.addMessageHandler(this); initialized = true; } else { - if (rpcSocket.isConnected()) { - logger.debug("{}: Disconnect Rpc Socket on initialize", thingName); - disconnect(); - } + logger.debug("{}: Disconnect Rpc Socket on initialize", thingName); + disconnect(); } } @@ -1217,9 +1215,7 @@ public class Shelly2ApiRpc extends Shelly2ApiClient implements ShellyApiInterfac } private void disconnect() { - if (rpcSocket.isConnected()) { - rpcSocket.disconnect(); - } + rpcSocket.disconnect(); } public Shelly2RpctInterface getRpcHandler() { diff --git a/bundles/org.openhab.binding.shelly/src/main/java/org/openhab/binding/shelly/internal/api2/Shelly2RpcSocket.java b/bundles/org.openhab.binding.shelly/src/main/java/org/openhab/binding/shelly/internal/api2/Shelly2RpcSocket.java index a043772cd9a..ead93f3653c 100644 --- a/bundles/org.openhab.binding.shelly/src/main/java/org/openhab/binding/shelly/internal/api2/Shelly2RpcSocket.java +++ b/bundles/org.openhab.binding.shelly/src/main/java/org/openhab/binding/shelly/internal/api2/Shelly2RpcSocket.java @@ -211,9 +211,7 @@ public class Shelly2RpcSocket { s.close(StatusCode.NORMAL, "Socket closed"); session = null; } - if (client.isStarted()) { - client.stop(); - } + client.stop(); } catch (Exception e) { if (e.getCause() instanceof InterruptedException) { logger.debug("{}: Unable to close socket - interrupted", thingName); // e.g. device was rebooted