nfc_scene_read_mifare_classic.c 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. #include "../nfc_i.h"
  2. enum {
  3. NfcSceneReadMifareClassicStateInProgress,
  4. NfcSceneReadMifareClassicStateDone,
  5. };
  6. void nfc_read_mifare_classic_worker_callback(NfcWorkerEvent event, void* context) {
  7. furi_assert(context);
  8. Nfc* nfc = context;
  9. view_dispatcher_send_custom_event(nfc->view_dispatcher, event);
  10. }
  11. void nfc_read_mifare_classic_dict_attack_result_callback(void* context) {
  12. furi_assert(context);
  13. Nfc* nfc = context;
  14. view_dispatcher_send_custom_event(nfc->view_dispatcher, NfcCustomEventDictAttackDone);
  15. }
  16. void nfc_scene_read_mifare_classic_on_enter(void* context) {
  17. Nfc* nfc = context;
  18. // Setup and start worker
  19. memset(&nfc->dev->dev_data.mf_classic_data, 0, sizeof(MfClassicData));
  20. dict_attack_set_result_callback(
  21. nfc->dict_attack, nfc_read_mifare_classic_dict_attack_result_callback, nfc);
  22. scene_manager_set_scene_state(
  23. nfc->scene_manager, NfcSceneReadMifareClassic, NfcSceneReadMifareClassicStateInProgress);
  24. view_dispatcher_switch_to_view(nfc->view_dispatcher, NfcViewDictAttack);
  25. nfc_worker_start(
  26. nfc->worker,
  27. NfcWorkerStateReadMifareClassic,
  28. &nfc->dev->dev_data,
  29. nfc_read_mifare_classic_worker_callback,
  30. nfc);
  31. nfc_blink_start(nfc);
  32. }
  33. bool nfc_scene_read_mifare_classic_on_event(void* context, SceneManagerEvent event) {
  34. Nfc* nfc = context;
  35. bool consumed = false;
  36. if(event.type == SceneManagerEventTypeTick) {
  37. consumed = true;
  38. } else if(event.type == SceneManagerEventTypeCustom) {
  39. if(event.event == NfcCustomEventDictAttackDone) {
  40. scene_manager_next_scene(nfc->scene_manager, NfcSceneMifareClassicMenu);
  41. consumed = true;
  42. } else if(event.event == NfcWorkerEventDetectedClassic1k) {
  43. dict_attack_card_detected(nfc->dict_attack, MfClassicType1k);
  44. consumed = true;
  45. } else if(event.event == NfcWorkerEventDetectedClassic4k) {
  46. dict_attack_card_detected(nfc->dict_attack, MfClassicType4k);
  47. consumed = true;
  48. } else if(event.event == NfcWorkerEventNewSector) {
  49. dict_attack_inc_curr_sector(nfc->dict_attack);
  50. consumed = true;
  51. } else if(event.event == NfcWorkerEventFoundKeyA) {
  52. dict_attack_inc_found_key(nfc->dict_attack, MfClassicKeyA);
  53. consumed = true;
  54. } else if(event.event == NfcWorkerEventFoundKeyB) {
  55. dict_attack_inc_found_key(nfc->dict_attack, MfClassicKeyB);
  56. consumed = true;
  57. } else if(event.event == NfcWorkerEventNoCardDetected) {
  58. dict_attack_card_removed(nfc->dict_attack);
  59. consumed = true;
  60. } else if(event.event == NfcWorkerEventSuccess) {
  61. scene_manager_set_scene_state(
  62. nfc->scene_manager, NfcSceneReadMifareClassic, NfcSceneReadMifareClassicStateDone);
  63. nfc_blink_stop(nfc);
  64. notification_message(nfc->notifications, &sequence_success);
  65. dict_attack_set_result(nfc->dict_attack, true);
  66. consumed = true;
  67. } else if(event.event == NfcWorkerEventFail) {
  68. scene_manager_set_scene_state(
  69. nfc->scene_manager, NfcSceneReadMifareClassic, NfcSceneReadMifareClassicStateDone);
  70. nfc_blink_stop(nfc);
  71. dict_attack_set_result(nfc->dict_attack, false);
  72. consumed = true;
  73. } else if(event.event == NfcWorkerEventNoDictFound) {
  74. scene_manager_next_scene(nfc->scene_manager, NfcSceneDictNotFound);
  75. consumed = true;
  76. }
  77. }
  78. return consumed;
  79. }
  80. void nfc_scene_read_mifare_classic_on_exit(void* context) {
  81. Nfc* nfc = context;
  82. // Stop worker
  83. nfc_worker_stop(nfc->worker);
  84. dict_attack_reset(nfc->dict_attack);
  85. nfc_blink_stop(nfc);
  86. }