diff options
-rw-r--r-- | debug.xml | 1 | ||||
-rw-r--r-- | setup/unix/traccar.xml | 1 | ||||
-rw-r--r-- | setup/windows/traccar.xml | 1 | ||||
-rw-r--r-- | src/org/traccar/protocol/LdplProtocol.java | 31 | ||||
-rw-r--r-- | src/org/traccar/protocol/LdplProtocolDecoder.java | 107 | ||||
-rw-r--r-- | test/org/traccar/protocol/LdplProtocolDecoderTest.java | 23 |
6 files changed, 164 insertions, 0 deletions
@@ -305,5 +305,6 @@ <entry key='arknav.port'>5107</entry> <entry key='supermate.port'>5108</entry> <entry key='appello.port'>5109</entry> + <entry key='ldpl.port'>5110</entry> </properties> diff --git a/setup/unix/traccar.xml b/setup/unix/traccar.xml index 4103634ac..bcb9a79e5 100644 --- a/setup/unix/traccar.xml +++ b/setup/unix/traccar.xml @@ -297,5 +297,6 @@ <entry key='arknav.port'>5107</entry> <entry key='supermate.port'>5108</entry> <entry key='appello.port'>5109</entry> + <entry key='ldpl.port'>5110</entry> </properties> diff --git a/setup/windows/traccar.xml b/setup/windows/traccar.xml index 5748f3993..9191c5ffb 100644 --- a/setup/windows/traccar.xml +++ b/setup/windows/traccar.xml @@ -297,5 +297,6 @@ <entry key='arknav.port'>5107</entry>
<entry key='supermate.port'>5108</entry>
<entry key='appello.port'>5109</entry>
+ <entry key='ldpl.port'>5110</entry>
</properties>
diff --git a/src/org/traccar/protocol/LdplProtocol.java b/src/org/traccar/protocol/LdplProtocol.java new file mode 100644 index 000000000..200baffb2 --- /dev/null +++ b/src/org/traccar/protocol/LdplProtocol.java @@ -0,0 +1,31 @@ +package org.traccar.protocol; + +import java.util.List; + +import org.jboss.netty.bootstrap.ServerBootstrap; +import org.jboss.netty.channel.ChannelPipeline; +import org.jboss.netty.handler.codec.string.StringDecoder; +import org.jboss.netty.handler.codec.string.StringEncoder; +import org.traccar.BaseProtocol; +import org.traccar.TrackerServer; + +public class LdplProtocol extends BaseProtocol { + + public LdplProtocol() { + super("ldpl"); + } + + @Override + public void initTrackerServers(List<TrackerServer> serverList) { + serverList.add(new TrackerServer(new ServerBootstrap(), this.getName()) { + @Override + protected void addSpecificHandlers(ChannelPipeline pipeline) { +// pipeline.addLast("frameDecoder", new LineBasedFrameDecoder(1024)); + pipeline.addLast("stringEncoder", new StringEncoder()); + pipeline.addLast("stringDecoder", new StringDecoder()); + pipeline.addLast("objectDecoder", new LdplProtocolDecoder(LdplProtocol.this)); + } + }); + } + +} diff --git a/src/org/traccar/protocol/LdplProtocolDecoder.java b/src/org/traccar/protocol/LdplProtocolDecoder.java new file mode 100644 index 000000000..74b17d5b6 --- /dev/null +++ b/src/org/traccar/protocol/LdplProtocolDecoder.java @@ -0,0 +1,107 @@ +package org.traccar.protocol; + +import java.net.SocketAddress; +import java.util.regex.Pattern; + +import org.jboss.netty.channel.Channel; +import org.traccar.BaseProtocolDecoder; +import org.traccar.Protocol; +import org.traccar.helper.DateBuilder; +import org.traccar.helper.Parser; +import org.traccar.helper.Parser.CoordinateFormat; +import org.traccar.helper.PatternBuilder; +import org.traccar.model.Position; + +public class LdplProtocolDecoder extends BaseProtocolDecoder { + + public LdplProtocolDecoder(Protocol protocol) { + super(protocol); + } + + private static final Pattern PATTERN = new PatternBuilder() + .text("*ID") // start of frame + .number("(d+),") // command_code + .number("(d+),") // imei + .number("(dd)(dd)(dd),") // current_date + .number("(dd)(dd)(dd),") // current_time + .expression("([A|V]),") // gps_fix + .number("(dd)(dd).?(d+),([NS]),") // latitude + .number("(ddd)(dd).?(d+),([EW]),") // longitude + .number("(d{1,3}.dd),") // speed + .number("(d{1,3}.dd),") // course + .number("(d{1,2}),") // sats + .number("(d{1,3}),") // gsm_signal_strength + .expression("([A|N|S]),") // vehicle_status + .expression("([0|1]),") // main_power_status + .number("(d.dd),") // internal_battery_voltage + .expression("([0|1]),") // sos_alert + .expression("([0|1]),") // body_tamper + .expression("([0|1])([0|1]),") // ac_status + ign_status + .expression("([0|1|2]),") // output1_status + .number("(d{1,3}),") // adc1 + .number("(d{1,3}),") // adc2 + .expression("([0-9A-Z]{3}),") // software_version + .expression("([L|R]),") // message_type + .expression("([0-9A-Z]{4})#") // crc + .compile(); + + @Override + protected Object decode(Channel channel, SocketAddress remoteAddress, Object msg) throws Exception { + + Parser parser = new Parser(PATTERN, (String) msg); + if (!parser.matches()) { + return null; + } + + Position position = new Position(); + position.setProtocol(getProtocolName()); + position.set(Position.KEY_TYPE, parser.nextInt()); + + if (!identify(parser.next(), channel, remoteAddress)) { + return null; + } + position.setDeviceId(getDeviceId()); + + DateBuilder dateBuilder = new DateBuilder() + .setDateReverse(parser.nextInt(), parser.nextInt(), parser.nextInt()) + .setTime(parser.nextInt(), parser.nextInt(), parser.nextInt()); + position.setTime(dateBuilder.getDate()); + + if ("A".equals(parser.next())) { + position.setValid(true); + } else { + position.setValid(false); + } + + position.setLatitude(parser.nextCoordinate(CoordinateFormat.DEG_MIN_MIN_HEM)); + position.setLongitude(parser.nextCoordinate(CoordinateFormat.DEG_MIN_MIN_HEM)); + + position.setSpeed(parser.nextDouble()); + position.setCourse(parser.nextDouble()); + + position.set(Position.KEY_SATELLITES, parser.nextInt()); + position.set(Position.KEY_GSM, parser.nextInt()); + String vehicleStatus = parser.next(); + position.set(Position.KEY_POWER, parser.nextInt()); + position.set(Position.KEY_BATTERY, parser.nextDouble()); + position.set(Position.KEY_ALARM, parser.nextInt()); + Integer bodyTamper = parser.nextInt(); + Integer acStatus = parser.nextInt(); + position.set(Position.KEY_IGNITION, parser.nextInt()); + position.set(Position.KEY_OUTPUT, parser.nextInt()); + position.set(Position.PREFIX_ADC + 1, parser.nextInt()); + position.set(Position.PREFIX_ADC + 2, parser.nextInt()); + position.set(Position.KEY_VERSION, parser.next()); + + if ("R".equals(parser.next())) { + position.set(Position.KEY_ARCHIVE, true); + } else { + position.set(Position.KEY_ARCHIVE, false); + } + + String checksum = parser.next(); + + return position; + } + +} diff --git a/test/org/traccar/protocol/LdplProtocolDecoderTest.java b/test/org/traccar/protocol/LdplProtocolDecoderTest.java new file mode 100644 index 000000000..0900d8c42 --- /dev/null +++ b/test/org/traccar/protocol/LdplProtocolDecoderTest.java @@ -0,0 +1,23 @@ +package org.traccar.protocol; + +import org.junit.Test; +import org.traccar.ProtocolTest; + +public class LdplProtocolDecoderTest extends ProtocolTest { + + @Test + public void testDecode() throws Exception { + + LdplProtocolDecoder decoder = new LdplProtocolDecoder(new LdplProtocol()); + + verifyPosition(decoder, text( + "*ID1,863071011086474,210314,153218,A,1831.4577,N,07351.1433,E,0.79,240.64,9,20,A,1,4.20,0,1,01,1,0,0,A01,R,935D#"), + position("2014-03-21 15:32:18.000", true, 18.524295, 73.852388333333)); + + verifyPosition(decoder, text( + "*ID1,863071011086474,210314,162752,A,1831.4412,N,07351.0983,E,0.04,213.84,9,25,A,1,4.20,0,1,01,1,0,0,A01,L,EA01#")); + + + } + +} |