mDot AT-Firmware for testing

Dependencies:   MTS-Serial libmDot-mbed5

Fork of Dot-AT-Firmware by MultiTech

Committer:
Mike Fiore
Date:
Fri Nov 04 14:25:43 2016 -0500
Revision:
14:f9a77400b622
Parent:
9:ff62b20f7000
update from git revision 2.0.16

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Mike Fiore 1:e52ae6584f1c 1 #include "CmdNetworkSessionKey.h"
Mike Fiore 1:e52ae6584f1c 2
Mike Fiore 14:f9a77400b622 3 CmdNetworkSessionKey::CmdNetworkSessionKey() :
Mike Fiore 14:f9a77400b622 4 Command("Network Session Key", "AT+NSK", "Network session encryption key (16 bytes)", "(hex:16)")
Mike Fiore 1:e52ae6584f1c 5 {
Mike Fiore 1:e52ae6584f1c 6 _queryable = true;
Mike Fiore 1:e52ae6584f1c 7 }
Mike Fiore 1:e52ae6584f1c 8
Mike Fiore 1:e52ae6584f1c 9 uint32_t CmdNetworkSessionKey::action(std::vector<std::string> args)
Mike Fiore 1:e52ae6584f1c 10 {
Mike Fiore 1:e52ae6584f1c 11 if (args.size() == 1)
Mike Fiore 1:e52ae6584f1c 12 {
Mike Fiore 14:f9a77400b622 13 CommandTerminal::Serial()->writef("%s\r\n", mts::Text::bin2hexString(CommandTerminal::Dot()->getNetworkSessionKey(), ".").c_str());
Mike Fiore 1:e52ae6584f1c 14 }
Mike Fiore 1:e52ae6584f1c 15 else if (args.size() == 2)
Mike Fiore 1:e52ae6584f1c 16 {
Mike Fiore 1:e52ae6584f1c 17 std::vector<uint8_t> NewKey;
Mike Fiore 1:e52ae6584f1c 18
Mike Fiore 1:e52ae6584f1c 19 // Read in the key components...
Mike Fiore 1:e52ae6584f1c 20 readByteArray(args[1], NewKey, KEY_LENGTH);
Mike Fiore 1:e52ae6584f1c 21
Mike Fiore 14:f9a77400b622 22 if (CommandTerminal::Dot()->setNetworkSessionKey(NewKey) == mDot::MDOT_OK) {
Mike Fiore 14:f9a77400b622 23 CommandTerminal::Serial()->writef("Set Network Session Key: ");
Mike Fiore 14:f9a77400b622 24 CommandTerminal::Serial()->writef("%s\r\n", mts::Text::bin2hexString(NewKey, ".").c_str());
Mike Fiore 1:e52ae6584f1c 25 } else {
Mike Fiore 9:ff62b20f7000 26
Mike Fiore 14:f9a77400b622 27 CommandTerminal::setErrorMessage(CommandTerminal::Dot()->getLastError());;
Mike Fiore 1:e52ae6584f1c 28 return 1;
Mike Fiore 1:e52ae6584f1c 29 }
Mike Fiore 1:e52ae6584f1c 30 }
Mike Fiore 1:e52ae6584f1c 31
Mike Fiore 1:e52ae6584f1c 32 return 0;
Mike Fiore 1:e52ae6584f1c 33 }
Mike Fiore 1:e52ae6584f1c 34
Mike Fiore 1:e52ae6584f1c 35 bool CmdNetworkSessionKey::verify(std::vector<std::string> args)
Mike Fiore 1:e52ae6584f1c 36 {
Mike Fiore 1:e52ae6584f1c 37 if (args.size() == 1)
Mike Fiore 1:e52ae6584f1c 38 return true;
Mike Fiore 1:e52ae6584f1c 39
Mike Fiore 1:e52ae6584f1c 40 if (args.size() == 2) {
Mike Fiore 1:e52ae6584f1c 41 if (!isHexString(args[1], 16)) {
Mike Fiore 14:f9a77400b622 42 CommandTerminal::setErrorMessage("Invalid key, expects (hex:16)");
Mike Fiore 1:e52ae6584f1c 43 return false;
Mike Fiore 1:e52ae6584f1c 44 }
Mike Fiore 1:e52ae6584f1c 45
Mike Fiore 1:e52ae6584f1c 46 return true;
Mike Fiore 1:e52ae6584f1c 47 }
Mike Fiore 1:e52ae6584f1c 48
Mike Fiore 14:f9a77400b622 49 CommandTerminal::setErrorMessage("Invalid arguments");
Mike Fiore 1:e52ae6584f1c 50 return false;
Mike Fiore 1:e52ae6584f1c 51 }