param parsing convert to procedures

This commit is contained in:
merlokk 2017-10-31 15:15:57 +02:00
commit 8019540b19
3 changed files with 81 additions and 43 deletions

View file

@ -556,17 +556,14 @@ int CmdHF14ASnoop(const char *Cmd) {
int CmdHF14AAPDU(const char *cmd) { int CmdHF14AAPDU(const char *cmd) {
uint8_t data[USB_CMD_DATA_SIZE]; uint8_t data[USB_CMD_DATA_SIZE];
uint16_t datalen = 0; int datalen = 0;
uint8_t cmdc = 0; uint8_t cmdc = 0;
char buf[5] = {0};
int i = 0;
uint32_t temp;
uint8_t first, second; uint8_t first, second;
bool activateField = false; bool activateField = false;
bool leaveSignalON = false; bool leaveSignalON = false;
bool decodeTLV = false; bool decodeTLV = false;
if (strlen(cmd)<2) { if (strlen(cmd) < 2) {
PrintAndLog("Usage: hf 14a apdu [-s] [-k] [-t] <APDU (hex)>"); PrintAndLog("Usage: hf 14a apdu [-s] [-k] [-t] <APDU (hex)>");
PrintAndLog(" -s activate field and select card"); PrintAndLog(" -s activate field and select card");
PrintAndLog(" -k leave the signal field ON after receive response"); PrintAndLog(" -k leave the signal field ON after receive response");
@ -574,13 +571,11 @@ int CmdHF14AAPDU(const char *cmd) {
return 0; return 0;
} }
// strip int cmdp = 0;
while (*cmd==' ' || *cmd=='\t') cmd++; while(param_getchar(cmd, cmdp) != 0x00) {
char c = param_getchar(cmd, cmdp);
while (cmd[i]!='\0') { if ((c == '-') && (param_getlength(cmd, cmdp) == 2))
if (cmd[i]==' ' || cmd[i]=='\t') { i++; continue; } switch (param_getchar_indx(cmd, 1, cmdp)) {
if (cmd[i]=='-') {
switch (cmd[i + 1]) {
case 's': case 's':
case 'S': case 'S':
activateField = true; activateField = true;
@ -594,39 +589,29 @@ int CmdHF14AAPDU(const char *cmd) {
decodeTLV = true; decodeTLV = true;
break; break;
default: default:
PrintAndLog("Invalid option"); PrintAndLog("Unknown parameter '%c'", param_getchar_indx(cmd, 1, cmdp));
return 1; return 1;
} }
i += 2;
continue; if (isxdigit(c)) {
} switch(param_gethex_to_eol(cmd, cmdp, data, sizeof(data), &datalen)) {
if ((cmd[i] >= '0' && cmd[i] <= '9') || case 1:
(cmd[i] >= 'a' && cmd[i] <= 'f') || PrintAndLog("Invalid HEX value.");
(cmd[i] >= 'A' && cmd[i] <= 'F') ) { return 1;
buf[strlen(buf) + 1] = 0x00; case 2:
buf[strlen(buf)] = cmd[i]; PrintAndLog("APDU too large.");
i++; return 1;
case 3:
if (strlen(buf) >= 2) { PrintAndLog("Hex must have even number of digits.");
sscanf(buf, "%x", &temp); return 1;
data[datalen] = (uint8_t)(temp & 0xff);
*buf = 0;
if (datalen > sizeof(data) - 2) {
PrintAndLog("Buffer is full...");
break;
} else {
datalen++;
}
} }
continue;
// we get all the hex to end of line with spaces
break;
} }
PrintAndLog("Invalid char on input");
return 1; cmdp++;
} }
if (*buf) {
PrintAndLog("Hex must have even number of digits. Detected %d symbols.", datalen * 2 + strlen(buf));
return 1;
}
if (activateField) if (activateField)
cmdc |= ISO14A_CONNECT; cmdc |= ISO14A_CONNECT;

View file

@ -364,13 +364,19 @@ int param_getlength(const char *line, int paramnum)
return en - bg + 1; return en - bg + 1;
} }
char param_getchar(const char *line, int paramnum) char param_getchar(const char *line, int paramnum) {
{ return param_getchar_indx(line, 0, paramnum);
}
char param_getchar_indx(const char *line, int indx, int paramnum) {
int bg, en; int bg, en;
if (param_getptr(line, &bg, &en, paramnum)) return 0x00; if (param_getptr(line, &bg, &en, paramnum)) return 0x00;
return line[bg]; if (bg + indx > en)
return '\0';
return line[bg + indx];
} }
uint8_t param_get8(const char *line, int paramnum) uint8_t param_get8(const char *line, int paramnum)
@ -480,6 +486,51 @@ int param_gethex_ex(const char *line, int paramnum, uint8_t * data, int *hexcnt)
return 0; return 0;
} }
int param_gethex_to_eol(const char *line, int paramnum, uint8_t * data, int maxdatalen, int *datalen) {
int bg, en;
uint32_t temp;
char buf[5] = {0};
if (param_getptr(line, &bg, &en, paramnum)) return 1;
*datalen = 0;
int indx = bg;
while (line[indx]) {
if (line[indx] == '\t' || line[indx] == ' ')
continue;
if (isxdigit(line[indx])) {
buf[strlen(buf) + 1] = 0x00;
buf[strlen(buf)] = line[indx];
} else {
// if we have symbols other than spaces and hex
return 1;
}
if (*datalen >= maxdatalen) {
// if we dont have space in buffer and have symbols to translate
return 2;
}
if (strlen(buf) >= 2) {
sscanf(buf, "%x", &temp);
data[*datalen] = (uint8_t)(temp & 0xff);
*buf = 0;
(*datalen)++;
}
indx++;
}
if (strlen(buf) > 0)
//error when not completed hex bytes
return 3;
return 0;
}
int param_getstr(const char *line, int paramnum, char * str) int param_getstr(const char *line, int paramnum, char * str)
{ {
int bg, en; int bg, en;

View file

@ -53,6 +53,7 @@ extern void SwapEndian64ex(const uint8_t *src, const size_t len, const uint8_t b
extern int param_getlength(const char *line, int paramnum); extern int param_getlength(const char *line, int paramnum);
extern char param_getchar(const char *line, int paramnum); extern char param_getchar(const char *line, int paramnum);
extern char param_getchar_indx(const char *line, int indx, int paramnum);
extern int param_getptr(const char *line, int *bg, int *en, int paramnum); extern int param_getptr(const char *line, int *bg, int *en, int paramnum);
extern uint8_t param_get8(const char *line, int paramnum); extern uint8_t param_get8(const char *line, int paramnum);
extern uint8_t param_get8ex(const char *line, int paramnum, int deflt, int base); extern uint8_t param_get8ex(const char *line, int paramnum, int deflt, int base);
@ -62,6 +63,7 @@ extern uint8_t param_getdec(const char *line, int paramnum, uint8_t *destination
extern uint8_t param_isdec(const char *line, int paramnum); extern uint8_t param_isdec(const char *line, int paramnum);
extern int param_gethex(const char *line, int paramnum, uint8_t * data, int hexcnt); extern int param_gethex(const char *line, int paramnum, uint8_t * data, int hexcnt);
extern int param_gethex_ex(const char *line, int paramnum, uint8_t * data, int *hexcnt); extern int param_gethex_ex(const char *line, int paramnum, uint8_t * data, int *hexcnt);
extern int param_gethex_to_eol(const char *line, int paramnum, uint8_t * data, int maxdatalen, int *datalen);
extern int param_getstr(const char *line, int paramnum, char * str); extern int param_getstr(const char *line, int paramnum, char * str);
extern int hextobinarray( char *target, char *source); extern int hextobinarray( char *target, char *source);