diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2016-09-27 13:01:40 +1300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-09-27 13:01:40 +1300 |
commit | 73d63c16505d869a82df1038cf876f1413d38bd5 (patch) | |
tree | 41bd458abf2d3c8b0194acedc1387e23a5070ad8 /src | |
parent | 18499577b16a198762609075ff1846f354d3d712 (diff) | |
parent | ad070aa889b0f8727f0b8389f19d3ed4bfb09806 (diff) | |
download | trackermap-server-73d63c16505d869a82df1038cf876f1413d38bd5.tar.gz trackermap-server-73d63c16505d869a82df1038cf876f1413d38bd5.tar.bz2 trackermap-server-73d63c16505d869a82df1038cf876f1413d38bd5.zip |
Merge pull request #2349 from dcbastos/master
Adds unknown devices automatically.
Diffstat (limited to 'src')
-rw-r--r-- | src/org/traccar/BaseProtocolDecoder.java | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/src/org/traccar/BaseProtocolDecoder.java b/src/org/traccar/BaseProtocolDecoder.java index 72b9a7a74..15f5471e9 100644 --- a/src/org/traccar/BaseProtocolDecoder.java +++ b/src/org/traccar/BaseProtocolDecoder.java @@ -26,11 +26,27 @@ import java.net.SocketAddress; import java.util.Date; import java.util.HashMap; import java.util.Map; +import java.sql.SQLException; public abstract class BaseProtocolDecoder extends ExtendedObjectDecoder { private final Protocol protocol; + public long addUnknownDevice(String uniqueId) { + Device device = new Device(); + device.setName(uniqueId); + device.setUniqueId(uniqueId); + + try { + Context.getDeviceManager().addDevice(device); + Log.info("Automatically registered device " + uniqueId); + return device.getId(); + } catch (SQLException e) { + Log.warning(e); + return 0; + } + } + public String getProtocolName() { return protocol.getName(); } @@ -55,6 +71,10 @@ public abstract class BaseProtocolDecoder extends ExtendedObjectDecoder { Log.warning(e); } if (deviceId == 0) { + if (Context.getConfig().getBoolean("database.registerUnknown")) { + return addUnknownDevice(uniqueIds[0]); + } + StringBuilder message = new StringBuilder("Unknown device -"); for (String uniqueId : uniqueIds) { message.append(" ").append(uniqueId); |