aboutsummaryrefslogtreecommitdiff
path: root/src/org/traccar/protocol/TotemFrameDecoder.java
diff options
context:
space:
mode:
authorAnton Tananaev <anton.tananaev@gmail.com>2015-07-29 11:29:39 +1200
committerAnton Tananaev <anton.tananaev@gmail.com>2015-07-29 11:29:39 +1200
commit41f88170ba9c47a20a0dda9cb42a2fa151c57ade (patch)
tree60e398c2ed865243b34c922fbb81acb559455a01 /src/org/traccar/protocol/TotemFrameDecoder.java
parent0de1d3e5ba4527bdef27b4e90f528300f5197c3e (diff)
parent44e0e42989bfba7159625b10a9b0e5023f6f6420 (diff)
downloadtrackermap-server-41f88170ba9c47a20a0dda9cb42a2fa151c57ade.tar.gz
trackermap-server-41f88170ba9c47a20a0dda9cb42a2fa151c57ade.tar.bz2
trackermap-server-41f88170ba9c47a20a0dda9cb42a2fa151c57ade.zip
Merge pull request #1317 from al3x1s/master
Implement Totem commands support
Diffstat (limited to 'src/org/traccar/protocol/TotemFrameDecoder.java')
-rw-r--r--src/org/traccar/protocol/TotemFrameDecoder.java18
1 files changed, 11 insertions, 7 deletions
diff --git a/src/org/traccar/protocol/TotemFrameDecoder.java b/src/org/traccar/protocol/TotemFrameDecoder.java
index 5ac3064e6..6f7c3a37c 100644
--- a/src/org/traccar/protocol/TotemFrameDecoder.java
+++ b/src/org/traccar/protocol/TotemFrameDecoder.java
@@ -19,7 +19,7 @@ import java.nio.charset.Charset;
import org.jboss.netty.buffer.ChannelBuffer;
import org.jboss.netty.channel.Channel;
import org.jboss.netty.channel.ChannelHandlerContext;
-import org.jboss.netty.handler.codec.frame.FrameDecoder;
+import org.jboss.netty.handler.codec.frame.FrameDecoder;
public class TotemFrameDecoder extends FrameDecoder {
@@ -38,13 +38,17 @@ public class TotemFrameDecoder extends FrameDecoder {
if (buf.getUnsignedShort(buf.readerIndex()) == 0x0d0a) {
buf.skipBytes(2);
}
-
- // Read message
- int length = Integer.parseInt(buf.toString(buf.readerIndex() + 2, 2, Charset.defaultCharset()), 16);
- if (length <= buf.readableBytes()) {
- return buf.readBytes(length);
+
+ if(buf.toString(buf.readerIndex(), 2, Charset.defaultCharset()).equals("$$")){
+ int length = Integer.parseInt(buf.toString(buf.readerIndex() + 2, 2, Charset.defaultCharset()), 16);
+ if (length <= buf.readableBytes()) {
+ return buf.readBytes(length);
+ }
+ }else{
+ //TODO: notify to user the GPS response
+ return buf.readBytes(buf.readableBytes());
}
-
+
return null;
}