From 6dc180657196e4b6c2029c8b3fe9d3931152d094 Mon Sep 17 00:00:00 2001 From: Anton Tananaev Date: Sun, 19 Aug 2012 22:34:23 +0400 Subject: Add ST-210 server --- default.cfg | 5 +++++ pom.xml | 2 +- src/org/traccar/Server.java | 22 ++++++++++++++++++++++ 3 files changed, 28 insertions(+), 1 deletion(-) diff --git a/default.cfg b/default.cfg index 2568a2cc3..21b59cc0a 100644 --- a/default.cfg +++ b/default.cfg @@ -145,4 +145,9 @@ 5010 0 + + true + 5011 + 0 + diff --git a/pom.xml b/pom.xml index b7e3b1a16..1feddd3c7 100644 --- a/pom.xml +++ b/pom.xml @@ -81,7 +81,7 @@ maven-dependency-plugin - 2.4 + 2.5 install diff --git a/src/org/traccar/Server.java b/src/org/traccar/Server.java index 36d7720b6..7df1a463a 100644 --- a/src/org/traccar/Server.java +++ b/src/org/traccar/Server.java @@ -97,6 +97,7 @@ public class Server { initEnforaServer(properties); initMeiligaoServer(properties); initMaxonServer(properties); + initST210Server(properties); // Initialize web server if (Boolean.valueOf(properties.getProperty("http.enable"))) { @@ -478,4 +479,25 @@ public class Server { } } + private void initST210Server(Properties properties) throws SQLException { + String protocol = "st210"; + if (isProtocolEnabled(properties, protocol)) { + + TrackerServer server = new TrackerServer(getProtocolPort(properties, protocol)); + final Integer resetDelay = getProtocolResetDelay(properties, protocol); + + server.setPipelineFactory(new GenericPipelineFactory(server, dataManager, isLoggerEnabled(), geocoder) { + protected void addSpecificHandlers(ChannelPipeline pipeline) { + byte delimiter[] = { (byte) '\r' }; + pipeline.addLast("frameDecoder", + new DelimiterBasedFrameDecoder(1024, ChannelBuffers.wrappedBuffer(delimiter))); + pipeline.addLast("stringDecoder", new StringDecoder()); + pipeline.addLast("objectDecoder", new ST210ProtocolDecoder(getDataManager(), resetDelay)); + } + }); + + serverList.add(server); + } + } + } -- cgit v1.2.3