summaryrefslogtreecommitdiff
path: root/CommandTerminal/CmdData.cpp
diff options
context:
space:
mode:
authorMike Fiore <mfiore@multitech.com>2015-11-18 15:46:37 -0600
committerMike Fiore <mfiore@multitech.com>2015-11-18 15:46:37 -0600
commitd48510e9c3a57753ff4b33b00e0c61a2b39ff9a1 (patch)
treef04f39f7287a6bca826a6c22179b0542cd16f36f /CommandTerminal/CmdData.cpp
parent94990163d2b694373eb5b2b8ccc4d002aad4ecd9 (diff)
parentce5c78c53be8d66da4a2cccdf18b622c0b77e773 (diff)
downloadmtdot-box-evb-factory-firmware-d48510e9c3a57753ff4b33b00e0c61a2b39ff9a1.tar.gz
mtdot-box-evb-factory-firmware-d48510e9c3a57753ff4b33b00e0c61a2b39ff9a1.tar.bz2
mtdot-box-evb-factory-firmware-d48510e9c3a57753ff4b33b00e0c61a2b39ff9a1.zip
Merge branch 'atcommands'
configuration needs to be pulled out of main and implemented as a Mode object Conflicts: main.cpp
Diffstat (limited to 'CommandTerminal/CmdData.cpp')
-rw-r--r--CommandTerminal/CmdData.cpp56
1 files changed, 56 insertions, 0 deletions
diff --git a/CommandTerminal/CmdData.cpp b/CommandTerminal/CmdData.cpp
new file mode 100644
index 0000000..4b31de6
--- /dev/null
+++ b/CommandTerminal/CmdData.cpp
@@ -0,0 +1,56 @@
+#include "CmdData.h"
+
+//SPECIAL NOTE: +Data is stored in the LoraConfig StartUpMode field. We decided to use 5 LoRaConfig locations,
+// that are not used for the DotBox, for the 5 DotBox settings... +minsize, +maxsize, +minpwr, +maxpwr and +data.
+CmdData::CmdData(mDot* dot, mts::MTSSerial& serial) :
+ Command(dot, "Data", "AT+DATA", "Enable/disable sending survey data results packet to the network server upon each successful survey. (0: off, 1: on)"), _serial(serial)
+{
+ _help = std::string(text()) + ": " + std::string(desc());
+ _usage = "(0,1)";
+ _queryable = true;
+}
+
+uint32_t CmdData::action(std::vector<std::string> args)
+{
+ if (args.size() == 1)
+ {
+ if (_dot->getVerbose())
+ _serial.writef("%s: ", name());
+ _serial.writef("%d\r\n", _dot->getStartUpMode());
+ }
+ else if (args.size() == 2)
+ {
+ int32_t code;
+ bool enable = (args[1] == "1");
+
+ if ((code = _dot->setStartUpMode(enable)) != mDot::MDOT_OK) {
+ std::string error = mDot::getReturnCodeString(code) + " - " + _dot->getLastError();
+ setErrorMessage(error);
+ return 1;
+ }
+ }
+
+ return 0;
+
+}
+
+bool CmdData::verify(std::vector<std::string> args)
+{
+ if (args.size() == 1)
+ return true;
+
+ if (args.size() == 2)
+ {
+ if (args[1] != "1" && args[1] != "0") {
+ setErrorMessage("Invalid parameter, expects (0: off, 1: on)");
+ return false;
+ }
+
+ return true;
+ }
+
+ setErrorMessage("Invalid arguments");
+ return false;
+
+}
+