picopass_scene_device_info.c 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. #include "../picopass_i.h"
  2. #include <dolphin/dolphin.h>
  3. void picopass_scene_device_info_widget_callback(
  4. GuiButtonType result,
  5. InputType type,
  6. void* context) {
  7. Picopass* picopass = context;
  8. if(type == InputTypeShort) {
  9. view_dispatcher_send_custom_event(picopass->view_dispatcher, result);
  10. }
  11. }
  12. void picopass_scene_device_info_on_enter(void* context) {
  13. Picopass* picopass = context;
  14. FuriString* csn_str = furi_string_alloc_set("CSN:");
  15. FuriString* credential_str = furi_string_alloc();
  16. FuriString* wiegand_str = furi_string_alloc();
  17. dolphin_deed(DolphinDeedNfcReadSuccess);
  18. // Setup view
  19. PicopassBlock* AA1 = picopass->dev->dev_data.AA1;
  20. PicopassPacs* pacs = &picopass->dev->dev_data.pacs;
  21. Widget* widget = picopass->widget;
  22. uint8_t csn[PICOPASS_BLOCK_LEN] = {0};
  23. memcpy(csn, AA1[PICOPASS_CSN_BLOCK_INDEX].data, PICOPASS_BLOCK_LEN);
  24. for(uint8_t i = 0; i < PICOPASS_BLOCK_LEN; i++) {
  25. furi_string_cat_printf(csn_str, "%02X ", csn[i]);
  26. }
  27. bool sio = 0x30 == AA1[PICOPASS_ICLASS_PACS_CFG_BLOCK_INDEX].data[0];
  28. if(sio) {
  29. furi_string_cat_printf(wiegand_str, "SIO");
  30. } else if(pacs->bitLength == 0 || pacs->bitLength == 255) {
  31. // Neither of these are valid. Indicates the block was all 0x00 or all 0xff
  32. furi_string_cat_printf(wiegand_str, "Invalid PACS");
  33. } else {
  34. size_t bytesLength = pacs->bitLength / 8;
  35. if(pacs->bitLength % 8 > 0) {
  36. // Add extra byte if there are bits remaining
  37. bytesLength++;
  38. }
  39. furi_string_set(credential_str, "");
  40. for(uint8_t i = PICOPASS_BLOCK_LEN - bytesLength; i < PICOPASS_BLOCK_LEN; i++) {
  41. furi_string_cat_printf(credential_str, "%02X", pacs->credential[i]);
  42. }
  43. furi_string_cat_printf(wiegand_str, "%d bits", pacs->bitLength);
  44. if(pacs->sio) { // SR
  45. furi_string_cat_printf(credential_str, " +SIO");
  46. }
  47. }
  48. widget_add_string_element(
  49. widget, 64, 5, AlignCenter, AlignCenter, FontSecondary, furi_string_get_cstr(csn_str));
  50. widget_add_string_element(
  51. widget, 64, 20, AlignCenter, AlignCenter, FontPrimary, furi_string_get_cstr(wiegand_str));
  52. widget_add_string_element(
  53. widget,
  54. 64,
  55. 36,
  56. AlignCenter,
  57. AlignCenter,
  58. FontSecondary,
  59. furi_string_get_cstr(credential_str));
  60. furi_string_free(csn_str);
  61. furi_string_free(credential_str);
  62. furi_string_free(wiegand_str);
  63. widget_add_button_element(
  64. picopass->widget,
  65. GuiButtonTypeLeft,
  66. "Back",
  67. picopass_scene_device_info_widget_callback,
  68. picopass);
  69. widget_add_button_element(
  70. picopass->widget,
  71. GuiButtonTypeRight,
  72. "More",
  73. picopass_scene_device_info_widget_callback,
  74. picopass);
  75. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewWidget);
  76. }
  77. bool picopass_scene_device_info_on_event(void* context, SceneManagerEvent event) {
  78. Picopass* picopass = context;
  79. bool consumed = false;
  80. if(event.type == SceneManagerEventTypeCustom) {
  81. if(event.event == GuiButtonTypeLeft) {
  82. consumed = scene_manager_previous_scene(picopass->scene_manager);
  83. } else if(event.event == GuiButtonTypeRight) {
  84. scene_manager_next_scene(picopass->scene_manager, PicopassSceneMoreInfo);
  85. consumed = true;
  86. } else if(event.event == PicopassCustomEventViewExit) {
  87. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewWidget);
  88. consumed = true;
  89. }
  90. } else if(event.type == SceneManagerEventTypeBack) {
  91. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewWidget);
  92. consumed = true;
  93. }
  94. return consumed;
  95. }
  96. void picopass_scene_device_info_on_exit(void* context) {
  97. Picopass* picopass = context;
  98. // Clear views
  99. widget_reset(picopass->widget);
  100. }