proxmark3/client/aidsearch.c

178 lines
4.9 KiB
C
Raw Normal View History

2019-11-05 01:54:23 +08:00
//-----------------------------------------------------------------------------
// Copyright (C) 2019 merlokk
//
// This code is licensed to you under the terms of the GNU GPL, version 2 or,
// at your option, any later version. See the LICENSE.txt file for the text of
// the license.
//-----------------------------------------------------------------------------
// Proxmark3 RDV40 AID list library
//-----------------------------------------------------------------------------
#include "aidsearch.h"
#include <ctype.h>
#include <string.h>
#include "fileutils.h"
#include "pm3_cmd.h"
int openAIDFile(json_t **root, bool verbose) {
2019-11-05 01:54:23 +08:00
json_error_t error;
char *path;
int res = searchFile(&path, RESOURCES_SUBDIR, "aidlist", ".json", false);
if (res != PM3_SUCCESS) {
return PM3_EFILE;
}
int retval = PM3_SUCCESS;
2019-11-05 02:15:09 +08:00
*root = json_load_file(path, 0, &error);
if (!*root) {
2019-11-05 01:54:23 +08:00
PrintAndLogEx(ERR, "json (%s) error on line %d: %s", path, error.line, error.text);
retval = PM3_ESOFT;
goto out;
}
2019-11-05 02:15:09 +08:00
if (!json_is_array(*root)) {
2019-11-05 01:54:23 +08:00
PrintAndLogEx(ERR, "Invalid json (%s) format. root must be an array.", path);
retval = PM3_ESOFT;
goto out;
}
2020-01-04 00:57:45 +08:00
if (verbose) PrintAndLogEx(SUCCESS, "Loaded file (%s) OK. %zu records.", path, json_array_size(*root));
2019-11-05 01:54:23 +08:00
out:
free(path);
return retval;
}
int closeAIDFile(json_t *root) {
json_decref(root);
return PM3_SUCCESS;
}
json_t *AIDSearchInit(bool verbose) {
2019-11-05 02:15:09 +08:00
json_t *root = NULL;
int res = openAIDFile(&root, verbose);
2019-11-05 01:54:23 +08:00
if (res != PM3_SUCCESS)
return NULL;
2019-11-05 02:15:09 +08:00
return root;
2019-11-05 01:54:23 +08:00
}
json_t *AIDSearchGetElm(json_t *root, int elmindx) {
json_t *data = json_array_get(root, elmindx);
if (!json_is_object(data)) {
PrintAndLogEx(ERR, "data [%d] is not an object\n", elmindx);
return NULL;
}
return data;
}
int AIDSearchFree(json_t *root) {
2019-11-08 19:00:21 +08:00
2019-11-05 01:54:23 +08:00
return closeAIDFile(root);
}
2019-11-08 19:00:21 +08:00
const char *jsonStrGet(json_t *data, char *name) {
2019-11-05 01:54:23 +08:00
json_t *jstr;
2019-11-08 19:00:21 +08:00
2019-11-05 01:54:23 +08:00
jstr = json_object_get(data, name);
2019-11-05 02:15:09 +08:00
if (jstr == NULL)
return NULL;
2019-11-05 01:54:23 +08:00
if (!json_is_string(jstr)) {
PrintAndLogEx(ERR, "`%s` is not a string", name);
return NULL;
}
const char *cstr = json_string_value(jstr);
if (strlen(cstr) == 0)
return NULL;
return cstr;
}
bool aidCompare(const char *aidlarge, const char *aidsmall) {
if (strcmp(aidlarge, aidsmall) == 0)
return true;
2019-11-08 19:00:21 +08:00
2019-11-05 01:54:23 +08:00
if (strlen(aidlarge) > strlen(aidsmall))
if (strncmp(aidlarge, aidsmall, strlen(aidsmall)) == 0)
return true;
2019-11-08 19:00:21 +08:00
2019-11-05 01:54:23 +08:00
return false;
}
2019-11-05 03:18:37 +08:00
bool AIDGetFromElm(json_t *data, uint8_t *aid, size_t aidmaxlen, int *aidlen) {
*aidlen = 0;
const char *hexaid = jsonStrGet(data, "AID");
if (hexaid == NULL || strlen(hexaid) == 0)
return false;
2019-11-08 19:00:21 +08:00
2019-11-05 03:18:37 +08:00
int res = param_gethex_to_eol(hexaid, 0, aid, aidmaxlen, aidlen);
if (res)
return false;
return true;
}
int PrintAIDDescription(json_t *xroot, char *aid, bool verbose) {
2019-11-05 01:54:23 +08:00
int retval = PM3_SUCCESS;
2019-11-08 19:00:21 +08:00
json_t *root = xroot;
if (root == NULL)
root = AIDSearchInit(verbose);
2019-11-05 03:18:37 +08:00
if (root == NULL)
2019-11-05 01:54:23 +08:00
goto out;
2019-11-08 19:00:21 +08:00
2019-11-05 03:18:37 +08:00
json_t *elm = NULL;
2019-11-05 05:21:02 +08:00
int maxaidlen = 0;
2019-11-05 03:18:37 +08:00
for (int elmindx = 0; elmindx < json_array_size(root); elmindx++) {
json_t *data = AIDSearchGetElm(root, elmindx);
2019-11-05 01:54:23 +08:00
if (data == NULL)
2019-11-05 03:18:37 +08:00
continue;
2019-11-05 05:21:02 +08:00
const char *dictaid = jsonStrGet(data, "AID");
if (aidCompare(aid, dictaid)) { // dictaid may be less length than requested aid
if (maxaidlen < strlen(dictaid) && strlen(dictaid) <= strlen(aid)) {
maxaidlen = strlen(dictaid);
elm = data;
}
2019-11-05 03:18:37 +08:00
}
2019-11-05 01:54:23 +08:00
}
2019-11-08 19:00:21 +08:00
2019-11-05 03:18:37 +08:00
if (elm == NULL)
goto out;
2019-11-08 19:00:21 +08:00
2019-11-05 01:54:23 +08:00
// print here
2019-11-05 03:18:37 +08:00
const char *vaid = jsonStrGet(elm, "AID");
const char *vendor = jsonStrGet(elm, "Vendor");
const char *name = jsonStrGet(elm, "Name");
const char *country = jsonStrGet(elm, "Country");
const char *description = jsonStrGet(elm, "Description");
const char *type = jsonStrGet(elm, "Type");
2019-11-05 01:54:23 +08:00
if (!verbose) {
PrintAndLogEx(SUCCESS, "AID %s | %s | %s", vaid, vendor, name);
} else {
2019-11-05 02:20:42 +08:00
PrintAndLogEx(SUCCESS, "Input AID: %s", aid);
2019-11-05 01:54:23 +08:00
if (aid)
2019-11-05 02:15:09 +08:00
PrintAndLogEx(SUCCESS, "Found AID: %s", vaid);
2019-11-05 01:54:23 +08:00
if (vendor)
2019-11-05 02:15:09 +08:00
PrintAndLogEx(SUCCESS, "Vendor: %s", vendor);
2019-11-05 01:54:23 +08:00
if (type)
2019-11-05 02:15:09 +08:00
PrintAndLogEx(SUCCESS, "Type: %s", type);
2019-11-05 01:54:23 +08:00
if (name)
2019-11-05 02:15:09 +08:00
PrintAndLogEx(SUCCESS, "Name: %s", name);
2019-11-05 01:54:23 +08:00
if (country)
2019-11-05 02:15:09 +08:00
PrintAndLogEx(SUCCESS, "Country: %s", country);
2019-11-05 01:54:23 +08:00
if (description)
2019-11-05 02:15:09 +08:00
PrintAndLogEx(SUCCESS, "Description: %s", description);
2019-11-05 01:54:23 +08:00
}
2019-11-08 19:00:21 +08:00
2019-11-05 01:54:23 +08:00
out:
if (xroot == NULL)
AIDSearchFree(root);
2019-11-05 01:54:23 +08:00
return retval;
}
int PrintAIDDescriptionBuf(json_t *root, uint8_t *aid, size_t aidlen, bool verbose) {
return PrintAIDDescription(root, sprint_hex_inrow(aid, aidlen), verbose);
2019-11-05 03:18:37 +08:00
}
2019-11-05 01:54:23 +08:00