picopass_scene_loclass.c 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. #include "../picopass_i.h"
  2. #include <dolphin/dolphin.h>
  3. static NfcCommand
  4. picopass_scene_loclass_listener_callback(PicopassListenerEvent event, void* context) {
  5. NfcCommand command = NfcCommandContinue;
  6. Picopass* picopass = context;
  7. if(event.type == PicopassListenerEventTypeLoclassGotMac) {
  8. picopass->loclass_context.macs_collected++;
  9. view_dispatcher_send_custom_event(
  10. picopass->view_dispatcher, PicopassCustomEventLoclassGotMac);
  11. } else if(event.type == PicopassListenerEventTypeLoclassGotStandardKey) {
  12. view_dispatcher_send_custom_event(
  13. picopass->view_dispatcher, PicopassCustomEventLoclassGotStandardKey);
  14. command = NfcCommandStop;
  15. }
  16. return command;
  17. }
  18. static void picopass_loclass_result_callback(void* context) {
  19. furi_assert(context);
  20. Picopass* picopass = context;
  21. view_dispatcher_send_custom_event(picopass->view_dispatcher, PicopassCustomEventViewExit);
  22. }
  23. void picopass_scene_loclass_on_enter(void* context) {
  24. Picopass* picopass = context;
  25. dolphin_deed(DolphinDeedNfcEmulate);
  26. scene_manager_set_scene_state(picopass->scene_manager, PicopassSceneLoclass, 0);
  27. loclass_set_callback(picopass->loclass, picopass_loclass_result_callback, picopass);
  28. loclass_set_header(picopass->loclass, "Loclass");
  29. loclass_set_subheader(picopass->loclass, "Hold To Reader");
  30. picopass_blink_emulate_start(picopass);
  31. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewLoclass);
  32. PicopassDeviceData* data = malloc(sizeof(PicopassDeviceData));
  33. const uint8_t config_block[PICOPASS_BLOCK_LEN] = {
  34. 0x12, 0xFF, 0xFF, 0xFF, 0x7F, 0x1F, 0xFF, 0x3C};
  35. memcpy(data->card_data[PICOPASS_CONFIG_BLOCK_INDEX].data, config_block, sizeof(config_block));
  36. data->card_data[PICOPASS_CONFIG_BLOCK_INDEX].valid = true;
  37. const uint8_t epurse[PICOPASS_BLOCK_LEN] = {0xFE, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
  38. memcpy(data->card_data[PICOPASS_SECURE_EPURSE_BLOCK_INDEX].data, epurse, sizeof(epurse));
  39. data->card_data[PICOPASS_SECURE_EPURSE_BLOCK_INDEX].valid = true;
  40. const uint8_t aia[PICOPASS_BLOCK_LEN] = {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
  41. memcpy(data->card_data[PICOPASS_SECURE_AIA_BLOCK_INDEX].data, aia, sizeof(aia));
  42. data->card_data[PICOPASS_SECURE_AIA_BLOCK_INDEX].valid = true;
  43. picopass->listener = picopass_listener_alloc(picopass->nfc, data);
  44. free(data);
  45. if(picopass_listener_set_mode(picopass->listener, PicopassListenerModeLoclass)) {
  46. picopass_listener_start(
  47. picopass->listener, picopass_scene_loclass_listener_callback, picopass);
  48. } else {
  49. loclass_set_num_macs(picopass->loclass, 255);
  50. loclass_set_header(picopass->loclass, "Error Opening Log File");
  51. picopass_listener_free(picopass->listener);
  52. picopass->listener = NULL;
  53. }
  54. }
  55. bool picopass_scene_loclass_on_event(void* context, SceneManagerEvent event) {
  56. bool consumed = false;
  57. Picopass* picopass = context;
  58. if(event.type == SceneManagerEventTypeCustom) {
  59. if(event.event == PicopassCustomEventLoclassGotMac) {
  60. notification_message(picopass->notifications, &sequence_single_vibro);
  61. loclass_set_num_macs(picopass->loclass, picopass->loclass_context.macs_collected);
  62. if(picopass->loclass_context.macs_collected >= LOCLASS_MACS_TO_COLLECT) {
  63. notification_message(picopass->notifications, &sequence_double_vibro);
  64. scene_manager_previous_scene(picopass->scene_manager);
  65. }
  66. consumed = true;
  67. } else if(event.event == PicopassCustomEventLoclassGotStandardKey) {
  68. loclass_set_header(picopass->loclass, "Loclass (Got Std Key)");
  69. notification_message(picopass->notifications, &sequence_error);
  70. consumed = true;
  71. } else if(event.event == PicopassCustomEventViewExit) {
  72. consumed = scene_manager_previous_scene(picopass->scene_manager);
  73. }
  74. }
  75. return consumed;
  76. }
  77. void picopass_scene_loclass_on_exit(void* context) {
  78. Picopass* picopass = context;
  79. if(picopass->listener) {
  80. picopass_listener_stop(picopass->listener);
  81. picopass_listener_free(picopass->listener);
  82. }
  83. picopass->loclass_context.macs_collected = 0;
  84. picopass_blink_stop(picopass);
  85. loclass_reset(picopass->loclass);
  86. }