subbrute_scene_load_file.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. #include "../subbrute_i.h"
  2. #include "subbrute_scene.h"
  3. #define TAG "SubBruteSceneLoadFile"
  4. void subbrute_scene_load_file_on_enter(void* context) {
  5. furi_assert(context);
  6. SubBruteState* instance = (SubBruteState*)context;
  7. // Input events and views are managed by file_browser
  8. FuriString* app_folder;
  9. FuriString* load_path;
  10. load_path = furi_string_alloc();
  11. app_folder = furi_string_alloc_set(SUBBRUTE_PATH);
  12. DialogsFileBrowserOptions browser_options;
  13. dialog_file_browser_set_basic_options(&browser_options, SUBBRUTE_FILE_EXT, &I_sub1_10px);
  14. SubBruteFileResult load_result = SubBruteFileResultUnknown;
  15. // TODO: DELETE IT
  16. #ifdef SUBBRUTE_FAST_TRACK
  17. bool res = true;
  18. furi_string_printf(load_path, "%s", "/ext/subghz/princeton.sub");
  19. #else
  20. bool res =
  21. dialog_file_browser_show(instance->dialogs, load_path, app_folder, &browser_options);
  22. #endif
  23. #ifdef FURI_DEBUG
  24. FURI_LOG_D(
  25. TAG,
  26. "load_path: %s, app_folder: %s",
  27. furi_string_get_cstr(load_path),
  28. furi_string_get_cstr(app_folder));
  29. #endif
  30. if(res) {
  31. load_result =
  32. subbrute_device_load_from_file(instance->device, furi_string_get_cstr(load_path));
  33. if(load_result == SubBruteFileResultOk) {
  34. uint8_t extra_repeats = subbrute_main_view_get_extra_repeats(instance->view_main);
  35. load_result = subbrute_device_attack_set(
  36. instance->device, SubBruteAttackLoadFile, extra_repeats);
  37. if(load_result == SubBruteFileResultOk) {
  38. if(!subbrute_worker_init_file_attack(
  39. instance->worker,
  40. instance->device->current_step,
  41. instance->device->current_step,
  42. instance->device->file_key,
  43. instance->device->file_protocol_info,
  44. extra_repeats)) {
  45. furi_crash("Invalid attack set!");
  46. }
  47. // Ready to run!
  48. FURI_LOG_I(TAG, "Ready to run");
  49. res = true;
  50. }
  51. }
  52. if(load_result == SubBruteFileResultOk) {
  53. scene_manager_next_scene(instance->scene_manager, SubBruteSceneLoadSelect);
  54. } else {
  55. FURI_LOG_E(TAG, "Returned error: %d", load_result);
  56. FuriString* dialog_msg;
  57. dialog_msg = furi_string_alloc();
  58. furi_string_cat_printf(
  59. dialog_msg, "Cannot parse\nfile: %s", subbrute_device_error_get_desc(load_result));
  60. dialog_message_show_storage_error(instance->dialogs, furi_string_get_cstr(dialog_msg));
  61. furi_string_free(dialog_msg);
  62. scene_manager_search_and_switch_to_previous_scene(
  63. instance->scene_manager, SubBruteSceneStart);
  64. }
  65. } else {
  66. scene_manager_search_and_switch_to_previous_scene(
  67. instance->scene_manager, SubBruteSceneStart);
  68. }
  69. furi_string_free(app_folder);
  70. furi_string_free(load_path);
  71. }
  72. void subbrute_scene_load_file_on_exit(void* context) {
  73. UNUSED(context);
  74. }
  75. bool subbrute_scene_load_file_on_event(void* context, SceneManagerEvent event) {
  76. UNUSED(context);
  77. UNUSED(event);
  78. return false;
  79. }