mirror of
https://github.com/openhab/openhab-addons.git
synced 2025-01-10 15:11:59 +01:00
[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:
parent
d6da67435a
commit
ec93c3600e
@ -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());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user