diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2023-03-13 11:07:29 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-03-13 11:07:29 -0700 |
commit | ab8260fa0125b5104255f5d132809b62006be48f (patch) | |
tree | b03d1d3f02b30055f2c434fa88cadce0fc140cf6 /src/main/java/org | |
parent | 08612944b879861c37b34688e0e9ef2d4a8c11a2 (diff) | |
parent | fc0b4234d1d0d668769819b40c476a51beab0c1d (diff) | |
download | trackermap-server-ab8260fa0125b5104255f5d132809b62006be48f.tar.gz trackermap-server-ab8260fa0125b5104255f5d132809b62006be48f.tar.bz2 trackermap-server-ab8260fa0125b5104255f5d132809b62006be48f.zip |
Merge pull request #5047 from bernamaxim/master
RegisterUnknown filter with regex
Diffstat (limited to 'src/main/java/org')
-rw-r--r-- | src/main/java/org/traccar/config/Keys.java | 7 | ||||
-rw-r--r-- | src/main/java/org/traccar/session/ConnectionManager.java | 4 |
2 files changed, 10 insertions, 1 deletions
diff --git a/src/main/java/org/traccar/config/Keys.java b/src/main/java/org/traccar/config/Keys.java index 1b4b3a5b4..491c724aa 100644 --- a/src/main/java/org/traccar/config/Keys.java +++ b/src/main/java/org/traccar/config/Keys.java @@ -495,6 +495,13 @@ public final class Keys { List.of(KeyType.CONFIG)); /** + * Automatically register unknown devices with regex filter. + */ + public static final ConfigKey<String> DATABASE_REGISTER_UNKNOWN_REGEX = new StringConfigKey( + "database.registerUnknown.regex", + List.of(KeyType.CONFIG), "\\w{3,15}"); + + /** * Store empty messages as positions. For example, heartbeats. */ public static final ConfigKey<Boolean> DATABASE_SAVE_EMPTY = new BooleanConfigKey( diff --git a/src/main/java/org/traccar/session/ConnectionManager.java b/src/main/java/org/traccar/session/ConnectionManager.java index 37a42d827..e6f5d00cf 100644 --- a/src/main/java/org/traccar/session/ConnectionManager.java +++ b/src/main/java/org/traccar/session/ConnectionManager.java @@ -123,7 +123,9 @@ public class ConnectionManager implements BroadcastInterface { Device device = deviceLookupService.lookup(uniqueIds); if (device == null && config.getBoolean(Keys.DATABASE_REGISTER_UNKNOWN)) { - device = addUnknownDevice(uniqueIds[0]); + if (uniqueIds[0].matches(config.getString(Keys.DATABASE_REGISTER_UNKNOWN_REGEX))) { + device = addUnknownDevice(uniqueIds[0]); + } } if (device != null) { |