picopass_scene_saved_menu.c 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. #include "../picopass_i.h"
  2. enum SubmenuIndex {
  3. SubmenuIndexInfo,
  4. SubmenuIndexWrite,
  5. SubmenuIndexEmulate,
  6. SubmenuIndexRename,
  7. SubmenuIndexDelete,
  8. SubmenuIndexSaveAsLF,
  9. };
  10. void picopass_scene_saved_menu_submenu_callback(void* context, uint32_t index) {
  11. Picopass* picopass = context;
  12. view_dispatcher_send_custom_event(picopass->view_dispatcher, index);
  13. }
  14. void picopass_scene_saved_menu_on_enter(void* context) {
  15. Picopass* picopass = context;
  16. Submenu* submenu = picopass->submenu;
  17. PicopassPacs* pacs = &picopass->dev->dev_data.pacs;
  18. PicopassBlock* card_data = picopass->dev->dev_data.card_data;
  19. bool secured = (card_data[PICOPASS_CONFIG_BLOCK_INDEX].data[7] & PICOPASS_FUSE_CRYPT10) !=
  20. PICOPASS_FUSE_CRYPT0;
  21. bool no_credential = picopass_is_memset(pacs->credential, 0x00, sizeof(pacs->credential));
  22. submenu_add_item(
  23. submenu, "Info", SubmenuIndexInfo, picopass_scene_saved_menu_submenu_callback, picopass);
  24. submenu_add_item(
  25. submenu, "Write", SubmenuIndexWrite, picopass_scene_saved_menu_submenu_callback, picopass);
  26. submenu_add_item(
  27. submenu,
  28. "Emulate",
  29. SubmenuIndexEmulate,
  30. picopass_scene_saved_menu_submenu_callback,
  31. picopass);
  32. if(secured && !no_credential) {
  33. submenu_add_item(
  34. submenu,
  35. "Save as LFRFID",
  36. SubmenuIndexSaveAsLF,
  37. picopass_scene_saved_menu_submenu_callback,
  38. picopass);
  39. }
  40. submenu_add_item(
  41. submenu,
  42. "Rename",
  43. SubmenuIndexRename,
  44. picopass_scene_saved_menu_submenu_callback,
  45. picopass);
  46. submenu_add_item(
  47. submenu,
  48. "Delete",
  49. SubmenuIndexDelete,
  50. picopass_scene_saved_menu_submenu_callback,
  51. picopass);
  52. submenu_set_selected_item(
  53. picopass->submenu,
  54. scene_manager_get_scene_state(picopass->scene_manager, PicopassSceneSavedMenu));
  55. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewMenu);
  56. }
  57. bool picopass_scene_saved_menu_on_event(void* context, SceneManagerEvent event) {
  58. Picopass* picopass = context;
  59. bool consumed = false;
  60. if(event.type == SceneManagerEventTypeCustom) {
  61. scene_manager_set_scene_state(
  62. picopass->scene_manager, PicopassSceneSavedMenu, event.event);
  63. if(event.event == SubmenuIndexDelete) {
  64. scene_manager_next_scene(picopass->scene_manager, PicopassSceneDelete);
  65. consumed = true;
  66. } else if(event.event == SubmenuIndexInfo) {
  67. scene_manager_next_scene(picopass->scene_manager, PicopassSceneDeviceInfo);
  68. consumed = true;
  69. } else if(event.event == SubmenuIndexWrite) {
  70. scene_manager_next_scene(picopass->scene_manager, PicopassSceneWriteCard);
  71. consumed = true;
  72. } else if(event.event == SubmenuIndexEmulate) {
  73. scene_manager_next_scene(picopass->scene_manager, PicopassSceneEmulate);
  74. consumed = true;
  75. } else if(event.event == SubmenuIndexRename) {
  76. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  77. consumed = true;
  78. } else if(event.event == SubmenuIndexSaveAsLF) {
  79. scene_manager_set_scene_state(
  80. picopass->scene_manager, PicopassSceneCardMenu, SubmenuIndexSaveAsLF);
  81. picopass->dev->format = PicopassDeviceSaveFormatLF;
  82. scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveName);
  83. consumed = true;
  84. }
  85. }
  86. return consumed;
  87. }
  88. void picopass_scene_saved_menu_on_exit(void* context) {
  89. Picopass* picopass = context;
  90. submenu_reset(picopass->submenu);
  91. }