aboutsummaryrefslogtreecommitdiff
path: root/src/org/traccar/BaseEventHandler.java
diff options
context:
space:
mode:
authorAnton Tananaev <anton.tananaev@gmail.com>2016-06-01 15:28:54 +1200
committerAnton Tananaev <anton.tananaev@gmail.com>2016-06-01 15:28:54 +1200
commit3db183a5535a986b015566c6df929da8c6ca9630 (patch)
tree3183f44e2b9b8ccfa2c460221b1d04fa74f0e9e9 /src/org/traccar/BaseEventHandler.java
parentcce427a783cbe0c2eca6a278d7327294002847e5 (diff)
parent41c46575a92f746622c61b07004b7a0832712a54 (diff)
downloadtrackermap-server-3db183a5535a986b015566c6df929da8c6ca9630.tar.gz
trackermap-server-3db183a5535a986b015566c6df929da8c6ca9630.tar.bz2
trackermap-server-3db183a5535a986b015566c6df929da8c6ca9630.zip
Merge pull request #1981 from Abyss777/master
Implement events subsystem
Diffstat (limited to 'src/org/traccar/BaseEventHandler.java')
-rw-r--r--src/org/traccar/BaseEventHandler.java35
1 files changed, 35 insertions, 0 deletions
diff --git a/src/org/traccar/BaseEventHandler.java b/src/org/traccar/BaseEventHandler.java
new file mode 100644
index 000000000..fde57748c
--- /dev/null
+++ b/src/org/traccar/BaseEventHandler.java
@@ -0,0 +1,35 @@
+package org.traccar;
+
+import org.traccar.model.Device;
+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) {
+
+ Device device = Context.getDataManager().getDeviceById(position.getDeviceId());
+ if (device != null) {
+ long lastPositionId = device.getPositionId();
+ if (position.getId() == lastPositionId) {
+ isLastPosition = true;
+ }
+ }
+
+ Event event = analizePosition(position);
+ if (event != null) {
+ Context.getConnectionManager().updateEvent(event);
+ }
+ return position;
+ }
+
+ protected abstract Event analizePosition(Position position);
+
+}