aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--debug.xml5
-rw-r--r--src/main/java/org/traccar/broadcast/MulticastBroadcastService.java6
2 files changed, 7 insertions, 4 deletions
diff --git a/debug.xml b/debug.xml
index debbd06b7..a597d83c5 100644
--- a/debug.xml
+++ b/debug.xml
@@ -24,7 +24,8 @@
<entry key='atrack.custom'>true</entry>
<entry key='intellitrac.port'>6037</entry>
- <!--<entry key='broadcast.address'>230.0.0.0</entry>
- <entry key='broadcast.port'>5000</entry>-->
+ <!--<entry key='broadcast.interface'>en0</entry>
+ <entry key='broadcast.address'>230.3.3.3</entry>
+ <entry key='broadcast.port'>7001</entry>-->
</properties>
diff --git a/src/main/java/org/traccar/broadcast/MulticastBroadcastService.java b/src/main/java/org/traccar/broadcast/MulticastBroadcastService.java
index c4ba0e059..be24989dd 100644
--- a/src/main/java/org/traccar/broadcast/MulticastBroadcastService.java
+++ b/src/main/java/org/traccar/broadcast/MulticastBroadcastService.java
@@ -167,8 +167,10 @@ public class MulticastBroadcastService implements BroadcastService {
while (!service.isShutdown()) {
DatagramPacket packet = new DatagramPacket(receiverBuffer, receiverBuffer.length);
socket.receive(packet);
- String data = new String(packet.getData(), 0, packet.getLength(), StandardCharsets.UTF_8);
- handleMessage(objectMapper.readValue(data, BroadcastMessage.class));
+ if (networkInterface.inetAddresses().noneMatch(a -> a.equals(packet.getAddress()))) {
+ String data = new String(packet.getData(), 0, packet.getLength(), StandardCharsets.UTF_8);
+ handleMessage(objectMapper.readValue(data, BroadcastMessage.class));
+ }
}
publisherSocket = null;
socket.leaveGroup(group, networkInterface);