diff options
author | Anton Tananaev <anton@traccar.org> | 2022-07-13 07:18:16 -0700 |
---|---|---|
committer | Anton Tananaev <anton@traccar.org> | 2022-07-13 07:18:16 -0700 |
commit | 859b9d4aad68f4dafdee60ff14d3c9c0b32693a0 (patch) | |
tree | 99d96c5ccc1312a44ef62bc4552d1e7273065f38 /src/main | |
parent | a1ec223a7ee9ff86a881428f787c6f11d532432a (diff) | |
download | trackermap-server-859b9d4aad68f4dafdee60ff14d3c9c0b32693a0.tar.gz trackermap-server-859b9d4aad68f4dafdee60ff14d3c9c0b32693a0.tar.bz2 trackermap-server-859b9d4aad68f4dafdee60ff14d3c9c0b32693a0.zip |
Ignore own multicast packets
Diffstat (limited to 'src/main')
-rw-r--r-- | src/main/java/org/traccar/broadcast/MulticastBroadcastService.java | 6 |
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); |