Custom "Installer Assistant" software. Modified Single Sweep Mode. Goes right into single sweep mode upon power-up and displays signal strength. Works with mbed-os 5.1.2 and mdot lib 5.1.5

Dependencies:   DOGS102 GpsParser ISL29011 MMA845x MPL3115A2 MTS-Serial NCP5623B libmDot-dev-mbed5-deprecated

Fork of MTDOT-BOX-EVB-Factory-Firmware by MultiTech

Committer:
ScottHoppeMultitech
Date:
Thu Dec 28 21:35:48 2017 +0000
Revision:
12:671b15182260
Parent:
1:71125aa00e33
Custom mDotBox software -modified single sweep mode - goes straight into a single sweep mode and display signal strength. Works With mbed-os 5.1.2 and mdot lib 5.1.5

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Mike Fiore 1:71125aa00e33 1 /* Copyright (c) <2016> <MultiTech Systems>, MIT License
Mike Fiore 1:71125aa00e33 2 *
Mike Fiore 1:71125aa00e33 3 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
Mike Fiore 1:71125aa00e33 4 * and associated documentation files (the "Software"), to deal in the Software without restriction,
Mike Fiore 1:71125aa00e33 5 * including without limitation the rights to use, copy, modify, merge, publish, distribute,
Mike Fiore 1:71125aa00e33 6 * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
Mike Fiore 1:71125aa00e33 7 * furnished to do so, subject to the following conditions:
Mike Fiore 1:71125aa00e33 8 *
Mike Fiore 1:71125aa00e33 9 * The above copyright notice and this permission notice shall be included in all copies or
Mike Fiore 1:71125aa00e33 10 * substantial portions of the Software.
Mike Fiore 1:71125aa00e33 11 *
Mike Fiore 1:71125aa00e33 12 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
Mike Fiore 1:71125aa00e33 13 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
Mike Fiore 1:71125aa00e33 14 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
Mike Fiore 1:71125aa00e33 15 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
Mike Fiore 1:71125aa00e33 16 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Mike Fiore 1:71125aa00e33 17 */
Mike Fiore 1:71125aa00e33 18
Mike Fiore 1:71125aa00e33 19 #include "CmdNetworkSessionKey.h"
Mike Fiore 1:71125aa00e33 20
Mike Fiore 1:71125aa00e33 21 CmdNetworkSessionKey::CmdNetworkSessionKey(mDot* dot, mts::MTSSerial& serial) :
Mike Fiore 1:71125aa00e33 22 Command(dot, "Network Session Key", "AT+NSK", "Network session encryption key (16 bytes)"), _serial(serial)
Mike Fiore 1:71125aa00e33 23 {
Mike Fiore 1:71125aa00e33 24 _help = std::string(text()) + ": " + std::string(desc());
Mike Fiore 1:71125aa00e33 25 _usage = "(hex:16)";
Mike Fiore 1:71125aa00e33 26 _queryable = true;
Mike Fiore 1:71125aa00e33 27 }
Mike Fiore 1:71125aa00e33 28
Mike Fiore 1:71125aa00e33 29 uint32_t CmdNetworkSessionKey::action(std::vector<std::string> args)
Mike Fiore 1:71125aa00e33 30 {
Mike Fiore 1:71125aa00e33 31 if (args.size() == 1)
Mike Fiore 1:71125aa00e33 32 {
Mike Fiore 1:71125aa00e33 33 if (_dot->getVerbose())
Mike Fiore 1:71125aa00e33 34 _serial.writef("Network Session Key: ");
Mike Fiore 1:71125aa00e33 35
Mike Fiore 1:71125aa00e33 36 _serial.writef("%s\r\n", mts::Text::bin2hexString(_dot->getNetworkSessionKey(), ".").c_str());
Mike Fiore 1:71125aa00e33 37 }
Mike Fiore 1:71125aa00e33 38 else if (args.size() == 2)
Mike Fiore 1:71125aa00e33 39 {
Mike Fiore 1:71125aa00e33 40 int32_t code;
Mike Fiore 1:71125aa00e33 41 std::vector<uint8_t> NewKey;
Mike Fiore 1:71125aa00e33 42
Mike Fiore 1:71125aa00e33 43 // Read in the key components...
Mike Fiore 1:71125aa00e33 44 readByteArray(args[1], NewKey, KEY_LENGTH);
Mike Fiore 1:71125aa00e33 45
Mike Fiore 1:71125aa00e33 46 if ((code = _dot->setNetworkSessionKey(NewKey)) == mDot::MDOT_OK) {
Mike Fiore 1:71125aa00e33 47 _serial.writef("Set Network Session Key: ");
Mike Fiore 1:71125aa00e33 48 _serial.writef("%s\r\n", mts::Text::bin2hexString(NewKey, ".").c_str());
Mike Fiore 1:71125aa00e33 49 } else {
Mike Fiore 1:71125aa00e33 50 std::string error = mDot::getReturnCodeString(code) + " - " + _dot->getLastError();
Mike Fiore 1:71125aa00e33 51 setErrorMessage(error);
Mike Fiore 1:71125aa00e33 52 return 1;
Mike Fiore 1:71125aa00e33 53 }
Mike Fiore 1:71125aa00e33 54 }
Mike Fiore 1:71125aa00e33 55
Mike Fiore 1:71125aa00e33 56 return 0;
Mike Fiore 1:71125aa00e33 57 }
Mike Fiore 1:71125aa00e33 58
Mike Fiore 1:71125aa00e33 59 bool CmdNetworkSessionKey::verify(std::vector<std::string> args)
Mike Fiore 1:71125aa00e33 60 {
Mike Fiore 1:71125aa00e33 61 if (args.size() == 1)
Mike Fiore 1:71125aa00e33 62 return true;
Mike Fiore 1:71125aa00e33 63
Mike Fiore 1:71125aa00e33 64 if (args.size() == 2) {
Mike Fiore 1:71125aa00e33 65 if (!isHexString(args[1], 16)) {
Mike Fiore 1:71125aa00e33 66 setErrorMessage("Invalid key, expects (hex:16)");
Mike Fiore 1:71125aa00e33 67 return false;
Mike Fiore 1:71125aa00e33 68 }
Mike Fiore 1:71125aa00e33 69
Mike Fiore 1:71125aa00e33 70 return true;
Mike Fiore 1:71125aa00e33 71 }
Mike Fiore 1:71125aa00e33 72
Mike Fiore 1:71125aa00e33 73 setErrorMessage("Invalid arguments");
Mike Fiore 1:71125aa00e33 74 return false;
Mike Fiore 1:71125aa00e33 75 }