seader_scene_sam_present.c 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. #include "../seader_i.h"
  2. enum SubmenuIndex {
  3. SubmenuIndexReadPicopass,
  4. SubmenuIndexRead14a,
  5. SubmenuIndexReadMfc,
  6. SubmenuIndexSaved,
  7. SubmenuIndexAPDURunner,
  8. SubmenuIndexSamInfo,
  9. SubmenuIndexFwVersion,
  10. };
  11. static uint8_t fwChecks = 3;
  12. void seader_scene_sam_present_submenu_callback(void* context, uint32_t index) {
  13. Seader* seader = context;
  14. view_dispatcher_send_custom_event(seader->view_dispatcher, index);
  15. }
  16. void seader_scene_sam_present_on_update(void* context) {
  17. Seader* seader = context;
  18. SeaderWorker* seader_worker = seader->worker;
  19. Submenu* submenu = seader->submenu;
  20. submenu_reset(submenu);
  21. submenu_add_item(
  22. submenu,
  23. "Read Picopass",
  24. SubmenuIndexReadPicopass,
  25. seader_scene_sam_present_submenu_callback,
  26. seader);
  27. submenu_add_item(
  28. submenu,
  29. "Read 14443A",
  30. SubmenuIndexRead14a,
  31. seader_scene_sam_present_submenu_callback,
  32. seader);
  33. submenu_add_item(
  34. submenu,
  35. "Read MFC",
  36. SubmenuIndexReadMfc,
  37. seader_scene_sam_present_submenu_callback,
  38. seader);
  39. submenu_add_item(
  40. submenu, "Saved", SubmenuIndexSaved, seader_scene_sam_present_submenu_callback, seader);
  41. if(apdu_log_check_presence(SEADER_APDU_RUNNER_FILE_NAME)) {
  42. submenu_add_item(
  43. submenu,
  44. "Run APDUs",
  45. SubmenuIndexAPDURunner,
  46. seader_scene_sam_present_submenu_callback,
  47. seader);
  48. }
  49. if(seader_worker->sam_version[0] != 0 && seader_worker->sam_version[1] != 0) {
  50. FuriString* fw_str = furi_string_alloc();
  51. furi_string_cat_printf(
  52. fw_str, "FW %d.%d", seader_worker->sam_version[0], seader_worker->sam_version[1]);
  53. submenu_add_item(
  54. submenu,
  55. furi_string_get_cstr(fw_str),
  56. SubmenuIndexFwVersion,
  57. seader_scene_sam_present_submenu_callback,
  58. seader);
  59. furi_string_free(fw_str);
  60. fwChecks = 0;
  61. }
  62. submenu_set_selected_item(
  63. submenu, scene_manager_get_scene_state(seader->scene_manager, SeaderSceneSamPresent));
  64. view_dispatcher_switch_to_view(seader->view_dispatcher, SeaderViewMenu);
  65. }
  66. void seader_scene_sam_present_on_enter(void* context) {
  67. seader_scene_sam_present_on_update(context);
  68. }
  69. bool seader_scene_sam_present_on_event(void* context, SceneManagerEvent event) {
  70. Seader* seader = context;
  71. bool consumed = false;
  72. if(event.type == SceneManagerEventTypeCustom) {
  73. if(event.event == SubmenuIndexReadPicopass) {
  74. scene_manager_set_scene_state(
  75. seader->scene_manager, SeaderSceneSamPresent, SubmenuIndexReadPicopass);
  76. scene_manager_next_scene(seader->scene_manager, SeaderSceneReadPicopass);
  77. consumed = true;
  78. } else if(event.event == SubmenuIndexRead14a) {
  79. scene_manager_set_scene_state(
  80. seader->scene_manager, SeaderSceneSamPresent, SubmenuIndexRead14a);
  81. scene_manager_next_scene(seader->scene_manager, SeaderSceneRead14a);
  82. consumed = true;
  83. } else if(event.event == SubmenuIndexReadMfc) {
  84. scene_manager_set_scene_state(
  85. seader->scene_manager, SeaderSceneSamPresent, SubmenuIndexReadMfc);
  86. scene_manager_next_scene(seader->scene_manager, SeaderSceneReadMfc);
  87. consumed = true;
  88. } else if(event.event == SubmenuIndexSamInfo) {
  89. scene_manager_set_scene_state(
  90. seader->scene_manager, SeaderSceneSamPresent, SubmenuIndexSamInfo);
  91. scene_manager_next_scene(seader->scene_manager, SeaderSceneSamInfo);
  92. consumed = true;
  93. } else if(event.event == SubmenuIndexSaved) {
  94. scene_manager_next_scene(seader->scene_manager, SeaderSceneFileSelect);
  95. consumed = true;
  96. } else if(event.event == SubmenuIndexFwVersion) {
  97. consumed = true;
  98. } else if(event.event == SeaderWorkerEventSamMissing) {
  99. scene_manager_next_scene(seader->scene_manager, SeaderSceneSamMissing);
  100. consumed = true;
  101. } else if(event.event == SubmenuIndexAPDURunner) {
  102. scene_manager_next_scene(seader->scene_manager, SeaderSceneAPDURunner);
  103. consumed = true;
  104. }
  105. } else if(event.type == SceneManagerEventTypeBack) {
  106. scene_manager_stop(seader->scene_manager);
  107. view_dispatcher_stop(seader->view_dispatcher);
  108. consumed = true;
  109. } else if(event.type == SceneManagerEventTypeTick) {
  110. SeaderWorker* seader_worker = seader->worker;
  111. if(fwChecks > 0 && seader_worker->sam_version[0] != 0 &&
  112. seader_worker->sam_version[1] != 0) {
  113. fwChecks--;
  114. seader_scene_sam_present_on_update(context);
  115. }
  116. }
  117. return consumed;
  118. }
  119. void seader_scene_sam_present_on_exit(void* context) {
  120. Seader* seader = context;
  121. submenu_reset(seader->submenu);
  122. }