From d6a52d5b2c89f174a764f33397b66b7e55274c44 Mon Sep 17 00:00:00 2001 From: Michael Lobstein Date: Fri, 25 Jun 2021 16:18:36 -0500 Subject: [PATCH] Fix thing staying offline after connection refresh Signed-off-by: Michael Lobstein --- .../org/openhab/binding/tivo/internal/handler/TiVoHandler.java | 1 + .../binding/tivo/internal/service/TivoStatusProvider.java | 3 ++- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/bundles/org.openhab.binding.tivo/src/main/java/org/openhab/binding/tivo/internal/handler/TiVoHandler.java b/bundles/org.openhab.binding.tivo/src/main/java/org/openhab/binding/tivo/internal/handler/TiVoHandler.java index 4546be62fa010..c38a8871bf2fb 100644 --- a/bundles/org.openhab.binding.tivo/src/main/java/org/openhab/binding/tivo/internal/handler/TiVoHandler.java +++ b/bundles/org.openhab.binding.tivo/src/main/java/org/openhab/binding/tivo/internal/handler/TiVoHandler.java @@ -115,6 +115,7 @@ public void handleCommand(ChannelUID channelUID, Command command) { } public void setStatusOffline() { + lastConnectionStatus = ConnectionStatus.UNKNOWN; this.updateStatus(ThingStatus.OFFLINE, ThingStatusDetail.COMMUNICATION_ERROR, "Power on device or check network configuration/connection."); } diff --git a/bundles/org.openhab.binding.tivo/src/main/java/org/openhab/binding/tivo/internal/service/TivoStatusProvider.java b/bundles/org.openhab.binding.tivo/src/main/java/org/openhab/binding/tivo/internal/service/TivoStatusProvider.java index b831649333bf2..ae3e70cf74121 100644 --- a/bundles/org.openhab.binding.tivo/src/main/java/org/openhab/binding/tivo/internal/service/TivoStatusProvider.java +++ b/bundles/org.openhab.binding.tivo/src/main/java/org/openhab/binding/tivo/internal/service/TivoStatusProvider.java @@ -20,6 +20,7 @@ import java.io.InputStreamReader; import java.io.PrintStream; import java.net.Socket; +import java.net.SocketException; import java.net.SocketTimeoutException; import java.net.UnknownHostException; import java.util.concurrent.TimeUnit; @@ -441,7 +442,7 @@ public void run() { try { receivedData = reader.readLine(); - } catch (SocketTimeoutException e) { + } catch (SocketTimeoutException | SocketException e) { // Do nothing. Just allow the thread to check if it has to stop. }