diff options
author | Abyss777 <abyss@fox5.ru> | 2016-05-26 16:14:52 +0500 |
---|---|---|
committer | Abyss777 <abyss@fox5.ru> | 2016-05-26 16:14:52 +0500 |
commit | c6cc8a87eb593dbf765814d1aaa09d5d231fa7fe (patch) | |
tree | 8b0cddcc79476a3252c8aec0946bd6e8e016b475 /src/org/traccar/BaseEventHandler.java | |
parent | aa12e5c750e771016545269ffa39409b06b47eee (diff) | |
download | trackermap-server-c6cc8a87eb593dbf765814d1aaa09d5d231fa7fe.tar.gz trackermap-server-c6cc8a87eb593dbf765814d1aaa09d5d231fa7fe.tar.bz2 trackermap-server-c6cc8a87eb593dbf765814d1aaa09d5d231fa7fe.zip |
Events subsystem
Diffstat (limited to 'src/org/traccar/BaseEventHandler.java')
-rw-r--r-- | src/org/traccar/BaseEventHandler.java | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/src/org/traccar/BaseEventHandler.java b/src/org/traccar/BaseEventHandler.java new file mode 100644 index 000000000..3c2016af0 --- /dev/null +++ b/src/org/traccar/BaseEventHandler.java @@ -0,0 +1,31 @@ +package org.traccar; + +import org.traccar.model.Event; +import org.traccar.model.Position; + +public abstract class BaseEventHandler extends BaseDataHandler { + + private boolean isLastPosition = false; + + public boolean isLastPosition() { + return isLastPosition; + } + + @Override + protected Position handlePosition(Position position) { + + Position lastPosition = Context.getConnectionManager().getLastPosition(position.getDeviceId()); + if (lastPosition == null || position.getFixTime().compareTo(lastPosition.getFixTime()) >= 0) { + isLastPosition = true; + } + + Event event = analizePosition(position); + if (event != null) { + Context.getConnectionManager().updateEvent(event); + } + return position; + } + + protected abstract Event analizePosition(Position position); + +} |