mirror of
https://github.com/Proxmark/proxmark3.git
synced 2025-08-19 12:59:44 -07:00
param parsing convert to procedures
This commit is contained in:
parent
f2b0169cc6
commit
8019540b19
3 changed files with 81 additions and 43 deletions
|
@ -556,11 +556,8 @@ 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;
|
||||||
|
@ -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,38 +589,28 @@ 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 ((cmd[i] >= '0' && cmd[i] <= '9') ||
|
|
||||||
(cmd[i] >= 'a' && cmd[i] <= 'f') ||
|
|
||||||
(cmd[i] >= 'A' && cmd[i] <= 'F') ) {
|
|
||||||
buf[strlen(buf) + 1] = 0x00;
|
|
||||||
buf[strlen(buf)] = cmd[i];
|
|
||||||
i++;
|
|
||||||
|
|
||||||
if (strlen(buf) >= 2) {
|
if (isxdigit(c)) {
|
||||||
sscanf(buf, "%x", &temp);
|
switch(param_gethex_to_eol(cmd, cmdp, data, sizeof(data), &datalen)) {
|
||||||
data[datalen] = (uint8_t)(temp & 0xff);
|
case 1:
|
||||||
*buf = 0;
|
PrintAndLog("Invalid HEX value.");
|
||||||
if (datalen > sizeof(data) - 2) {
|
return 1;
|
||||||
PrintAndLog("Buffer is full...");
|
case 2:
|
||||||
|
PrintAndLog("APDU too large.");
|
||||||
|
return 1;
|
||||||
|
case 3:
|
||||||
|
PrintAndLog("Hex must have even number of digits.");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// we get all the hex to end of line with spaces
|
||||||
break;
|
break;
|
||||||
} else {
|
|
||||||
datalen++;
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
continue;
|
cmdp++;
|
||||||
}
|
|
||||||
PrintAndLog("Invalid char on input");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
if (*buf) {
|
|
||||||
PrintAndLog("Hex must have even number of digits. Detected %d symbols.", datalen * 2 + strlen(buf));
|
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (activateField)
|
if (activateField)
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue