[homekit] quick restart on network changes (#12072)

* quick restart on network changes

* only restart if needed
* add null check

Signed-off-by: Eugen Freiter <freiter@gmx.de>
This commit is contained in:
eugen 2022-01-26 20:19:03 +01:00 committed by GitHub
parent d6da67435a
commit ec93c3600e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -14,6 +14,7 @@ package org.openhab.io.homekit.internal;
import java.io.IOException; import java.io.IOException;
import java.net.InetAddress; import java.net.InetAddress;
import java.net.UnknownHostException;
import java.security.InvalidAlgorithmParameterException; import java.security.InvalidAlgorithmParameterException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Dictionary; import java.util.Dictionary;
@ -116,10 +117,7 @@ public class HomekitImpl implements Homekit, NetworkAddressChangeListener {
if (props == null) { // if null, the configuration is new if (props == null) { // if null, the configuration is new
props = new Hashtable<>(); props = new Hashtable<>();
} }
if (settings.networkInterface == null) {
settings.networkInterface = networkAddressService.getPrimaryIpv4HostAddress();
props.put("networkInterface", settings.networkInterface);
}
if (settings.setupId == null) { // generate setupId very first time if (settings.setupId == null) { // generate setupId very first time
settings.setupId = HAPSetupCodeUtils.generateSetupId(); settings.setupId = HAPSetupCodeUtils.generateSetupId();
props.put("setupId", settings.setupId); props.put("setupId", settings.setupId);
@ -210,13 +208,12 @@ public class HomekitImpl implements Homekit, NetworkAddressChangeListener {
private void startHomekitServer() throws IOException { private void startHomekitServer() throws IOException {
logger.trace("start HomeKit bridge"); logger.trace("start HomeKit bridge");
if (homekitServer == null) { if (homekitServer == null) {
if (settings.useOHmDNS) { try {
if ((settings.networkInterface == null) || (settings.networkInterface.isEmpty())) { networkInterface = InetAddress
logger.trace( .getByName(((settings.networkInterface != null) && (!settings.networkInterface.isEmpty()))
"no IP address configured in HomeKit settings. HomeKit will use the first configured address of openHAB"); ? settings.networkInterface
homekitServer = new HomekitServer(mdnsClient.getClientInstances().iterator().next(), settings.port); : networkAddressService.getPrimaryIpv4HostAddress());
} else { if (settings.useOHmDNS) {
networkInterface = InetAddress.getByName(settings.networkInterface);
for (JmDNS mdns : mdnsClient.getClientInstances()) { for (JmDNS mdns : mdnsClient.getClientInstances()) {
if (mdns.getInetAddress().equals(networkInterface)) { if (mdns.getInetAddress().equals(networkInterface)) {
logger.trace("suitable mDNS client for IP {} found and will be used for HomeKit", logger.trace("suitable mDNS client for IP {} found and will be used for HomeKit",
@ -225,15 +222,18 @@ public class HomekitImpl implements Homekit, NetworkAddressChangeListener {
} }
} }
} }
} if (homekitServer == null) {
if (homekitServer == null) { if (settings.useOHmDNS) {
if (settings.useOHmDNS) { logger.trace("no suitable mDNS server for IP {} found", networkInterface);
logger.trace("no suitable mDNS server for IP {} found", networkInterface); }
logger.trace("create HomeKit server with dedicated mDNS server");
homekitServer = new HomekitServer(networkInterface, settings.port);
} }
logger.trace("create HomeKit server with dedicated mDNS server"); startBridge();
homekitServer = new HomekitServer(networkInterface, settings.port); } catch (UnknownHostException e) {
logger.warn("cannot resolve the Pv4 address / hostname {}.",
networkAddressService.getPrimaryIpv4HostAddress());
} }
startBridge();
} else { } else {
logger.warn("trying to start HomeKit server but it is already initialized"); logger.warn("trying to start HomeKit server but it is already initialized");
} }
@ -291,13 +291,30 @@ public class HomekitImpl implements Homekit, NetworkAddressChangeListener {
} }
@Override @Override
public void onChanged(final List<CidrAddress> list, final List<CidrAddress> list1) { public void onChanged(final List<CidrAddress> added, final List<CidrAddress> removed) {
logger.trace("restarting homekit bridge on network interface changes."); logger.trace("restarting HomeKit bridge on network interface changes.");
stopHomekitServer(); removed.forEach(i -> {
try { logger.trace("removed interface {}", i.getAddress().toString());
startHomekitServer(); if (i.getAddress().equals(networkInterface)) {
} catch (IOException e) { final @Nullable HomekitRoot bridge = this.bridge;
logger.warn("could not initialize HomeKit bridge: {}", e.getMessage()); if (this.bridge != null) {
bridge.stop();
this.bridge = null;
}
final @Nullable HomekitServer homekitServer = this.homekitServer;
if (homekitServer != null) {
homekitServer.stop();
this.homekitServer = null;
}
logger.trace("bridge stopped");
}
});
if ((this.bridge == null) && (!added.isEmpty())) {
try {
startHomekitServer();
} catch (IOException e) {
logger.warn("could not initialize HomeKit bridge: {}", e.getMessage());
}
} }
} }
} }