mirror of
https://github.com/Next-Flip/Momentum-Firmware.git
synced 2026-05-24 05:34:45 -07:00
[FL-3787] NFC: Slix privacy password reveal and Desfire detect fix (#3504)
* slix: fix incorrect default privacy passwords * slix poller: add check privacy password state * mf desfire: change detect algorithm * mf desfire: change detection algorithm to check master key version * mf desfire: change assert to check * Update api symbols and cleanup code Co-authored-by: あく <alleteam@gmail.com>
This commit is contained in:
@@ -225,8 +225,8 @@ static bool mf_desfire_poller_detect(NfcGenericEvent event, void* context) {
|
||||
bool protocol_detected = false;
|
||||
|
||||
if(iso14443_4a_event->type == Iso14443_4aPollerEventTypeReady) {
|
||||
MfDesfireVersion version = {};
|
||||
const MfDesfireError error = mf_desfire_poller_read_version(instance, &version);
|
||||
MfDesfireKeyVersion key_version = {0};
|
||||
MfDesfireError error = mf_desfire_poller_read_key_version(instance, 0, &key_version);
|
||||
protocol_detected = (error == MfDesfireErrorNone);
|
||||
}
|
||||
|
||||
|
||||
@@ -91,6 +91,21 @@ MfDesfireError
|
||||
MfDesfireError
|
||||
mf_desfire_poller_read_key_settings(MfDesfirePoller* instance, MfDesfireKeySettings* data);
|
||||
|
||||
/**
|
||||
* @brief Read key version on MfDesfire card.
|
||||
*
|
||||
* Must ONLY be used inside the callback function.
|
||||
*
|
||||
* @param[in, out] instance pointer to the instance to be used in the transaction.
|
||||
* @param[out] key_num key number.
|
||||
* @param[in] data pointer to the MfDesfireKeyVersion structure to be filled with key version data.
|
||||
* @return MfDesfireErrorNone on success, an error code on failure.
|
||||
*/
|
||||
MfDesfireError mf_desfire_poller_read_key_version(
|
||||
MfDesfirePoller* instance,
|
||||
uint8_t key_num,
|
||||
MfDesfireKeyVersion* data);
|
||||
|
||||
/**
|
||||
* @brief Read key versions on MfDesfire card.
|
||||
*
|
||||
|
||||
@@ -139,6 +139,28 @@ MfDesfireError
|
||||
return error;
|
||||
}
|
||||
|
||||
MfDesfireError mf_desfire_poller_read_key_version(
|
||||
MfDesfirePoller* instance,
|
||||
uint8_t key_num,
|
||||
MfDesfireKeyVersion* data) {
|
||||
furi_check(instance);
|
||||
furi_check(data);
|
||||
|
||||
bit_buffer_set_size_bytes(instance->input_buffer, sizeof(uint8_t) * 2);
|
||||
bit_buffer_set_byte(instance->input_buffer, 0, MF_DESFIRE_CMD_GET_KEY_VERSION);
|
||||
bit_buffer_set_byte(instance->input_buffer, 1, key_num);
|
||||
|
||||
MfDesfireError error =
|
||||
mf_desfire_send_chunks(instance, instance->input_buffer, instance->result_buffer);
|
||||
if(error == MfDesfireErrorNone) {
|
||||
if(!mf_desfire_key_version_parse(data, instance->result_buffer)) {
|
||||
error = MfDesfireErrorProtocol;
|
||||
}
|
||||
}
|
||||
|
||||
return error;
|
||||
}
|
||||
|
||||
MfDesfireError mf_desfire_poller_read_key_versions(
|
||||
MfDesfirePoller* instance,
|
||||
SimpleArray* data,
|
||||
@@ -148,22 +170,11 @@ MfDesfireError mf_desfire_poller_read_key_versions(
|
||||
|
||||
simple_array_init(data, count);
|
||||
|
||||
bit_buffer_set_size_bytes(instance->input_buffer, sizeof(uint8_t) * 2);
|
||||
bit_buffer_set_byte(instance->input_buffer, 0, MF_DESFIRE_CMD_GET_KEY_VERSION);
|
||||
|
||||
MfDesfireError error = MfDesfireErrorNone;
|
||||
|
||||
for(uint32_t i = 0; i < count; ++i) {
|
||||
bit_buffer_set_byte(instance->input_buffer, 1, i);
|
||||
|
||||
error = mf_desfire_send_chunks(instance, instance->input_buffer, instance->result_buffer);
|
||||
|
||||
error = mf_desfire_poller_read_key_version(instance, i, simple_array_get(data, i));
|
||||
if(error != MfDesfireErrorNone) break;
|
||||
|
||||
if(!mf_desfire_key_version_parse(simple_array_get(data, i), instance->result_buffer)) {
|
||||
error = MfDesfireErrorProtocol;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
return error;
|
||||
|
||||
Reference in New Issue
Block a user