aboutsummaryrefslogtreecommitdiff
path: root/src/org/traccar/WebDataHandler.java
diff options
context:
space:
mode:
authorAnton Tananaev <anton.tananaev@gmail.com>2015-07-14 19:17:02 +1200
committerAnton Tananaev <anton.tananaev@gmail.com>2015-07-14 19:17:02 +1200
commite98b18b8b0a8c99d24ac8010c1393978d071baa2 (patch)
tree48d63f067dcfaae9c0bdac34af4f9514a49ab9f5 /src/org/traccar/WebDataHandler.java
parent7310ee5f15729ea8517bfb6b0890a46da1217610 (diff)
downloadtrackermap-server-e98b18b8b0a8c99d24ac8010c1393978d071baa2.tar.gz
trackermap-server-e98b18b8b0a8c99d24ac8010c1393978d071baa2.tar.bz2
trackermap-server-e98b18b8b0a8c99d24ac8010c1393978d071baa2.zip
Support forwarding of data (fix #1131)
Diffstat (limited to 'src/org/traccar/WebDataHandler.java')
-rw-r--r--src/org/traccar/WebDataHandler.java41
1 files changed, 38 insertions, 3 deletions
diff --git a/src/org/traccar/WebDataHandler.java b/src/org/traccar/WebDataHandler.java
index bb1a540a9..fce73c816 100644
--- a/src/org/traccar/WebDataHandler.java
+++ b/src/org/traccar/WebDataHandler.java
@@ -16,6 +16,12 @@
package org.traccar;
import com.ning.http.client.AsyncHttpClient;
+import java.util.Calendar;
+import java.util.Formatter;
+import java.util.Locale;
+import java.util.TimeZone;
+import org.traccar.helper.Crc;
+import org.traccar.model.Device;
import org.traccar.model.Position;
public class WebDataHandler extends BaseDataHandler {
@@ -25,15 +31,44 @@ public class WebDataHandler extends BaseDataHandler {
public WebDataHandler(String url) {
this.url = url;
}
+
+ private static String formatSentence(Position position) {
+
+ StringBuilder s = new StringBuilder("$GPRMC,");
+
+ try (Formatter f = new Formatter(s, Locale.ENGLISH)) {
+
+ Calendar calendar = Calendar.getInstance(TimeZone.getTimeZone("UTC"), Locale.ENGLISH);
+ calendar.setTimeInMillis(position.getFixTime().getTime());
+
+ f.format("%1$tH%1$tM%1$tS.%1$tL,A,", calendar);
+
+ double lat = position.getLatitude();
+ double lon = position.getLongitude();
+ f.format("%02d%07.4f,%c,", (int) Math.abs(lat), Math.abs(lat) % 1 * 60, lat < 0 ? 'S' : 'N');
+ f.format("%03d%07.4f,%c,", (int) Math.abs(lon), Math.abs(lon) % 1 * 60, lon < 0 ? 'W' : 'E');
+
+ f.format("%.2f,%.2f,", position.getSpeed(), position.getCourse());
+ f.format("%1$td%1$tm%1$ty,,", calendar);
+ }
+
+ s.append(Crc.nmeaChecksum(s.toString()));
+
+ return s.toString();
+ }
@Override
protected Position handlePosition(Position position) {
+
+ Device device = Context.getIdentityManager().getDeviceById(position.getDeviceId());
+
String request = url.
- //replaceAll("\\{uniqueId}", String.valueOf(position.getDeviceId())).
- replaceAll("\\{deviceId}", String.valueOf(position.getDeviceId())).
+ replaceAll("\\{uniqueId}", device.getUniqueId()).
+ replaceAll("\\{deviceId}", String.valueOf(device.getId())).
replaceAll("\\{fixTime}", String.valueOf(position.getFixTime().getTime())).
replaceAll("\\{latitude}", String.valueOf(position.getLatitude())).
- replaceAll("\\{longitude}", String.valueOf(position.getLongitude()));
+ replaceAll("\\{longitude}", String.valueOf(position.getLongitude())).
+ replaceAll("\\{gprmc}", formatSentence(position));
AsyncHttpClient asyncHttpClient = new AsyncHttpClient();
asyncHttpClient.prepareGet(request).execute();