aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/org/traccar/handler/events/IgnitionEventHandler.java
diff options
context:
space:
mode:
authorIván Ávalos <avalos@disroot.org>2024-04-10 15:29:47 -0600
committerIván Ávalos <avalos@disroot.org>2024-04-10 15:29:47 -0600
commite8456ae8ec5960b2119b7cdbcffac6d9ff004c95 (patch)
treeed5dfe5ff3b9e3491adf15b2abe83e13e2ccb6c0 /src/main/java/org/traccar/handler/events/IgnitionEventHandler.java
parent4dec2ef603f078ff3bd18d63d1fbd992537cbb88 (diff)
parent9a285e59e580994dc9c3f80935f766f3dafdcd46 (diff)
downloadtrackermap-server-e8456ae8ec5960b2119b7cdbcffac6d9ff004c95.tar.gz
trackermap-server-e8456ae8ec5960b2119b7cdbcffac6d9ff004c95.tar.bz2
trackermap-server-e8456ae8ec5960b2119b7cdbcffac6d9ff004c95.zip
Merge tag 'v6.0'
Diffstat (limited to 'src/main/java/org/traccar/handler/events/IgnitionEventHandler.java')
-rw-r--r--src/main/java/org/traccar/handler/events/IgnitionEventHandler.java25
1 files changed, 6 insertions, 19 deletions
diff --git a/src/main/java/org/traccar/handler/events/IgnitionEventHandler.java b/src/main/java/org/traccar/handler/events/IgnitionEventHandler.java
index ba4159a42..bbf9fadd1 100644
--- a/src/main/java/org/traccar/handler/events/IgnitionEventHandler.java
+++ b/src/main/java/org/traccar/handler/events/IgnitionEventHandler.java
@@ -1,5 +1,5 @@
/*
- * Copyright 2016 - 2022 Anton Tananaev (anton@traccar.org)
+ * Copyright 2016 - 2024 Anton Tananaev (anton@traccar.org)
* Copyright 2016 Andrey Kunitsyn (andrey@traccar.org)
*
* Licensed under the Apache License, Version 2.0 (the "License");
@@ -16,21 +16,13 @@
*/
package org.traccar.handler.events;
-import java.util.Collections;
-import java.util.Map;
-
-import io.netty.channel.ChannelHandler;
+import jakarta.inject.Inject;
import org.traccar.helper.model.PositionUtil;
import org.traccar.model.Device;
import org.traccar.model.Event;
import org.traccar.model.Position;
import org.traccar.session.cache.CacheManager;
-import jakarta.inject.Inject;
-import jakarta.inject.Singleton;
-
-@Singleton
-@ChannelHandler.Sharable
public class IgnitionEventHandler extends BaseEventHandler {
private final CacheManager cacheManager;
@@ -41,14 +33,12 @@ public class IgnitionEventHandler extends BaseEventHandler {
}
@Override
- protected Map<Event, Position> analyzePosition(Position position) {
+ public void analyzePosition(Position position, Callback callback) {
Device device = cacheManager.getObject(Device.class, position.getDeviceId());
if (device == null || !PositionUtil.isLatest(cacheManager, position)) {
- return null;
+ return;
}
- Map<Event, Position> result = null;
-
if (position.hasAttribute(Position.KEY_IGNITION)) {
boolean ignition = position.getBoolean(Position.KEY_IGNITION);
@@ -57,15 +47,12 @@ public class IgnitionEventHandler extends BaseEventHandler {
boolean oldIgnition = lastPosition.getBoolean(Position.KEY_IGNITION);
if (ignition && !oldIgnition) {
- result = Collections.singletonMap(
- new Event(Event.TYPE_IGNITION_ON, position), position);
+ callback.eventDetected(new Event(Event.TYPE_IGNITION_ON, position));
} else if (!ignition && oldIgnition) {
- result = Collections.singletonMap(
- new Event(Event.TYPE_IGNITION_OFF, position), position);
+ callback.eventDetected(new Event(Event.TYPE_IGNITION_OFF, position));
}
}
}
- return result;
}
}