mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2024-11-24 05:23:06 +00:00
820afd2aec
* Mifare Classic 1/4K, 4/7b uid, NFC-A: NFC-A is not complete yet, as there are no 4b uid tests. Also, Mifare Classic tests don't cover the key cache yet. * NFC unit tests require access to the NFC app * Made nfc_device_save accept full path as an argument * Move from cstrs to furi strings and fix logic * nfc tests: fix memory leak * nfc: add mf_classic_get_total_blocks() to API * nfc tests: simplify nfc tests * nfc: fix memory leak in shadow file saving * nfc: fix set uid scene * nfc: fix saving files * nfc: fix preload nfc file path * nfc: remove comments Co-authored-by: Sergey Gavrilov <who.just.the.doctor@gmail.com> Co-authored-by: gornekich <n.gorbadey@gmail.com> Co-authored-by: あく <alleteam@gmail.com>
93 lines
3.3 KiB
C
93 lines
3.3 KiB
C
#include "../nfc_i.h"
|
|
#include <lib/toolbox/random_name.h>
|
|
#include <gui/modules/validators.h>
|
|
#include <toolbox/path.h>
|
|
#include <dolphin/dolphin.h>
|
|
|
|
void nfc_scene_save_name_text_input_callback(void* context) {
|
|
Nfc* nfc = context;
|
|
|
|
view_dispatcher_send_custom_event(nfc->view_dispatcher, NfcCustomEventTextInputDone);
|
|
}
|
|
|
|
void nfc_scene_save_name_on_enter(void* context) {
|
|
Nfc* nfc = context;
|
|
|
|
// Setup view
|
|
TextInput* text_input = nfc->text_input;
|
|
bool dev_name_empty = false;
|
|
if(!strcmp(nfc->dev->dev_name, "")) {
|
|
set_random_name(nfc->text_store, sizeof(nfc->text_store));
|
|
dev_name_empty = true;
|
|
} else {
|
|
nfc_text_store_set(nfc, nfc->dev->dev_name);
|
|
}
|
|
text_input_set_header_text(text_input, "Name the card");
|
|
text_input_set_result_callback(
|
|
text_input,
|
|
nfc_scene_save_name_text_input_callback,
|
|
nfc,
|
|
nfc->text_store,
|
|
NFC_DEV_NAME_MAX_LEN,
|
|
dev_name_empty);
|
|
|
|
FuriString* folder_path;
|
|
folder_path = furi_string_alloc();
|
|
|
|
if(furi_string_end_with(nfc->dev->load_path, NFC_APP_EXTENSION)) {
|
|
path_extract_dirname(furi_string_get_cstr(nfc->dev->load_path), folder_path);
|
|
} else {
|
|
furi_string_set(folder_path, NFC_APP_FOLDER);
|
|
}
|
|
|
|
ValidatorIsFile* validator_is_file = validator_is_file_alloc_init(
|
|
furi_string_get_cstr(folder_path), NFC_APP_EXTENSION, nfc->dev->dev_name);
|
|
text_input_set_validator(text_input, validator_is_file_callback, validator_is_file);
|
|
|
|
view_dispatcher_switch_to_view(nfc->view_dispatcher, NfcViewTextInput);
|
|
|
|
furi_string_free(folder_path);
|
|
}
|
|
|
|
bool nfc_scene_save_name_on_event(void* context, SceneManagerEvent event) {
|
|
Nfc* nfc = context;
|
|
bool consumed = false;
|
|
|
|
if(event.type == SceneManagerEventTypeCustom) {
|
|
if(event.event == NfcCustomEventTextInputDone) {
|
|
if(strcmp(nfc->dev->dev_name, "")) {
|
|
nfc_device_delete(nfc->dev, true);
|
|
}
|
|
if(scene_manager_has_previous_scene(nfc->scene_manager, NfcSceneSetUid)) {
|
|
nfc->dev->dev_data.nfc_data = nfc->dev_edit_data;
|
|
}
|
|
strlcpy(nfc->dev->dev_name, nfc->text_store, strlen(nfc->text_store) + 1);
|
|
if(nfc_save_file(nfc)) {
|
|
scene_manager_next_scene(nfc->scene_manager, NfcSceneSaveSuccess);
|
|
if(!scene_manager_has_previous_scene(nfc->scene_manager, NfcSceneSavedMenu)) {
|
|
// Nothing, do not count editing as saving
|
|
} else if(scene_manager_has_previous_scene(nfc->scene_manager, NfcSceneSetType)) {
|
|
DOLPHIN_DEED(DolphinDeedNfcAddSave);
|
|
} else {
|
|
DOLPHIN_DEED(DolphinDeedNfcSave);
|
|
}
|
|
consumed = true;
|
|
} else {
|
|
consumed = scene_manager_search_and_switch_to_previous_scene(
|
|
nfc->scene_manager, NfcSceneStart);
|
|
}
|
|
}
|
|
}
|
|
return consumed;
|
|
}
|
|
|
|
void nfc_scene_save_name_on_exit(void* context) {
|
|
Nfc* nfc = context;
|
|
|
|
// Clear view
|
|
void* validator_context = text_input_get_validator_callback_context(nfc->text_input);
|
|
text_input_set_validator(nfc->text_input, NULL, NULL);
|
|
validator_is_file_free(validator_context);
|
|
|
|
text_input_reset(nfc->text_input);
|
|
}
|