aboutsummaryrefslogtreecommitdiff
path: root/src/org/traccar
diff options
context:
space:
mode:
authorAbyss777 <abyss@fox5.ru>2018-04-28 16:14:24 +0500
committerAbyss777 <abyss@fox5.ru>2018-04-28 16:14:24 +0500
commit94f87ea207558f6b03eeaf49dd2527dcfe0472ba (patch)
tree7eb9734abf93f6e9b230bc39002bfa46bc38ac6e /src/org/traccar
parentc763c6c688a2148e46c951c9fc33c09e640bcd9d (diff)
downloadtraccar-server-94f87ea207558f6b03eeaf49dd2527dcfe0472ba.tar.gz
traccar-server-94f87ea207558f6b03eeaf49dd2527dcfe0472ba.tar.bz2
traccar-server-94f87ea207558f6b03eeaf49dd2527dcfe0472ba.zip
Make Commands queueing switchable
Diffstat (limited to 'src/org/traccar')
-rw-r--r--src/org/traccar/Context.java2
-rw-r--r--src/org/traccar/database/CommandsManager.java7
2 files changed, 7 insertions, 2 deletions
diff --git a/src/org/traccar/Context.java b/src/org/traccar/Context.java
index 67fd02f75..30e6ca713 100644
--- a/src/org/traccar/Context.java
+++ b/src/org/traccar/Context.java
@@ -391,7 +391,7 @@ public final class Context {
driversManager = new DriversManager(dataManager);
- commandsManager = new CommandsManager(dataManager);
+ commandsManager = new CommandsManager(dataManager, config.getBoolean("commands.queueing"));
statisticsManager = new StatisticsManager();
diff --git a/src/org/traccar/database/CommandsManager.java b/src/org/traccar/database/CommandsManager.java
index 9ceb995ef..e59762d10 100644
--- a/src/org/traccar/database/CommandsManager.java
+++ b/src/org/traccar/database/CommandsManager.java
@@ -37,8 +37,11 @@ public class CommandsManager extends ExtendedObjectManager<Command> {
private final Map<Long, Queue<Command>> deviceQueues = new ConcurrentHashMap<>();
- public CommandsManager(DataManager dataManager) {
+ private boolean queueing;
+
+ public CommandsManager(DataManager dataManager, boolean queueing) {
super(dataManager, Command.class);
+ this.queueing = queueing;
}
public boolean checkDeviceCommand(long deviceId, long commandId) {
@@ -70,6 +73,8 @@ public class CommandsManager extends ExtendedObjectManager<Command> {
ActiveDevice activeDevice = Context.getConnectionManager().getActiveDevice(deviceId);
if (activeDevice != null) {
activeDevice.sendCommand(command);
+ } else if (!queueing) {
+ throw new RuntimeException("Commands queueing is not enabled");
} else {
getDeviceQueue(deviceId).add(command);
return false;