picopass_scene_card_menu.c 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. #include "../picopass_i.h"
  2. enum SubmenuIndex {
  3. SubmenuIndexSave,
  4. SubmenuIndexSaveAsLF,
  5. SubmenuIndexSaveAsSeader,
  6. SubmenuIndexChangeKey,
  7. SubmenuIndexWrite,
  8. SubmenuIndexEmulate,
  9. SubmenuIndexSavePartial,
  10. };
  11. void picopass_scene_card_menu_submenu_callback(void* context, uint32_t index) {
  12. Picopass* picopass = context;
  13. view_dispatcher_send_custom_event(picopass->view_dispatcher, index);
  14. }
  15. void picopass_scene_card_menu_on_enter(void* context) {
  16. Picopass* picopass = context;
  17. Submenu* submenu = picopass->submenu;
  18. PicopassPacs* pacs = &picopass->dev->dev_data.pacs;
  19. PicopassBlock* AA1 = picopass->dev->dev_data.AA1;
  20. bool sio = 0x30 == AA1[PICOPASS_ICLASS_PACS_CFG_BLOCK_INDEX].data[0];
  21. bool no_key = picopass_is_memset(pacs->key, 0x00, PICOPASS_BLOCK_LEN);
  22. bool secured = (AA1[PICOPASS_CONFIG_BLOCK_INDEX].data[7] & PICOPASS_FUSE_CRYPT10) !=
  23. PICOPASS_FUSE_CRYPT0;
  24. if(!secured) {
  25. submenu_add_item(
  26. submenu, "Save", SubmenuIndexSave, picopass_scene_card_menu_submenu_callback, picopass);
  27. } else if(no_key) {
  28. if(sio) {
  29. submenu_add_item(
  30. submenu,
  31. "Save",
  32. SubmenuIndexSave,
  33. picopass_scene_card_menu_submenu_callback,
  34. picopass);
  35. submenu_add_item(
  36. submenu,
  37. "Save in Seader fmt",
  38. SubmenuIndexSaveAsSeader,
  39. picopass_scene_card_menu_submenu_callback,
  40. picopass);
  41. } else {
  42. submenu_add_item(
  43. submenu,
  44. "Save Partial",
  45. SubmenuIndexSavePartial,
  46. picopass_scene_card_menu_submenu_callback,
  47. picopass);
  48. }
  49. } else {
  50. submenu_add_item(
  51. submenu, "Save", SubmenuIndexSave, picopass_scene_card_menu_submenu_callback, picopass);
  52. submenu_add_item(
  53. submenu,
  54. "Save as LFRFID",
  55. SubmenuIndexSaveAsLF,
  56. picopass_scene_card_menu_submenu_callback,
  57. picopass);
  58. if(pacs->sio) { // SR
  59. submenu_add_item(
  60. submenu,
  61. "Save in Seader fmt",
  62. SubmenuIndexSaveAsSeader,
  63. picopass_scene_card_menu_submenu_callback,
  64. picopass);
  65. }
  66. submenu_add_item(
  67. submenu,
  68. "Write",
  69. SubmenuIndexWrite,
  70. picopass_scene_card_menu_submenu_callback,
  71. picopass);
  72. submenu_add_item(
  73. submenu,
  74. "Emulate",
  75. SubmenuIndexEmulate,
  76. picopass_scene_card_menu_submenu_callback,
  77. picopass);
  78. submenu_add_item(
  79. submenu,
  80. "Change Key",
  81. SubmenuIndexChangeKey,
  82. picopass_scene_card_menu_submenu_callback,
  83. picopass);
  84. }
  85. submenu_set_selected_item(
  86. picopass->submenu,
  87. scene_manager_get_scene_state(picopass->scene_manager, PicopassSceneCardMenu));
  88. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewMenu);
  89. }
  90. bool picopass_scene_card_menu_on_event(void* context, SceneManagerEvent event) {
  91. Picopass* picopass = context;
  92. bool consumed = false;
  93. if(event.type == SceneManagerEventTypeCustom) {
  94. if(event.event == SubmenuIndexSave) {
  95. scene_manager_set_scene_state(
  96. picopass->scene_manager, PicopassSceneCardMenu, SubmenuIndexSave);
  97. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  98. picopass->dev->format = PicopassDeviceSaveFormatHF;
  99. consumed = true;
  100. } else if(event.event == SubmenuIndexSavePartial) {
  101. scene_manager_set_scene_state(
  102. picopass->scene_manager, PicopassSceneCardMenu, SubmenuIndexSave);
  103. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  104. picopass->dev->format = PicopassDeviceSaveFormatPartial;
  105. consumed = true;
  106. } else if(event.event == SubmenuIndexSaveAsSeader) {
  107. scene_manager_set_scene_state(
  108. picopass->scene_manager, PicopassSceneCardMenu, event.event);
  109. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  110. picopass->dev->format = PicopassDeviceSaveFormatSeader;
  111. consumed = true;
  112. } else if(event.event == SubmenuIndexSaveAsLF) {
  113. scene_manager_set_scene_state(
  114. picopass->scene_manager, PicopassSceneCardMenu, SubmenuIndexSaveAsLF);
  115. picopass->dev->format = PicopassDeviceSaveFormatLF;
  116. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  117. consumed = true;
  118. } else if(event.event == SubmenuIndexWrite) {
  119. scene_manager_next_scene(picopass->scene_manager, PicopassSceneWriteCard);
  120. consumed = true;
  121. } else if(event.event == SubmenuIndexEmulate) {
  122. scene_manager_next_scene(picopass->scene_manager, PicopassSceneEmulate);
  123. consumed = true;
  124. } else if(event.event == SubmenuIndexChangeKey) {
  125. scene_manager_set_scene_state(
  126. picopass->scene_manager, PicopassSceneCardMenu, SubmenuIndexChangeKey);
  127. scene_manager_next_scene(picopass->scene_manager, PicopassSceneKeyMenu);
  128. consumed = true;
  129. }
  130. } else if(event.type == SceneManagerEventTypeBack) {
  131. consumed = scene_manager_search_and_switch_to_previous_scene(
  132. picopass->scene_manager, PicopassSceneStart);
  133. }
  134. return consumed;
  135. }
  136. void picopass_scene_card_menu_on_exit(void* context) {
  137. Picopass* picopass = context;
  138. submenu_reset(picopass->submenu);
  139. }