picopass_scene_read_card_success.c 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. #include "../picopass_i.h"
  2. #include <dolphin/dolphin.h>
  3. void picopass_scene_read_card_success_widget_callback(
  4. GuiButtonType result,
  5. InputType type,
  6. void* context) {
  7. furi_assert(context);
  8. Picopass* picopass = context;
  9. if(type == InputTypeShort) {
  10. view_dispatcher_send_custom_event(picopass->view_dispatcher, result);
  11. }
  12. }
  13. void picopass_scene_read_card_success_on_enter(void* context) {
  14. Picopass* picopass = context;
  15. FuriString* credential_str;
  16. FuriString* wiegand_str;
  17. FuriString* sio_str;
  18. credential_str = furi_string_alloc();
  19. wiegand_str = furi_string_alloc();
  20. sio_str = furi_string_alloc();
  21. DOLPHIN_DEED(DolphinDeedNfcReadSuccess);
  22. // Send notification
  23. notification_message(picopass->notifications, &sequence_success);
  24. // Setup view
  25. PicopassPacs* pacs = &picopass->dev->dev_data.pacs;
  26. Widget* widget = picopass->widget;
  27. if(pacs->record.bitLength == 0) {
  28. furi_string_cat_printf(wiegand_str, "Read Failed");
  29. if(pacs->se_enabled) {
  30. furi_string_cat_printf(credential_str, "SE enabled");
  31. }
  32. widget_add_button_element(
  33. widget,
  34. GuiButtonTypeLeft,
  35. "Retry",
  36. picopass_scene_read_card_success_widget_callback,
  37. picopass);
  38. } else {
  39. size_t bytesLength = 1 + pacs->record.bitLength / 8;
  40. furi_string_set(credential_str, "");
  41. for(uint8_t i = PICOPASS_BLOCK_LEN - bytesLength; i < PICOPASS_BLOCK_LEN; i++) {
  42. furi_string_cat_printf(credential_str, " %02X", pacs->credential[i]);
  43. }
  44. if(pacs->record.valid) {
  45. furi_string_cat_printf(
  46. wiegand_str, "FC: %u CN: %u", pacs->record.FacilityCode, pacs->record.CardNumber);
  47. } else {
  48. furi_string_cat_printf(wiegand_str, "%d bits", pacs->record.bitLength);
  49. }
  50. if(pacs->sio) {
  51. furi_string_cat_printf(sio_str, "+SIO");
  52. }
  53. widget_add_button_element(
  54. widget,
  55. GuiButtonTypeLeft,
  56. "Retry",
  57. picopass_scene_read_card_success_widget_callback,
  58. picopass);
  59. widget_add_button_element(
  60. widget,
  61. GuiButtonTypeRight,
  62. "More",
  63. picopass_scene_read_card_success_widget_callback,
  64. picopass);
  65. }
  66. widget_add_string_element(
  67. widget, 64, 12, AlignCenter, AlignCenter, FontPrimary, furi_string_get_cstr(wiegand_str));
  68. widget_add_string_element(
  69. widget,
  70. 64,
  71. 32,
  72. AlignCenter,
  73. AlignCenter,
  74. FontSecondary,
  75. furi_string_get_cstr(credential_str));
  76. widget_add_string_element(
  77. widget, 64, 42, AlignCenter, AlignCenter, FontSecondary, furi_string_get_cstr(sio_str));
  78. furi_string_free(credential_str);
  79. furi_string_free(wiegand_str);
  80. furi_string_free(sio_str);
  81. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewWidget);
  82. }
  83. bool picopass_scene_read_card_success_on_event(void* context, SceneManagerEvent event) {
  84. Picopass* picopass = context;
  85. bool consumed = false;
  86. if(event.type == SceneManagerEventTypeCustom) {
  87. if(event.event == GuiButtonTypeLeft) {
  88. consumed = scene_manager_previous_scene(picopass->scene_manager);
  89. } else if(event.event == GuiButtonTypeRight) {
  90. // Clear device name
  91. picopass_device_set_name(picopass->dev, "");
  92. scene_manager_next_scene(picopass->scene_manager, PicopassSceneCardMenu);
  93. consumed = true;
  94. }
  95. }
  96. return consumed;
  97. }
  98. void picopass_scene_read_card_success_on_exit(void* context) {
  99. Picopass* picopass = context;
  100. // Clear view
  101. widget_reset(picopass->widget);
  102. }