diff options
author | Anton Tananaev <anton@traccar.org> | 2022-07-26 17:29:14 -0700 |
---|---|---|
committer | Anton Tananaev <anton@traccar.org> | 2022-07-26 17:29:14 -0700 |
commit | c5f793815a6429d77c429f49c876f52062051f03 (patch) | |
tree | 1cf42fff6dc107ecaeff08bdb0d91b69ccad9b04 | |
parent | 535eb8d11fccfa7ba4bfcbe9e3d8a0bc9be8f247 (diff) | |
download | trackermap-server-c5f793815a6429d77c429f49c876f52062051f03.tar.gz trackermap-server-c5f793815a6429d77c429f49c876f52062051f03.tar.bz2 trackermap-server-c5f793815a6429d77c429f49c876f52062051f03.zip |
Handle connectionless protocols
-rw-r--r-- | src/main/java/org/traccar/MainEventHandler.java | 7 | ||||
-rw-r--r-- | src/main/java/org/traccar/session/ConnectionManager.java | 6 |
2 files changed, 7 insertions, 6 deletions
diff --git a/src/main/java/org/traccar/MainEventHandler.java b/src/main/java/org/traccar/MainEventHandler.java index 981888577..52eb43faf 100644 --- a/src/main/java/org/traccar/MainEventHandler.java +++ b/src/main/java/org/traccar/MainEventHandler.java @@ -159,10 +159,9 @@ public class MainEventHandler extends ChannelInboundHandlerAdapter { LOGGER.info("[{}] disconnected", NetworkUtil.session(ctx.channel())); closeChannel(ctx.channel()); - if (BasePipelineFactory.getHandler(ctx.pipeline(), HttpRequestDecoder.class) == null - && !connectionlessProtocols.contains(ctx.pipeline().get(BaseProtocolDecoder.class).getProtocolName())) { - connectionManager.deviceDisconnected(ctx.channel()); - } + boolean supportsOffline = BasePipelineFactory.getHandler(ctx.pipeline(), HttpRequestDecoder.class) == null + && !connectionlessProtocols.contains(ctx.pipeline().get(BaseProtocolDecoder.class).getProtocolName()); + connectionManager.deviceDisconnected(ctx.channel(), supportsOffline); } @Override diff --git a/src/main/java/org/traccar/session/ConnectionManager.java b/src/main/java/org/traccar/session/ConnectionManager.java index 2d183ee22..262a302af 100644 --- a/src/main/java/org/traccar/session/ConnectionManager.java +++ b/src/main/java/org/traccar/session/ConnectionManager.java @@ -189,12 +189,14 @@ public class ConnectionManager implements BroadcastInterface { } } - public void deviceDisconnected(Channel channel) { + public void deviceDisconnected(Channel channel, boolean supportsOffline) { Endpoint endpoint = new Endpoint(channel, channel.remoteAddress()); Map<String, DeviceSession> endpointSessions = sessionsByEndpoint.remove(endpoint); if (endpointSessions != null) { for (DeviceSession deviceSession : endpointSessions.values()) { - updateDevice(deviceSession.getDeviceId(), Device.STATUS_OFFLINE, null); + if (supportsOffline) { + updateDevice(deviceSession.getDeviceId(), Device.STATUS_OFFLINE, null); + } sessionsByDeviceId.remove(deviceSession.getDeviceId()); cacheManager.removeDevice(deviceSession.getDeviceId()); } |