From dd557b5a21d64cd49b1179ac891ffb2c63dee6d8 Mon Sep 17 00:00:00 2001 From: Leon Lindenfelser Date: Fri, 13 Nov 2015 08:14:28 -0600 Subject: Added CommandTerminal with unneccessary commands removed --- CommandTerminal/CmdDeviceId.cpp | 57 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 CommandTerminal/CmdDeviceId.cpp (limited to 'CommandTerminal/CmdDeviceId.cpp') diff --git a/CommandTerminal/CmdDeviceId.cpp b/CommandTerminal/CmdDeviceId.cpp new file mode 100644 index 0000000..05d2301 --- /dev/null +++ b/CommandTerminal/CmdDeviceId.cpp @@ -0,0 +1,57 @@ +#include "CmdDeviceId.h" +#include + +CmdDeviceId::CmdDeviceId(mDot* dot, mts::MTSSerial& serial) : + Command(dot, "Device ID", "AT+DI", "Device EUI (unique, set at factory) (8 bytes)"), _serial(serial) +{ + _help = std::string(text()) + ": " + std::string(desc()); + _usage = "(hex:8)"; + _queryable = true; +} + +uint32_t CmdDeviceId::action(std::vector args) +{ + if (args.size() == 1) + { + if (_dot->getVerbose()) + _serial.writef("%s: ", name()); + _serial.writef("%s\r\n", mts::Text::bin2hexString(_dot->getDeviceId(), ":").c_str()); + } +#ifdef DEBUG_MAC + else if (args.size() == 2) + { + int32_t code; + std::vector NewEUI; + + // Read in the key components... + readByteArray(args[1], NewEUI, EUI_LENGTH); + + if ((code = _dot->setDeviceId(NewEUI)) == mDot::MDOT_OK) { + _serial.writef("Set %s: ", name()); + _serial.writef("%s\r\n", mts::Text::bin2hexString(NewEUI, ":").c_str()); + } else { + std::string error = mDot::getReturnCodeString(code) + " - " + _dot->getLastError(); + setErrorMessage(error); + return 1; + } + } +#endif + return 0; +} + +bool CmdDeviceId::verify(std::vector args) +{ + if (args.size() == 1) + return true; + +#ifdef DEBUG_MAC + if (args.size() == 2 && isHexString(args[1], 8)) + return true; + + setErrorMessage("Invalid id, expects (hex:8)"); +#else + setErrorMessage("Invalid arguments"); +#endif + + return false; +} -- cgit v1.2.3