From cf78794053bf2e6890e279c49471a936698bde1f Mon Sep 17 00:00:00 2001 From: Anton Tananaev Date: Sat, 7 Jan 2017 09:49:43 +1300 Subject: Support GT30 alarm messages --- src/org/traccar/protocol/Gt30ProtocolDecoder.java | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) (limited to 'src/org/traccar') diff --git a/src/org/traccar/protocol/Gt30ProtocolDecoder.java b/src/org/traccar/protocol/Gt30ProtocolDecoder.java index 19d964687..6c3f8c0a4 100644 --- a/src/org/traccar/protocol/Gt30ProtocolDecoder.java +++ b/src/org/traccar/protocol/Gt30ProtocolDecoder.java @@ -37,6 +37,7 @@ public class Gt30ProtocolDecoder extends BaseProtocolDecoder { .number("x{4}") // length .expression("(.{14})") // device id .number("x{4}") // type + .expression("(.)?") // alarm .number("(dd)(dd)(dd).(d+),") // time .expression("([AV]),") // validity .number("(d+)(dd.d+),") // latitude @@ -52,6 +53,23 @@ public class Gt30ProtocolDecoder extends BaseProtocolDecoder { .number("x{4}") // checksum .compile(); + private String decodeAlarm(int value) { + switch (value) { + case 0x01: + case 0x02: + case 0x03: + return Position.ALARM_SOS; + case 0x10: + return Position.ALARM_LOW_BATTERY; + case 0x11: + return Position.ALARM_OVERSPEED; + case 0x12: + return Position.ALARM_GEOFENCE; + default: + return null; + } + } + @Override protected Object decode( Channel channel, SocketAddress remoteAddress, Object msg) throws Exception { @@ -70,6 +88,10 @@ public class Gt30ProtocolDecoder extends BaseProtocolDecoder { position.setProtocol(getProtocolName()); position.setDeviceId(deviceSession.getDeviceId()); + if (parser.hasNext()) { + position.set(Position.KEY_ALARM, decodeAlarm(parser.next().charAt(0))); + } + DateBuilder dateBuilder = new DateBuilder() .setTime(parser.nextInt(), parser.nextInt(), parser.nextInt(), parser.nextInt()); -- cgit v1.2.3