picopass_scene_saved_menu.c 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. #include "../picopass_i.h"
  2. enum SubmenuIndex {
  3. SubmenuIndexInfo,
  4. SubmenuIndexWrite,
  5. SubmenuIndexEmulate,
  6. SubmenuIndexRename,
  7. SubmenuIndexDelete,
  8. SubmenuIndexSaveAsLF,
  9. SubmenuIndexSaveLegacy,
  10. SubmenuIndexSaveAsSeader,
  11. };
  12. void picopass_scene_saved_menu_submenu_callback(void* context, uint32_t index) {
  13. Picopass* picopass = context;
  14. view_dispatcher_send_custom_event(picopass->view_dispatcher, index);
  15. }
  16. void picopass_scene_saved_menu_on_enter(void* context) {
  17. Picopass* picopass = context;
  18. Submenu* submenu = picopass->submenu;
  19. PicopassPacs* pacs = &picopass->dev->dev_data.pacs;
  20. PicopassBlock* card_data = picopass->dev->dev_data.card_data;
  21. bool secured = (card_data[PICOPASS_CONFIG_BLOCK_INDEX].data[7] & PICOPASS_FUSE_CRYPT10) !=
  22. PICOPASS_FUSE_CRYPT0;
  23. bool no_credential = picopass_is_memset(pacs->credential, 0x00, sizeof(pacs->credential));
  24. bool SE = card_data[PICOPASS_ICLASS_PACS_CFG_BLOCK_INDEX].valid &&
  25. 0x30 == card_data[PICOPASS_ICLASS_PACS_CFG_BLOCK_INDEX].data[0];
  26. bool SR = card_data[PICOPASS_ICLASS_PACS_CFG_BLOCK_INDEX].data[0] == 0xA3 &&
  27. card_data[10].valid && 0x30 == card_data[10].data[0];
  28. bool has_sio = SE || SR;
  29. submenu_add_item(
  30. submenu, "Info", SubmenuIndexInfo, picopass_scene_saved_menu_submenu_callback, picopass);
  31. submenu_add_item(
  32. submenu, "Write", SubmenuIndexWrite, picopass_scene_saved_menu_submenu_callback, picopass);
  33. submenu_add_item(
  34. submenu,
  35. "Emulate",
  36. SubmenuIndexEmulate,
  37. picopass_scene_saved_menu_submenu_callback,
  38. picopass);
  39. if(secured && has_sio) {
  40. submenu_add_item(
  41. submenu,
  42. "Save in Seader fmt",
  43. SubmenuIndexSaveAsSeader,
  44. picopass_scene_saved_menu_submenu_callback,
  45. picopass);
  46. }
  47. if(secured && !no_credential) {
  48. submenu_add_item(
  49. submenu,
  50. "Save as LFRFID",
  51. SubmenuIndexSaveAsLF,
  52. picopass_scene_saved_menu_submenu_callback,
  53. picopass);
  54. if(SR) {
  55. submenu_add_item(
  56. submenu,
  57. "Save as Legacy",
  58. SubmenuIndexSaveLegacy,
  59. picopass_scene_saved_menu_submenu_callback,
  60. picopass);
  61. }
  62. }
  63. submenu_add_item(
  64. submenu,
  65. "Rename",
  66. SubmenuIndexRename,
  67. picopass_scene_saved_menu_submenu_callback,
  68. picopass);
  69. submenu_add_item(
  70. submenu,
  71. "Delete",
  72. SubmenuIndexDelete,
  73. picopass_scene_saved_menu_submenu_callback,
  74. picopass);
  75. submenu_set_selected_item(
  76. picopass->submenu,
  77. scene_manager_get_scene_state(picopass->scene_manager, PicopassSceneSavedMenu));
  78. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewMenu);
  79. }
  80. bool picopass_scene_saved_menu_on_event(void* context, SceneManagerEvent event) {
  81. Picopass* picopass = context;
  82. bool consumed = false;
  83. if(event.type == SceneManagerEventTypeCustom) {
  84. scene_manager_set_scene_state(
  85. picopass->scene_manager, PicopassSceneSavedMenu, event.event);
  86. if(event.event == SubmenuIndexDelete) {
  87. scene_manager_next_scene(picopass->scene_manager, PicopassSceneDelete);
  88. consumed = true;
  89. } else if(event.event == SubmenuIndexInfo) {
  90. scene_manager_next_scene(picopass->scene_manager, PicopassSceneDeviceInfo);
  91. consumed = true;
  92. } else if(event.event == SubmenuIndexWrite) {
  93. scene_manager_next_scene(picopass->scene_manager, PicopassSceneWriteCard);
  94. consumed = true;
  95. } else if(event.event == SubmenuIndexEmulate) {
  96. scene_manager_next_scene(picopass->scene_manager, PicopassSceneEmulate);
  97. consumed = true;
  98. } else if(event.event == SubmenuIndexRename) {
  99. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  100. consumed = true;
  101. } else if(event.event == SubmenuIndexSaveAsLF) {
  102. scene_manager_set_scene_state(
  103. picopass->scene_manager, PicopassSceneSavedMenu, SubmenuIndexSaveAsLF);
  104. picopass->dev->format = PicopassDeviceSaveFormatLF;
  105. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  106. consumed = true;
  107. } else if(event.event == SubmenuIndexSaveLegacy) {
  108. scene_manager_set_scene_state(
  109. picopass->scene_manager, PicopassSceneSavedMenu, SubmenuIndexSaveLegacy);
  110. picopass->dev->format = PicopassDeviceSaveFormatLegacy;
  111. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  112. consumed = true;
  113. } else if(event.event == SubmenuIndexSaveAsSeader) {
  114. scene_manager_set_scene_state(
  115. picopass->scene_manager, PicopassSceneSavedMenu, event.event);
  116. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  117. picopass->dev->format = PicopassDeviceSaveFormatSeader;
  118. consumed = true;
  119. }
  120. }
  121. return consumed;
  122. }
  123. void picopass_scene_saved_menu_on_exit(void* context) {
  124. Picopass* picopass = context;
  125. submenu_reset(picopass->submenu);
  126. }