From 260f58904fbfa7f20b2766b77393496196d9bcd3 Mon Sep 17 00:00:00 2001 From: Kai Kreuzer Date: Sun, 11 Dec 2022 17:09:31 +0100 Subject: [PATCH] [homekit] Simplify start level handling (#13914) Signed-off-by: Kai Kreuzer --- .../io/homekit/internal/HomekitImpl.java | 32 ++++++------------- 1 file changed, 9 insertions(+), 23 deletions(-) diff --git a/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitImpl.java b/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitImpl.java index 468c1c9b9..7e4da4a9a 100644 --- a/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitImpl.java +++ b/bundles/org.openhab.io.homekit/src/main/java/org/openhab/io/homekit/internal/HomekitImpl.java @@ -107,7 +107,8 @@ public class HomekitImpl implements Homekit, NetworkAddressChangeListener, Ready this.metadataRegistry = metadataRegistry; this.readyService = readyService; networkAddressService.addNetworkAddressChangeListener(this); - readyService.registerTracker(this, new ReadyMarkerFilter().withType(StartLevelService.STARTLEVEL_MARKER_TYPE)); + readyService.registerTracker(this, new ReadyMarkerFilter().withType(StartLevelService.STARTLEVEL_MARKER_TYPE) + .withIdentifier(Integer.toString(StartLevelService.STARTLEVEL_STATES))); } private HomekitSettings processConfig(Map properties) { @@ -152,8 +153,9 @@ public class HomekitImpl implements Homekit, NetworkAddressChangeListener, Ready try { HomekitSettings oldSettings = settings; settings = processConfig(config); - if ((oldSettings == null) || (settings == null)) + if ((oldSettings == null) || (settings == null)) { return; + } if (!oldSettings.name.equals(settings.name) || !oldSettings.pin.equals(settings.pin) || !oldSettings.setupId.equals(settings.setupId) || (oldSettings.networkInterface != null @@ -177,32 +179,16 @@ public class HomekitImpl implements Homekit, NetworkAddressChangeListener, Ready @Override public synchronized void onReadyMarkerAdded(ReadyMarker readyMarker) { - int newLevel = Integer.parseInt(readyMarker.getIdentifier()); - currentStartLevel = newLevel; - - if (newLevel >= StartLevelService.STARTLEVEL_STATES) { - try { - startHomekitServer(); - } catch (IOException | InvalidAlgorithmParameterException e) { - logger.warn("could not initialize HomeKit bridge: {}", e.getMessage()); - } + try { + startHomekitServer(); + } catch (IOException | InvalidAlgorithmParameterException e) { + logger.warn("could not initialize HomeKit bridge: {}", e.getMessage()); } } @Override - @SuppressWarnings("PMD.EmptyWhileStmt") public synchronized void onReadyMarkerRemoved(ReadyMarker readyMarker) { - int newLevel = Integer.parseInt(readyMarker.getIdentifier()); - - if (currentStartLevel > newLevel) { - while (newLevel-- > 0 && !readyService - .isReady(new ReadyMarker(StartLevelService.STARTLEVEL_MARKER_TYPE, Integer.toString(newLevel)))) { - } - currentStartLevel = newLevel; - if (currentStartLevel < StartLevelService.STARTLEVEL_STATES) { - stopHomekitServer(); - } - } + stopHomekitServer(); } private HomekitRoot startBridge(HomekitServer homekitServer, HomekitAuthInfoImpl authInfo,