adds write condition check in unlock_card()
This commit is contained in:
parent
f7b9b0eafa
commit
db957aabdf
1 changed files with 12 additions and 10 deletions
|
@ -248,7 +248,7 @@ authenticate(uint32_t uiBlock)
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
unlock_card(void)
|
unlock_card(bool write)
|
||||||
{
|
{
|
||||||
// Configure the CRC
|
// Configure the CRC
|
||||||
if (nfc_device_set_property_bool(pnd, NP_HANDLE_CRC, false) < 0) {
|
if (nfc_device_set_property_bool(pnd, NP_HANDLE_CRC, false) < 0) {
|
||||||
|
@ -266,8 +266,10 @@ unlock_card(void)
|
||||||
// now send unlock
|
// now send unlock
|
||||||
if (!transmit_bits(abtUnlock1, 7)) {
|
if (!transmit_bits(abtUnlock1, 7)) {
|
||||||
printf("Warning: Unlock command [1/2]: failed / not acknowledged.\n");
|
printf("Warning: Unlock command [1/2]: failed / not acknowledged.\n");
|
||||||
printf("Trying to rewrite block 0 on a gen2 tag.\n");
|
if (write) {
|
||||||
magic2 = true;
|
printf("Trying to rewrite block 0 on a gen2 tag.\n");
|
||||||
|
magic2 = true;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (transmit_bytes(abtUnlock2, 1)) {
|
if (transmit_bytes(abtUnlock2, 1)) {
|
||||||
printf("Card unlocked\n");
|
printf("Card unlocked\n");
|
||||||
|
@ -333,7 +335,7 @@ get_rats(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
read_card(int read_unlocked)
|
read_card(bool read_unlocked)
|
||||||
{
|
{
|
||||||
int32_t iBlock;
|
int32_t iBlock;
|
||||||
bool bFailure = false;
|
bool bFailure = false;
|
||||||
|
@ -347,7 +349,7 @@ read_card(int read_unlocked)
|
||||||
read_unlocked = 0;
|
read_unlocked = 0;
|
||||||
} else {
|
} else {
|
||||||
//If User has requested an unlocked read, but we're unable to unlock the card, we'll error out.
|
//If User has requested an unlocked read, but we're unable to unlock the card, we'll error out.
|
||||||
if (!unlock_card()) {
|
if (!unlock_card(false)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -420,7 +422,7 @@ read_card(int read_unlocked)
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool
|
static bool
|
||||||
write_card(int write_block_zero)
|
write_card(bool write_block_zero)
|
||||||
{
|
{
|
||||||
uint32_t uiBlock;
|
uint32_t uiBlock;
|
||||||
bool bFailure = false;
|
bool bFailure = false;
|
||||||
|
@ -429,7 +431,7 @@ write_card(int write_block_zero)
|
||||||
//Determine if we have to unlock the card
|
//Determine if we have to unlock the card
|
||||||
if (write_block_zero) {
|
if (write_block_zero) {
|
||||||
if (!magic2 && !magic3) {
|
if (!magic2 && !magic3) {
|
||||||
if (!unlock_card()) {
|
if (!unlock_card(true)) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -663,7 +665,7 @@ main(int argc, const char *argv[])
|
||||||
uint8_t _tag_uid[4];
|
uint8_t _tag_uid[4];
|
||||||
uint8_t *tag_uid = _tag_uid;
|
uint8_t *tag_uid = _tag_uid;
|
||||||
|
|
||||||
int unlock = 0;
|
bool unlock = false;
|
||||||
|
|
||||||
if (argc < 2) {
|
if (argc < 2) {
|
||||||
print_usage(argv[0]);
|
print_usage(argv[0]);
|
||||||
|
@ -678,7 +680,7 @@ main(int argc, const char *argv[])
|
||||||
if (strcmp(command, "r") == 0 || strcmp(command, "R") == 0) {
|
if (strcmp(command, "r") == 0 || strcmp(command, "R") == 0) {
|
||||||
atAction = ACTION_READ;
|
atAction = ACTION_READ;
|
||||||
if (strcmp(command, "R") == 0)
|
if (strcmp(command, "R") == 0)
|
||||||
unlock = 1;
|
unlock = true;
|
||||||
bUseKeyA = tolower((int)((unsigned char) * (argv[2]))) == 'a';
|
bUseKeyA = tolower((int)((unsigned char) * (argv[2]))) == 'a';
|
||||||
bTolerateFailures = tolower((int)((unsigned char) * (argv[2]))) != (int)((unsigned char) * (argv[2]));
|
bTolerateFailures = tolower((int)((unsigned char) * (argv[2]))) != (int)((unsigned char) * (argv[2]));
|
||||||
bUseKeyFile = (argc > 5) && strcmp(argv[5], "v");
|
bUseKeyFile = (argc > 5) && strcmp(argv[5], "v");
|
||||||
|
@ -686,7 +688,7 @@ main(int argc, const char *argv[])
|
||||||
} else if (strcmp(command, "w") == 0 || strcmp(command, "W") == 0 || strcmp(command, "f") == 0) {
|
} else if (strcmp(command, "w") == 0 || strcmp(command, "W") == 0 || strcmp(command, "f") == 0) {
|
||||||
atAction = ACTION_WRITE;
|
atAction = ACTION_WRITE;
|
||||||
if (strcmp(command, "W") == 0)
|
if (strcmp(command, "W") == 0)
|
||||||
unlock = 1;
|
unlock = true;
|
||||||
bFormatCard = (strcmp(command, "f") == 0);
|
bFormatCard = (strcmp(command, "f") == 0);
|
||||||
bUseKeyA = tolower((int)((unsigned char) * (argv[2]))) == 'a';
|
bUseKeyA = tolower((int)((unsigned char) * (argv[2]))) == 'a';
|
||||||
bTolerateFailures = tolower((int)((unsigned char) * (argv[2]))) != (int)((unsigned char) * (argv[2]));
|
bTolerateFailures = tolower((int)((unsigned char) * (argv[2]))) != (int)((unsigned char) * (argv[2]));
|
||||||
|
|
Loading…
Reference in a new issue