aboutsummaryrefslogtreecommitdiff
path: root/src/main/java
diff options
context:
space:
mode:
authorAnton Tananaev <anton@traccar.org>2022-07-13 07:18:16 -0700
committerAnton Tananaev <anton@traccar.org>2022-07-13 07:18:16 -0700
commit859b9d4aad68f4dafdee60ff14d3c9c0b32693a0 (patch)
tree99d96c5ccc1312a44ef62bc4552d1e7273065f38 /src/main/java
parenta1ec223a7ee9ff86a881428f787c6f11d532432a (diff)
downloadtrackermap-server-859b9d4aad68f4dafdee60ff14d3c9c0b32693a0.tar.gz
trackermap-server-859b9d4aad68f4dafdee60ff14d3c9c0b32693a0.tar.bz2
trackermap-server-859b9d4aad68f4dafdee60ff14d3c9c0b32693a0.zip
Ignore own multicast packets
Diffstat (limited to 'src/main/java')
-rw-r--r--src/main/java/org/traccar/broadcast/MulticastBroadcastService.java6
1 files changed, 4 insertions, 2 deletions
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);