passy_scene_read.c 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  1. #include "../passy_i.h"
  2. #include "../passy_reader.h"
  3. #include <dolphin/dolphin.h>
  4. #define TAG "PassySceneRead"
  5. static PassyReader* passy_reader = NULL;
  6. void passy_scene_detect_scan_callback(NfcScannerEvent event, void* context) {
  7. furi_assert(context);
  8. Passy* passy = context;
  9. // detect the type of protocol, either 4a/4b and then run the specific poller callback functions yada yada yada
  10. if(event.type == NfcScannerEventTypeDetected) {
  11. if(event.data.protocols && *event.data.protocols == NfcProtocolIso14443_4a) {
  12. passy->proto = "4a";
  13. } else if(event.data.protocols && *event.data.protocols == NfcProtocolIso14443_4b) {
  14. passy->proto = "4b";
  15. } else if(event.data.protocols && *event.data.protocols == NfcProtocolIso14443_3b) {
  16. passy->proto = "4b";
  17. } else {
  18. FURI_LOG_E(TAG, "Unknown protocol detected, %d", *event.data.protocols);
  19. passy->proto = "";
  20. // just continue as expected..
  21. }
  22. view_dispatcher_send_custom_event(passy->view_dispatcher, PassyCustomEventReaderDetected);
  23. }
  24. }
  25. void passy_scene_read_on_enter(void* context) {
  26. Passy* passy = context;
  27. dolphin_deed(DolphinDeedNfcRead);
  28. // Setup view
  29. Popup* popup = passy->popup;
  30. popup_set_header(popup, "Reading", 68, 30, AlignLeft, AlignTop);
  31. popup_set_icon(popup, 0, 3, &I_RFIDDolphinReceive_97x61);
  32. passy->scanner = nfc_scanner_alloc(passy->nfc);
  33. nfc_scanner_start(
  34. passy->scanner, passy_scene_detect_scan_callback, passy); // starts a scanner instance
  35. passy_blink_start(passy);
  36. view_dispatcher_switch_to_view(passy->view_dispatcher, PassyViewPopup);
  37. }
  38. bool passy_scene_read_on_event(void* context, SceneManagerEvent event) {
  39. Passy* passy = context;
  40. bool consumed = false;
  41. Popup* popup = passy->popup;
  42. if(event.type == SceneManagerEventTypeCustom) {
  43. if(event.event == PassyCustomEventReaderSuccess) {
  44. if(passy->read_type == PassyReadCOM) {
  45. scene_manager_next_scene(passy->scene_manager, PassySceneAdvancedMenu);
  46. } else {
  47. scene_manager_next_scene(passy->scene_manager, PassySceneReadSuccess);
  48. }
  49. consumed = true;
  50. } else if(event.event == PassyCustomEventReaderError) {
  51. passy->last_sw = passy_reader->last_sw;
  52. scene_manager_next_scene(passy->scene_manager, PassySceneReadError);
  53. consumed = true;
  54. } else if(event.event == PassyCustomEventReaderDetected) {
  55. nfc_scanner_stop(passy->scanner);
  56. nfc_scanner_free(passy->scanner);
  57. passy->scanner = NULL;
  58. if(strcmp(passy->proto, "4b") == 0) {
  59. FURI_LOG_I(TAG, "detected 4B protocol");
  60. passy->poller = nfc_poller_alloc(passy->nfc, NfcProtocolIso14443_4b);
  61. passy_reader = passy_reader_alloc(passy);
  62. nfc_poller_start(passy->poller, passy_reader_poller_callback, passy_reader);
  63. passy->bytes_total = 0;
  64. } else if(strcmp(passy->proto, "4a") == 0) {
  65. FURI_LOG_I(TAG, "detected 4A protocol");
  66. passy->poller = nfc_poller_alloc(passy->nfc, NfcProtocolIso14443_4a);
  67. passy_reader = passy_reader_alloc(passy);
  68. nfc_poller_start(passy->poller, passy_reader_poller_callback, passy_reader);
  69. passy->bytes_total = 0;
  70. } else {
  71. view_dispatcher_send_custom_event(
  72. passy->view_dispatcher, PassyCustomEventReaderError);
  73. }
  74. popup_set_header(popup, "Detected", 68, 30, AlignLeft, AlignTop);
  75. } else if(event.event == PassyCustomEventReaderAuthenticated) {
  76. popup_set_header(popup, "Authenticated", 68, 30, AlignLeft, AlignTop);
  77. } else if(event.event == PassyCustomEventReaderReading) {
  78. if(passy->bytes_total == 0) {
  79. popup_set_header(popup, "Reading", 68, 30, AlignLeft, AlignTop);
  80. } else {
  81. // Update the header with the current bytes read
  82. char header[32];
  83. snprintf(
  84. header,
  85. sizeof(header),
  86. "Reading\n%d/%dk",
  87. passy->offset,
  88. (passy->bytes_total / 1024));
  89. popup_set_header(popup, header, 68, 30, AlignLeft, AlignTop);
  90. }
  91. }
  92. } else if(event.type == SceneManagerEventTypeBack) {
  93. scene_manager_search_and_switch_to_previous_scene(
  94. passy->scene_manager, PassySceneMainMenu);
  95. consumed = true;
  96. }
  97. return consumed;
  98. }
  99. void passy_scene_read_on_exit(void* context) {
  100. Passy* passy = context;
  101. if(passy_reader) {
  102. passy_reader_free(passy_reader);
  103. passy_reader = NULL;
  104. }
  105. if(passy->poller) {
  106. nfc_poller_stop(passy->poller);
  107. nfc_poller_free(passy->poller);
  108. passy->poller = NULL;
  109. }
  110. if(passy->scanner) {
  111. nfc_scanner_stop(passy->scanner);
  112. nfc_scanner_free(passy->scanner);
  113. passy->scanner = NULL;
  114. }
  115. // Clear view
  116. popup_reset(passy->popup);
  117. passy_blink_stop(passy);
  118. }