From 69049a6621c707b04c09bf9b1748bb544338d1e1 Mon Sep 17 00:00:00 2001 From: Matt Moran Date: Fri, 7 Jan 2022 19:31:36 +1300 Subject: [PATCH] Remove incorrect AID validation --- client/src/cmdhfgallagher.c | 35 ++++++----------------------------- common/generator.c | 8 -------- 2 files changed, 6 insertions(+), 37 deletions(-) diff --git a/client/src/cmdhfgallagher.c b/client/src/cmdhfgallagher.c index e95e25bcc..f3085ed3b 100644 --- a/client/src/cmdhfgallagher.c +++ b/client/src/cmdhfgallagher.c @@ -758,7 +758,6 @@ static int CmdGallagherReader(const char *cmd) { CLIGetHexWithReturn(ctx, 1, aid_buf, &aid_len); if (aid_len > 0 && aid_len != 3) HFGAL_RET_ERR(PM3_EINVARG, "--aid must be 3 bytes"); - reverse_aid(aid_buf); // PM3 displays AIDs backwards uint32_t aid = DesfireAIDByteToUint(aid_buf); @@ -832,19 +831,11 @@ static int CmdGallagherClone(const char *cmd) { int aid_len = 0; uint8_t aid_buf[3] = {0}; - uint32_t aid = 0; CLIGetHexWithReturn(ctx, 8, aid_buf, &aid_len); - if (aid_len > 0) { - if (aid_len != 3) - HFGAL_RET_ERR(PM3_EINVARG, "--aid must be 3 bytes"); - reverse_aid(aid_buf); // PM3 displays AIDs backwards - aid = DesfireAIDByteToUint(aid_buf); - - // Check that the AID is in the expected range - if (memcmp(aid_buf, "\xF4\x81", 2) != 0 || aid_buf[2] < 0x20 || aid_buf[2] > 0x2B) - // TODO: this should probably be a warning, but key diversification will throw an error later even if we don't - HFGAL_RET_ERR(PM3_EINVARG, "Invalid Gallagher AID %06X, expected 2?81F4, where 0 <= ? <= 0xB", aid); - } + if (aid_len > 0 && aid_len != 3) + HFGAL_RET_ERR(PM3_EINVARG, "--aid must be 3 bytes"); + reverse_aid(aid_buf); // PM3 displays AIDs backwards + uint32_t aid = DesfireAIDByteToUint(aid_buf); int site_key_len = 0; uint8_t site_key[16] = {0}; @@ -925,18 +916,11 @@ static int CmdGallagherDelete(const char *cmd) { int aid_len = 0; uint8_t aid_buf[3] = {0}; - uint32_t aid = 0; CLIGetHexWithReturn(ctx, 1, aid_buf, &aid_len); - if (aid_len != 3) HFGAL_RET_ERR(PM3_EINVARG, "--aid must be 3 bytes"); reverse_aid(aid_buf); // PM3 displays AIDs backwards - aid = DesfireAIDByteToUint(aid_buf); - - // Check that the AID is in the expected range - if (memcmp(aid_buf, "\xF4\x81", 2) != 0 || aid_buf[2] < 0x20 || aid_buf[2] > 0x2B) - // TODO: this should probably be a warning, but key diversification will throw an error later even if we don't - HFGAL_RET_ERR(PM3_EINVARG, "Invalid Gallagher AID %06X, expected 2?81F4, where 0 <= ? <= 0xB", aid); + uint32_t aid = DesfireAIDByteToUint(aid_buf); int site_key_len = 0; uint8_t site_key[16] = {0}; @@ -992,18 +976,11 @@ static int CmdGallagherDiversify(const char *cmd) { int aid_len = 0; uint8_t aid_buf[3] = {0}; - uint32_t aid = 0; CLIGetHexWithReturn(ctx, 1, aid_buf, &aid_len); - if (aid_len != 3) HFGAL_RET_ERR(PM3_EINVARG, "--aid must be 3 bytes"); reverse_aid(aid_buf); // PM3 displays AIDs backwards - aid = DesfireAIDByteToUint(aid_buf); - - // Check that the AID is in the expected range - if (memcmp(aid_buf, "\xF4\x81", 2) != 0 || aid_buf[2] < 0x20 || aid_buf[2] > 0x2B) - // TODO: this should probably be a warning, but key diversification will throw an error later even if we don't - HFGAL_RET_ERR(PM3_EINVARG, "Invalid Gallagher AID %06X, expected 2?81F4, where 0 <= ? <= 0xB", aid); + uint32_t aid = DesfireAIDByteToUint(aid_buf); int key_num = arg_get_int_def(ctx, 2, 0); diff --git a/common/generator.c b/common/generator.c index 8b259a79c..425587527 100644 --- a/common/generator.c +++ b/common/generator.c @@ -441,14 +441,6 @@ int mfdes_kdf_input_gallagher(uint8_t *uid, uint8_t uidLen, uint8_t keyNo, uint3 return PM3_EINVARG; } - // Verify the AppID is a valid Gallagher AppID - if ((aid & 0xF0FFFF) != 0x2081F4) { - if (g_debugMode) { - PrintAndLogEx(WARNING, "Invalid Gallagher AID %06X", aid); - } - return PM3_EINVARG; - } - int len = 0; // If the keyNo == 1, then omit the UID. if (keyNo != 1) {