subbrute_scene_load_file.c 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  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->bit_index,
  42. instance->device->key_from_file,
  43. instance->device->file_protocol_info,
  44. extra_repeats,
  45. instance->device->two_bytes)) {
  46. furi_crash("Invalid attack set!");
  47. }
  48. // Ready to run!
  49. FURI_LOG_I(TAG, "Ready to run");
  50. res = true;
  51. }
  52. }
  53. if(load_result == SubBruteFileResultOk) {
  54. scene_manager_next_scene(instance->scene_manager, SubBruteSceneLoadSelect);
  55. } else {
  56. FURI_LOG_E(TAG, "Returned error: %d", load_result);
  57. FuriString* dialog_msg;
  58. dialog_msg = furi_string_alloc();
  59. furi_string_cat_printf(
  60. dialog_msg, "Cannot parse\nfile: %s", subbrute_device_error_get_desc(load_result));
  61. dialog_message_show_storage_error(instance->dialogs, furi_string_get_cstr(dialog_msg));
  62. furi_string_free(dialog_msg);
  63. scene_manager_search_and_switch_to_previous_scene(
  64. instance->scene_manager, SubBruteSceneStart);
  65. }
  66. } else {
  67. scene_manager_search_and_switch_to_previous_scene(
  68. instance->scene_manager, SubBruteSceneStart);
  69. }
  70. furi_string_free(app_folder);
  71. furi_string_free(load_path);
  72. }
  73. void subbrute_scene_load_file_on_exit(void* context) {
  74. UNUSED(context);
  75. }
  76. bool subbrute_scene_load_file_on_event(void* context, SceneManagerEvent event) {
  77. UNUSED(context);
  78. UNUSED(event);
  79. return false;
  80. }