aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnton Tananaev <anton.tananaev@gmail.com>2012-11-04 21:24:17 +1300
committerAnton Tananaev <anton.tananaev@gmail.com>2012-11-04 21:24:17 +1300
commit8b4dc809a91bcd124ae087988aa79ceaeff1fd36 (patch)
treef9b5865598e04d64fa327370c74af5ddba473fcf
parent2808fe5c99d50b3d9414020373c28bc6f04b937a (diff)
downloadtraccar-server-8b4dc809a91bcd124ae087988aa79ceaeff1fd36.tar.gz
traccar-server-8b4dc809a91bcd124ae087988aa79ceaeff1fd36.tar.bz2
traccar-server-8b4dc809a91bcd124ae087988aa79ceaeff1fd36.zip
Release 1.4
-rw-r--r--opengts.cfg24
-rw-r--r--pom.xml2
-rw-r--r--setup/linux/linux.cfg4
-rw-r--r--setup/universal/README.txt11
-rwxr-xr-xsetup/universal/traccar.sh5
-rw-r--r--setup/windows/traccar.iss2
-rw-r--r--setup/windows/windows.cfg4
-rw-r--r--src/org/traccar/protocol/Pt502ProtocolDecoder.java130
8 files changed, 180 insertions, 2 deletions
diff --git a/opengts.cfg b/opengts.cfg
index 6ab52c6d8..583add525 100644
--- a/opengts.cfg
+++ b/opengts.cfg
@@ -98,4 +98,28 @@
<entry key="st210.enable">true</entry>
<entry key="st210.port">5011</entry>
+ <!-- Progress server configuration -->
+ <entry key="progress.enable">true</entry>
+ <entry key="progress.port">5012</entry>
+
+ <!-- H02 server configuration -->
+ <entry key="h02.enable">true</entry>
+ <entry key="h02.port">5013</entry>
+
+ <!-- JT600 server configuration -->
+ <entry key="jt600.enable">true</entry>
+ <entry key="jt600.port">5014</entry>
+
+ <!-- EV603 server configuration -->
+ <entry key="ev603.enable">true</entry>
+ <entry key="ev603.port">5015</entry>
+
+ <!-- V680 server configuration -->
+ <entry key="v680.enable">true</entry>
+ <entry key="v680.port">5016</entry>
+
+ <!-- PT502 server configuration -->
+ <entry key="pt502.enable">true</entry>
+ <entry key="pt502.port">5017</entry>
+
</properties>
diff --git a/pom.xml b/pom.xml
index 8ff018fdf..21966b261 100644
--- a/pom.xml
+++ b/pom.xml
@@ -3,7 +3,7 @@
<modelVersion>4.0.0</modelVersion>
<groupId>org.traccar</groupId>
<artifactId>traccar</artifactId>
- <version>1.3-SNAPSHOT</version>
+ <version>1.4-SNAPSHOT</version>
<name>traccar</name>
<url>http://www.traccar.org</url>
diff --git a/setup/linux/linux.cfg b/setup/linux/linux.cfg
index 4c7ac58bb..d0f11199a 100644
--- a/setup/linux/linux.cfg
+++ b/setup/linux/linux.cfg
@@ -155,5 +155,9 @@
<!-- V680 server configuration -->
<entry key="v680.enable">true</entry>
<entry key="v680.port">5016</entry>
+
+ <!-- PT502 server configuration -->
+ <entry key="pt502.enable">true</entry>
+ <entry key="pt502.port">5017</entry>
</properties>
diff --git a/setup/universal/README.txt b/setup/universal/README.txt
new file mode 100644
index 000000000..e741319e8
--- /dev/null
+++ b/setup/universal/README.txt
@@ -0,0 +1,11 @@
+Web page - http://www.traccar.org
+
+This package contains only main Java application (tracker-server.jar).
+
+1) To start application you need libraries to lib folder (check manifest file)
+
+2) Create configuration file (more information on web page)
+
+3) To start application run following command:
+
+java -jar tracker-server.jar "configuration.xml"
diff --git a/setup/universal/traccar.sh b/setup/universal/traccar.sh
new file mode 100755
index 000000000..26a3078fa
--- /dev/null
+++ b/setup/universal/traccar.sh
@@ -0,0 +1,5 @@
+#!/bin/sh
+
+cp ../../target/tracker-server.jar ./
+zip tracker-server.zip tracker-server.jar README.txt
+rm tracker-server.jar
diff --git a/setup/windows/traccar.iss b/setup/windows/traccar.iss
index ddfdbc40e..54c93367c 100644
--- a/setup/windows/traccar.iss
+++ b/setup/windows/traccar.iss
@@ -1,6 +1,6 @@
[Setup]
AppName=Traccar
-AppVersion=1.3
+AppVersion=1.4
DefaultDirName={pf}\Traccar
AlwaysRestart=yes
diff --git a/setup/windows/windows.cfg b/setup/windows/windows.cfg
index fbe008aeb..6e3a1a12f 100644
--- a/setup/windows/windows.cfg
+++ b/setup/windows/windows.cfg
@@ -155,5 +155,9 @@
<!-- V680 server configuration -->
<entry key="v680.enable">true</entry>
<entry key="v680.port">5016</entry>
+
+ <!-- PT502 server configuration -->
+ <entry key="pt502.enable">true</entry>
+ <entry key="pt502.port">5017</entry>
</properties>
diff --git a/src/org/traccar/protocol/Pt502ProtocolDecoder.java b/src/org/traccar/protocol/Pt502ProtocolDecoder.java
new file mode 100644
index 000000000..a010f936f
--- /dev/null
+++ b/src/org/traccar/protocol/Pt502ProtocolDecoder.java
@@ -0,0 +1,130 @@
+/*
+ * Copyright 2012 Anton Tananaev (anton.tananaev@gmail.com)
+ * Luis Parada (luis.parada@gmail.com)
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package org.traccar.protocol;
+
+import java.util.Calendar;
+import java.util.TimeZone;
+import java.util.regex.Matcher;
+import java.util.regex.Pattern;
+import org.jboss.netty.channel.Channel;
+import org.jboss.netty.channel.ChannelHandlerContext;
+import org.traccar.GenericProtocolDecoder;
+import org.traccar.helper.Log;
+import org.traccar.model.DataManager;
+import org.traccar.model.Position;
+
+/**
+ * PT502 tracker protocol decoder
+ */
+public class Pt502ProtocolDecoder extends GenericProtocolDecoder {
+
+ /**
+ * Initialize
+ */
+ public Pt502ProtocolDecoder(DataManager dataManager) {
+ super(dataManager);
+ }
+ /**
+ * Regular expressions pattern
+ */
+ //$POS,6094,205523.000,A,1013.6223,N,06728.4248,W,0.0,99.3,011112,,,A/00000,00000/0/23895000//
+ static private Pattern pattern = Pattern.compile(
+ "\\$POS," + // Data Frame start
+ "(\\d+)," + // Id
+ "(\\d{2})(\\d{2})(\\d{2})\\.(\\d{3})," + // Time (HHMMSS.SSS)
+ "([AV])," + // Validity
+ "(\\d{2})(\\d{2}\\.\\d{4})," + // Latitude (DDMM.MMMM)
+ "([NS])," +
+ "(\\d{3})(\\d{2}\\.\\d{4})," + // Longitude (DDDMM.MMMM)
+ "([EW])," +
+ "(\\d+\\.\\d+)," + // Speed
+ "(\\d+\\.\\d+)," + // Course (or Distance???)
+ "(\\d{2})(\\d{2})(\\d{2})," + // Date
+ ".*");
+
+ /*
+ * Decode message
+ */
+ protected Object decode(
+ ChannelHandlerContext ctx, Channel channel, Object msg)
+ throws Exception {
+
+ String sentence = (String) msg;
+
+ // Parse message
+ Matcher parser = pattern.matcher(sentence);
+ if (!parser.matches()) {
+ Log.getLogger().info("Parsing error");
+ return null;
+ }
+
+ // Create new position
+ Position position = new Position();
+ StringBuilder extendedInfo = new StringBuilder("<protocol>pt502</protocol>");
+
+ Integer index = 1;
+
+ // Get device by IMEI
+ String id = parser.group(index++);
+ position.setDeviceId(getDataManager().getDeviceByImei(id).getId());
+
+ // Time
+ Calendar time = Calendar.getInstance(TimeZone.getTimeZone("UTC"));
+ time.clear();
+ time.set(Calendar.HOUR, Integer.valueOf(parser.group(index++)));
+ time.set(Calendar.MINUTE, Integer.valueOf(parser.group(index++)));
+ time.set(Calendar.SECOND, Integer.valueOf(parser.group(index++)));
+ time.set(Calendar.MILLISECOND, Integer.valueOf(parser.group(index++)));
+
+ // Validity
+ position.setValid(parser.group(index++).compareTo("A") == 0 ? true : false);
+
+ // Latitude
+ Double latitude = Double.valueOf(parser.group(index++));
+ latitude += Double.valueOf(parser.group(index++)) / 60;
+ if (parser.group(index++).compareTo("S") == 0) {
+ latitude = -latitude;
+ }
+ position.setLatitude(latitude);
+
+ // Longitude
+ Double lonlitude = Double.valueOf(parser.group(index++));
+ lonlitude += Double.valueOf(parser.group(index++)) / 60;
+ if (parser.group(index++).compareTo("W") == 0) {
+ lonlitude = -lonlitude;
+ }
+ position.setLongitude(lonlitude);
+
+ // Altitude
+ position.setAltitude(0.0);
+
+ // Speed
+ position.setSpeed(Double.valueOf(parser.group(index++)));
+ position.setCourse(Double.valueOf(parser.group(index++)));
+
+ // Date
+ time.set(Calendar.DAY_OF_MONTH, Integer.valueOf(parser.group(index++)));
+ time.set(Calendar.MONTH, Integer.valueOf(parser.group(index++)) - 1);
+ time.set(Calendar.YEAR, 2000 + Integer.valueOf(parser.group(index++)));
+ position.setTime(time.getTime());
+
+ // Extended info
+ position.setExtendedInfo(extendedInfo.toString());
+
+ return position;
+ }
+}