From c81a80dc9631071f854e03129de389df788ac7d1 Mon Sep 17 00:00:00 2001 From: iceman1001 Date: Wed, 20 May 2015 21:44:22 +0200 Subject: [PATCH] FIX: made the authentication part a bit clearer. It now uses two booleans to seperate which type of authentication was requested from user. --- client/cmdhfmfu.c | 34 ++++++++++++++++++---------------- 1 file changed, 18 insertions(+), 16 deletions(-) diff --git a/client/cmdhfmfu.c b/client/cmdhfmfu.c index f3e03567c..667392809 100644 --- a/client/cmdhfmfu.c +++ b/client/cmdhfmfu.c @@ -18,7 +18,7 @@ #define MAX_UL_BLOCKS 0x0f #define MAX_ULC_BLOCKS 0x2b -#define MAX_ULEV1a_BLOCKS 0x13 +#define MAX_ULEV1a_BLOCKS 0x13 #define MAX_ULEV1b_BLOCKS 0x28 #define MAX_NTAG_203 0x29 #define MAX_NTAG_210 0x13 @@ -620,12 +620,13 @@ int CmdHF14AMfUInfo(const char *Cmd){ int status; bool errors = false; bool hasAuthKey = false; + bool hasPwdKey = false; bool locked = false; uint8_t cmdp = 0; uint8_t datalen = 0; uint8_t authenticationkey[16] = {0x00}; uint8_t pack[4] = {0,0,0,0}; - int len=0; + int len = 0; while(param_getchar(Cmd, cmdp) != 0x00) { @@ -641,7 +642,7 @@ int CmdHF14AMfUInfo(const char *Cmd){ if ( !datalen ) { memcpy(authenticationkey, data, 4); cmdp += 2; - hasAuthKey = true; + hasPwdKey = true; break; } // UL-C size key @@ -672,24 +673,24 @@ int CmdHF14AMfUInfo(const char *Cmd){ PrintAndLog("-------------------------------------------------------------"); ul_print_type(tagtype, 6); + if (!ul_select(&card)) return 0; + if ( hasAuthKey && (tagtype & UL_C)) { //will select card automatically and close connection on error if (!ulc_authentication(authenticationkey, false)) { - PrintAndLog("Error: Authentication Failed UL-C"); - return 0; - } - } else { - if ( !ul_select(&card) ) return 0; - - if (hasAuthKey) { - len = ulev1_requestAuthentication(authenticationkey, pack, sizeof(pack)); - if (len < 1) { - ul_switch_off_field(); - PrintAndLog("Error: Authentication Failed UL-EV1/NTAG"); - return 0; - } + PrintAndLog("Error: Authentication Failed UL-C"); + return 0; } } + + if ( hasPwdKey ) { + len = ulev1_requestAuthentication(authenticationkey, pack, sizeof(pack)); + if (len < 1) { + ul_switch_off_field(); + PrintAndLog("Error: Authentication Failed UL-EV1/NTAG"); + return 0; + } + } // read pages 0,1,2,3 (should read 4pages) status = ul_read(0, data, sizeof(data)); @@ -698,6 +699,7 @@ int CmdHF14AMfUInfo(const char *Cmd){ PrintAndLog("Error: tag didn't answer to READ"); return status; } + if (status == 16) { ul_print_default(data); ndef_print_CC(data+12);