subbrute_scene_load_file.c 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. #include "../subbrute_i.h"
  2. #include "subbrute_scene.h"
  3. #define TAG "SubBruteSceneLoadFile"
  4. //void subbrute_scene_load_file_callback(SubBruteCustomEvent event, void* context) {
  5. //// furi_assert(context);
  6. ////
  7. //// SubBruteState* instance = (SubBruteState*)context;
  8. //// view_dispatcher_send_custom_event(instance->view_dispatcher, event);
  9. //}
  10. void subbrute_scene_load_file_on_enter(void* context) {
  11. furi_assert(context);
  12. SubBruteState* instance = (SubBruteState*)context;
  13. // Input events and views are managed by file_browser
  14. FuriString* app_folder;
  15. FuriString* load_path;
  16. load_path = furi_string_alloc();
  17. app_folder = furi_string_alloc_set(SUBBRUTE_PATH);
  18. DialogsFileBrowserOptions browser_options;
  19. dialog_file_browser_set_basic_options(&browser_options, SUBBRUTE_FILE_EXT, &I_sub1_10px);
  20. SubBruteFileResult load_result = SubBruteFileResultUnknown;
  21. bool res =
  22. dialog_file_browser_show(instance->dialogs, load_path, app_folder, &browser_options);
  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. load_result = subbrute_device_attack_set(instance->device, SubBruteAttackLoadFile);
  35. if(load_result == SubBruteFileResultOk) {
  36. if(!subbrute_worker_init_file_attack(
  37. instance->worker,
  38. instance->device->key_index,
  39. instance->device->load_index,
  40. instance->device->file_key,
  41. instance->device->file_protocol_info)) {
  42. furi_crash("Invalid attack set!");
  43. }
  44. // Ready to run!
  45. FURI_LOG_I(TAG, "Ready to run");
  46. res = true;
  47. }
  48. }
  49. if(load_result == SubBruteFileResultOk) {
  50. scene_manager_next_scene(instance->scene_manager, SubBruteSceneLoadSelect);
  51. } else {
  52. FURI_LOG_E(TAG, "Returned error: %d", load_result);
  53. FuriString* dialog_msg;
  54. dialog_msg = furi_string_alloc();
  55. furi_string_cat_printf(
  56. dialog_msg, "Cannot parse\nfile: %s", subbrute_device_error_get_desc(load_result));
  57. dialog_message_show_storage_error(instance->dialogs, furi_string_get_cstr(dialog_msg));
  58. furi_string_free(dialog_msg);
  59. scene_manager_search_and_switch_to_previous_scene(
  60. instance->scene_manager, SubBruteSceneStart);
  61. }
  62. } else {
  63. scene_manager_search_and_switch_to_previous_scene(
  64. instance->scene_manager, SubBruteSceneStart);
  65. }
  66. furi_string_free(app_folder);
  67. furi_string_free(load_path);
  68. }
  69. void subbrute_scene_load_file_on_exit(void* context) {
  70. UNUSED(context);
  71. }
  72. bool subbrute_scene_load_file_on_event(void* context, SceneManagerEvent event) {
  73. UNUSED(context);
  74. UNUSED(event);
  75. return false;
  76. }