picopass_scene_card_menu.c 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  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 secured = (AA1[PICOPASS_CONFIG_BLOCK_INDEX].data[7] & PICOPASS_FUSE_CRYPT10) !=
  22. PICOPASS_FUSE_CRYPT0;
  23. bool zero_config = picopass_is_memset(
  24. AA1[PICOPASS_ICLASS_PACS_CFG_BLOCK_INDEX].data, 0x00, PICOPASS_BLOCK_LEN);
  25. bool no_credential = picopass_is_memset(pacs->credential, 0x00, sizeof(pacs->credential));
  26. bool no_key =
  27. picopass_is_memset(AA1[PICOPASS_SECURE_KD_BLOCK_INDEX].data, 0xFF, PICOPASS_BLOCK_LEN);
  28. if(secured && zero_config) {
  29. submenu_add_item(
  30. submenu,
  31. "Save Partial",
  32. SubmenuIndexSavePartial,
  33. picopass_scene_card_menu_submenu_callback,
  34. picopass);
  35. } else {
  36. submenu_add_item(
  37. submenu, "Save", SubmenuIndexSave, picopass_scene_card_menu_submenu_callback, picopass);
  38. }
  39. if(secured && (sio || pacs->sio)) {
  40. submenu_add_item(
  41. submenu,
  42. "Save in Seader fmt",
  43. SubmenuIndexSaveAsSeader,
  44. picopass_scene_card_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_card_menu_submenu_callback,
  53. picopass);
  54. }
  55. if(!zero_config && !no_key) {
  56. submenu_add_item(
  57. submenu,
  58. "Write",
  59. SubmenuIndexWrite,
  60. picopass_scene_card_menu_submenu_callback,
  61. picopass);
  62. submenu_add_item(
  63. submenu,
  64. "Emulate",
  65. SubmenuIndexEmulate,
  66. picopass_scene_card_menu_submenu_callback,
  67. picopass);
  68. if(secured) {
  69. submenu_add_item(
  70. submenu,
  71. "Change Key",
  72. SubmenuIndexChangeKey,
  73. picopass_scene_card_menu_submenu_callback,
  74. picopass);
  75. }
  76. }
  77. submenu_set_selected_item(
  78. picopass->submenu,
  79. scene_manager_get_scene_state(picopass->scene_manager, PicopassSceneCardMenu));
  80. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewMenu);
  81. }
  82. bool picopass_scene_card_menu_on_event(void* context, SceneManagerEvent event) {
  83. Picopass* picopass = context;
  84. bool consumed = false;
  85. if(event.type == SceneManagerEventTypeCustom) {
  86. if(event.event == SubmenuIndexSave) {
  87. scene_manager_set_scene_state(
  88. picopass->scene_manager, PicopassSceneCardMenu, SubmenuIndexSave);
  89. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  90. picopass->dev->format = PicopassDeviceSaveFormatHF;
  91. consumed = true;
  92. } else if(event.event == SubmenuIndexSavePartial) {
  93. scene_manager_set_scene_state(
  94. picopass->scene_manager, PicopassSceneCardMenu, SubmenuIndexSave);
  95. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  96. picopass->dev->format = PicopassDeviceSaveFormatPartial;
  97. consumed = true;
  98. } else if(event.event == SubmenuIndexSaveAsSeader) {
  99. scene_manager_set_scene_state(
  100. picopass->scene_manager, PicopassSceneCardMenu, event.event);
  101. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  102. picopass->dev->format = PicopassDeviceSaveFormatSeader;
  103. consumed = true;
  104. } else if(event.event == SubmenuIndexSaveAsLF) {
  105. scene_manager_set_scene_state(
  106. picopass->scene_manager, PicopassSceneCardMenu, SubmenuIndexSaveAsLF);
  107. picopass->dev->format = PicopassDeviceSaveFormatLF;
  108. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  109. consumed = true;
  110. } else if(event.event == SubmenuIndexWrite) {
  111. scene_manager_next_scene(picopass->scene_manager, PicopassSceneWriteCard);
  112. consumed = true;
  113. } else if(event.event == SubmenuIndexEmulate) {
  114. scene_manager_next_scene(picopass->scene_manager, PicopassSceneEmulate);
  115. consumed = true;
  116. } else if(event.event == SubmenuIndexChangeKey) {
  117. scene_manager_set_scene_state(
  118. picopass->scene_manager, PicopassSceneCardMenu, SubmenuIndexChangeKey);
  119. scene_manager_next_scene(picopass->scene_manager, PicopassSceneKeyMenu);
  120. consumed = true;
  121. }
  122. } else if(event.type == SceneManagerEventTypeBack) {
  123. consumed = scene_manager_search_and_switch_to_previous_scene(
  124. picopass->scene_manager, PicopassSceneStart);
  125. }
  126. return consumed;
  127. }
  128. void picopass_scene_card_menu_on_exit(void* context) {
  129. Picopass* picopass = context;
  130. submenu_reset(picopass->submenu);
  131. }