[homekit] Simplify start level handling (#13914)

Signed-off-by: Kai Kreuzer <kai@openhab.org>
This commit is contained in:
Kai Kreuzer 2022-12-11 17:09:31 +01:00 committed by GitHub
parent 3ea004ad35
commit 260f58904f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 9 additions and 23 deletions

View File

@ -107,7 +107,8 @@ public class HomekitImpl implements Homekit, NetworkAddressChangeListener, Ready
this.metadataRegistry = metadataRegistry; this.metadataRegistry = metadataRegistry;
this.readyService = readyService; this.readyService = readyService;
networkAddressService.addNetworkAddressChangeListener(this); 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<String, Object> properties) { private HomekitSettings processConfig(Map<String, Object> properties) {
@ -152,8 +153,9 @@ public class HomekitImpl implements Homekit, NetworkAddressChangeListener, Ready
try { try {
HomekitSettings oldSettings = settings; HomekitSettings oldSettings = settings;
settings = processConfig(config); settings = processConfig(config);
if ((oldSettings == null) || (settings == null)) if ((oldSettings == null) || (settings == null)) {
return; return;
}
if (!oldSettings.name.equals(settings.name) || !oldSettings.pin.equals(settings.pin) if (!oldSettings.name.equals(settings.name) || !oldSettings.pin.equals(settings.pin)
|| !oldSettings.setupId.equals(settings.setupId) || !oldSettings.setupId.equals(settings.setupId)
|| (oldSettings.networkInterface != null || (oldSettings.networkInterface != null
@ -177,32 +179,16 @@ public class HomekitImpl implements Homekit, NetworkAddressChangeListener, Ready
@Override @Override
public synchronized void onReadyMarkerAdded(ReadyMarker readyMarker) { public synchronized void onReadyMarkerAdded(ReadyMarker readyMarker) {
int newLevel = Integer.parseInt(readyMarker.getIdentifier()); try {
currentStartLevel = newLevel; startHomekitServer();
} catch (IOException | InvalidAlgorithmParameterException e) {
if (newLevel >= StartLevelService.STARTLEVEL_STATES) { 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 @Override
@SuppressWarnings("PMD.EmptyWhileStmt")
public synchronized void onReadyMarkerRemoved(ReadyMarker readyMarker) { public synchronized void onReadyMarkerRemoved(ReadyMarker readyMarker) {
int newLevel = Integer.parseInt(readyMarker.getIdentifier()); stopHomekitServer();
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();
}
}
} }
private HomekitRoot startBridge(HomekitServer homekitServer, HomekitAuthInfoImpl authInfo, private HomekitRoot startBridge(HomekitServer homekitServer, HomekitAuthInfoImpl authInfo,