picopass_scene_loclass.c 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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. picopass_blink_emulate_start(picopass);
  30. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewLoclass);
  31. PicopassDeviceData* data = malloc(sizeof(PicopassDeviceData));
  32. const uint8_t config_block[PICOPASS_BLOCK_LEN] = {
  33. 0x12, 0xFF, 0xFF, 0xFF, 0x7F, 0x1F, 0xFF, 0x3C};
  34. memcpy(data->card_data[PICOPASS_CONFIG_BLOCK_INDEX].data, config_block, sizeof(config_block));
  35. data->card_data[PICOPASS_CONFIG_BLOCK_INDEX].valid = true;
  36. const uint8_t epurse[PICOPASS_BLOCK_LEN] = {0xFE, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
  37. memcpy(data->card_data[PICOPASS_SECURE_EPURSE_BLOCK_INDEX].data, epurse, sizeof(epurse));
  38. data->card_data[PICOPASS_SECURE_EPURSE_BLOCK_INDEX].valid = true;
  39. const uint8_t aia[PICOPASS_BLOCK_LEN] = {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
  40. memcpy(data->card_data[PICOPASS_SECURE_AIA_BLOCK_INDEX].data, aia, sizeof(aia));
  41. data->card_data[PICOPASS_SECURE_AIA_BLOCK_INDEX].valid = true;
  42. picopass->listener = picopass_listener_alloc(picopass->nfc, data);
  43. free(data);
  44. if(picopass_listener_set_mode(picopass->listener, PicopassListenerModeLoclass)) {
  45. picopass_listener_start(
  46. picopass->listener, picopass_scene_loclass_listener_callback, picopass);
  47. } else {
  48. loclass_set_num_macs(picopass->loclass, 255);
  49. loclass_set_header(picopass->loclass, "Error Opening Log File");
  50. picopass_listener_free(picopass->listener);
  51. picopass->listener = NULL;
  52. }
  53. }
  54. bool picopass_scene_loclass_on_event(void* context, SceneManagerEvent event) {
  55. bool consumed = false;
  56. Picopass* picopass = context;
  57. if(event.type == SceneManagerEventTypeCustom) {
  58. if(event.event == PicopassCustomEventLoclassGotMac) {
  59. notification_message(picopass->notifications, &sequence_single_vibro);
  60. loclass_set_num_macs(picopass->loclass, picopass->loclass_context.macs_collected);
  61. if(picopass->loclass_context.macs_collected >= LOCLASS_MACS_TO_COLLECT) {
  62. notification_message(picopass->notifications, &sequence_double_vibro);
  63. scene_manager_previous_scene(picopass->scene_manager);
  64. }
  65. consumed = true;
  66. } else if(event.event == PicopassCustomEventLoclassGotStandardKey) {
  67. loclass_set_header(picopass->loclass, "Loclass (Got Std Key)");
  68. notification_message(picopass->notifications, &sequence_error);
  69. consumed = true;
  70. } else if(event.event == PicopassCustomEventViewExit) {
  71. consumed = scene_manager_previous_scene(picopass->scene_manager);
  72. }
  73. }
  74. return consumed;
  75. }
  76. void picopass_scene_loclass_on_exit(void* context) {
  77. Picopass* picopass = context;
  78. if(picopass->listener) {
  79. picopass_listener_stop(picopass->listener);
  80. picopass_listener_free(picopass->listener);
  81. }
  82. picopass->loclass_context.macs_collected = 0;
  83. picopass_blink_stop(picopass);
  84. loclass_reset(picopass->loclass);
  85. }