diff options
-rw-r--r-- | include/dissect.h | 25 | ||||
-rw-r--r-- | unittest/test.cc | 2 |
2 files changed, 24 insertions, 3 deletions
diff --git a/include/dissect.h b/include/dissect.h index 32df78d..3b347de 100644 --- a/include/dissect.h +++ b/include/dissect.h @@ -32,19 +32,40 @@ public: } }; + template <CommandID id, class HIDPacket> class ResponseDissector : semantics::non_constructible { public: static std::string dissect(const HIDPacket &pod) { std::stringstream out; + + std::string status[4]; + status[0] = " STATUS_READY"; + status[1]= " STATUS_BUSY"; + status[2]= " STATUS_ERROR"; + status[3]= " STATUS_RECEIVED_REPORT"; + std::string cmd[11]; + cmd[0]= " CMD_STATUS_OK"; + cmd[1]= " CMD_STATUS_WRONG_CRC"; + cmd[2]= " CMD_STATUS_WRONG_SLOT"; + cmd[3]= " CMD_STATUS_SLOT_NOT_PROGRAMMED"; + cmd[4]= " CMD_STATUS_WRONG_PASSWORD"; + cmd[5]= " CMD_STATUS_NOT_AUTHORIZED"; + cmd[6]= " CMD_STATUS_TIMESTAMP_WARNING"; + cmd[7]= " CMD_STATUS_NO_NAME_ERROR"; + cmd[8]= " CMD_STATUS_NOT_SUPPORTED"; + cmd[9]= " CMD_STATUS_UNKNOWN_COMMAND"; + cmd[10]= " CMD_STATUS_AES_DEC_FAILED"; + + out << "Raw HID packet:" << std::endl; out << ::nitrokey::misc::hexdump((const char *)(&pod), sizeof pod); - out << "Device status:\t" << pod.device_status + 0 << std::endl; + out << "Device status:\t" << pod.device_status + 0<<" "<< cmd[ pod.device_status ] << std::endl; out << "Command ID:\t" << commandid_to_string((CommandID)(pod.command_id)) << std::endl; out << "Last command CRC:\t" << pod.last_command_crc << std::endl; - out << "Last command status:\t" << pod.last_command_status + 0 << std::endl; + out << "Last command status:\t" << pod.last_command_status + 0<<" "<<status[pod.last_command_status] << std::endl; out << "CRC:\t" << pod.crc << std::endl; out << "Payload:" << std::endl; diff --git a/unittest/test.cc b/unittest/test.cc index ae13dda..9d1423c 100644 --- a/unittest/test.cc +++ b/unittest/test.cc @@ -26,7 +26,7 @@ int main() { } { - for (int i=0; i<10; i++) { + for (int i=0x20; i<0x23; i++) { ReadSlot::CommandTransaction::CommandPayload slot_req; slot_req.slot_number = i; auto slot = ReadSlot::CommandTransaction::run(stick, slot_req); |