[pilight] Fix background discovery in case of multiple network interfaces (#15791)
If there were multiple network interfaces and the DatagramSocket.receive timed out an exception was thrown and the remaining network interfaces were not considered anymore. Signed-off-by: Stefan Roellin <stefan@roellin-baumann.ch>
This commit is contained in:
parent
532476a9c6
commit
b503382e93
@ -20,6 +20,7 @@ import java.net.Inet4Address;
|
||||
import java.net.InetAddress;
|
||||
import java.net.InetSocketAddress;
|
||||
import java.net.NetworkInterface;
|
||||
import java.net.SocketException;
|
||||
import java.nio.charset.StandardCharsets;
|
||||
import java.util.Collections;
|
||||
import java.util.Enumeration;
|
||||
@ -55,7 +56,7 @@ import org.slf4j.LoggerFactory;
|
||||
public class PilightBridgeDiscoveryService extends AbstractDiscoveryService {
|
||||
|
||||
private static final int AUTODISCOVERY_SEARCH_TIME_SEC = 5;
|
||||
private static final int AUTODISCOVERY_BACKGROUND_SEARCH_INTERVAL_SEC = 60 * 10;
|
||||
private static final int AUTODISCOVERY_BACKGROUND_SEARCH_INTERVAL_SEC = 10 * 60; // 10 minutes
|
||||
|
||||
private static final String SSDP_DISCOVERY_REQUEST_MESSAGE = """
|
||||
M-SEARCH * HTTP/1.1
|
||||
@ -65,6 +66,7 @@ public class PilightBridgeDiscoveryService extends AbstractDiscoveryService {
|
||||
MX:3
|
||||
|
||||
""";
|
||||
|
||||
public static final String SSDP_MULTICAST_ADDRESS = "239.255.255.250";
|
||||
public static final int SSDP_PORT = 1900;
|
||||
public static final int SSDP_WAIT_TIMEOUT = 2000; // in milliseconds
|
||||
@ -91,6 +93,7 @@ public class PilightBridgeDiscoveryService extends AbstractDiscoveryService {
|
||||
Enumeration<InetAddress> inetAddresses = nic.getInetAddresses();
|
||||
for (InetAddress inetAddress : Collections.list(inetAddresses)) {
|
||||
if (!inetAddress.isLoopbackAddress() && inetAddress instanceof Inet4Address) {
|
||||
try {
|
||||
DatagramSocket ssdp = new DatagramSocket(
|
||||
new InetSocketAddress(inetAddress.getHostAddress(), 0));
|
||||
byte[] buff = SSDP_DISCOVERY_REQUEST_MESSAGE.getBytes(StandardCharsets.UTF_8);
|
||||
@ -122,22 +125,24 @@ public class PilightBridgeDiscoveryService extends AbstractDiscoveryService {
|
||||
|
||||
ThingUID uid = new ThingUID(PilightBindingConstants.THING_TYPE_BRIDGE, bridgeName);
|
||||
|
||||
DiscoveryResult result = DiscoveryResultBuilder.create(uid).withProperties(properties)
|
||||
DiscoveryResult result = DiscoveryResultBuilder.create(uid)
|
||||
.withProperties(properties)
|
||||
.withRepresentationProperty(PilightBindingConstants.PROPERTY_NAME)
|
||||
.withLabel("Pilight Bridge (" + server + ")").build();
|
||||
|
||||
thingDiscovered(result);
|
||||
}).count() == 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
} catch (IOException e) {
|
||||
if (e.getMessage() != null && !"Receive timed out".equals(e.getMessage())) {
|
||||
logger.warn("Unable to enumerate the local network interfaces {}", e.getMessage());
|
||||
// nothing to do
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
} catch (SocketException e) {
|
||||
logger.warn("Unable to enumerate the local network interfaces", e);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected synchronized void stopScan() {
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user