picopass_scene_key_menu.c 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. #include "../picopass_i.h"
  2. #include "../picopass_keys.h"
  3. enum SubmenuIndex {
  4. SubmenuIndexWriteStandard,
  5. SubmenuIndexWriteiCE,
  6. SubmenuIndexWriteiCL,
  7. SubmenuIndexWriteiCS,
  8. SubmenuIndexWriteCustom, //TODO: user input of key
  9. };
  10. void picopass_scene_key_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_key_menu_on_enter(void* context) {
  15. Picopass* picopass = context;
  16. Submenu* submenu = picopass->submenu;
  17. submenu_add_item(
  18. submenu,
  19. "Write Standard",
  20. SubmenuIndexWriteStandard,
  21. picopass_scene_key_menu_submenu_callback,
  22. picopass);
  23. submenu_add_item(
  24. submenu,
  25. "Write iCE",
  26. SubmenuIndexWriteiCE,
  27. picopass_scene_key_menu_submenu_callback,
  28. picopass);
  29. submenu_add_item(
  30. submenu,
  31. "Write iCL",
  32. SubmenuIndexWriteiCL,
  33. picopass_scene_key_menu_submenu_callback,
  34. picopass);
  35. submenu_add_item(
  36. submenu,
  37. "Write iCS",
  38. SubmenuIndexWriteiCS,
  39. picopass_scene_key_menu_submenu_callback,
  40. picopass);
  41. submenu_set_selected_item(
  42. picopass->submenu,
  43. scene_manager_get_scene_state(picopass->scene_manager, PicopassSceneKeyMenu));
  44. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewMenu);
  45. }
  46. bool picopass_scene_key_menu_on_event(void* context, SceneManagerEvent event) {
  47. Picopass* picopass = context;
  48. bool consumed = false;
  49. if(event.type == SceneManagerEventTypeCustom) {
  50. if(event.event == SubmenuIndexWriteStandard) {
  51. scene_manager_set_scene_state(
  52. picopass->scene_manager, PicopassSceneKeyMenu, SubmenuIndexWriteStandard);
  53. memcpy(picopass->dev->dev_data.pacs.key, picopass_iclass_key, RFAL_PICOPASS_BLOCK_LEN);
  54. picopass->dev->dev_data.pacs.elite_kdf = false;
  55. scene_manager_next_scene(picopass->scene_manager, PicopassSceneWriteKey);
  56. consumed = true;
  57. } else if(event.event == SubmenuIndexWriteiCE) {
  58. scene_manager_set_scene_state(
  59. picopass->scene_manager, PicopassSceneKeyMenu, SubmenuIndexWriteiCE);
  60. memcpy(picopass->dev->dev_data.pacs.key, picopass_xice_key, RFAL_PICOPASS_BLOCK_LEN);
  61. picopass->dev->dev_data.pacs.elite_kdf = true;
  62. scene_manager_next_scene(picopass->scene_manager, PicopassSceneWriteKey);
  63. consumed = true;
  64. } else if(event.event == SubmenuIndexWriteiCL) {
  65. scene_manager_set_scene_state(
  66. picopass->scene_manager, PicopassSceneKeyMenu, SubmenuIndexWriteiCL);
  67. memcpy(picopass->dev->dev_data.pacs.key, picopass_xicl_key, RFAL_PICOPASS_BLOCK_LEN);
  68. picopass->dev->dev_data.pacs.elite_kdf = false;
  69. scene_manager_next_scene(picopass->scene_manager, PicopassSceneWriteKey);
  70. consumed = true;
  71. } else if(event.event == SubmenuIndexWriteiCS) {
  72. scene_manager_set_scene_state(
  73. picopass->scene_manager, PicopassSceneKeyMenu, SubmenuIndexWriteiCS);
  74. memcpy(picopass->dev->dev_data.pacs.key, picopass_xics_key, RFAL_PICOPASS_BLOCK_LEN);
  75. picopass->dev->dev_data.pacs.elite_kdf = false;
  76. scene_manager_next_scene(picopass->scene_manager, PicopassSceneWriteKey);
  77. consumed = true;
  78. }
  79. } else if(event.type == SceneManagerEventTypeBack) {
  80. consumed = scene_manager_search_and_switch_to_previous_scene(
  81. picopass->scene_manager, PicopassSceneStart);
  82. }
  83. return consumed;
  84. }
  85. void picopass_scene_key_menu_on_exit(void* context) {
  86. Picopass* picopass = context;
  87. submenu_reset(picopass->submenu);
  88. }