picopass_scene_loclass.c 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. #include "../picopass_i.h"
  2. #include <dolphin/dolphin.h>
  3. void picopass_loclass_worker_callback(PicopassWorkerEvent event, void* context) {
  4. furi_assert(context);
  5. Picopass* picopass = context;
  6. view_dispatcher_send_custom_event(picopass->view_dispatcher, event);
  7. }
  8. void picopass_loclass_result_callback(void* context) {
  9. furi_assert(context);
  10. Picopass* picopass = context;
  11. view_dispatcher_send_custom_event(picopass->view_dispatcher, PicopassCustomEventViewExit);
  12. }
  13. void picopass_scene_loclass_on_enter(void* context) {
  14. Picopass* picopass = context;
  15. dolphin_deed(DolphinDeedNfcEmulate);
  16. scene_manager_set_scene_state(picopass->scene_manager, PicopassSceneLoclass, 0);
  17. loclass_set_callback(picopass->loclass, picopass_loclass_result_callback, picopass);
  18. // Start worker
  19. picopass_worker_start(
  20. picopass->worker,
  21. PicopassWorkerStateLoclass,
  22. &picopass->dev->dev_data,
  23. picopass_loclass_worker_callback,
  24. picopass);
  25. picopass_blink_emulate_start(picopass);
  26. loclass_set_header(picopass->loclass, "Loclass");
  27. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewLoclass);
  28. }
  29. bool picopass_scene_loclass_on_event(void* context, SceneManagerEvent event) {
  30. Picopass* picopass = context;
  31. bool consumed = false;
  32. if(event.type == SceneManagerEventTypeCustom) {
  33. if(event.event == PicopassWorkerEventLoclassGotMac) {
  34. uint32_t loclass_macs_collected =
  35. scene_manager_get_scene_state(picopass->scene_manager, PicopassSceneLoclass);
  36. loclass_macs_collected++;
  37. notification_message(picopass->notifications, &sequence_single_vibro);
  38. scene_manager_set_scene_state(
  39. picopass->scene_manager, PicopassSceneLoclass, loclass_macs_collected);
  40. loclass_set_num_macs(picopass->loclass, loclass_macs_collected);
  41. if(loclass_macs_collected >= LOCLASS_MACS_TO_COLLECT) {
  42. notification_message(picopass->notifications, &sequence_double_vibro);
  43. scene_manager_previous_scene(picopass->scene_manager);
  44. }
  45. consumed = true;
  46. } else if(event.event == PicopassWorkerEventLoclassGotStandardKey) {
  47. loclass_set_header(picopass->loclass, "Loclass (Got Std Key)");
  48. notification_message(picopass->notifications, &sequence_error);
  49. consumed = true;
  50. } else if(event.event == PicopassWorkerEventLoclassFileError) {
  51. scene_manager_set_scene_state(picopass->scene_manager, PicopassSceneLoclass, 255);
  52. loclass_set_num_macs(picopass->loclass, 255);
  53. loclass_set_header(picopass->loclass, "Error Opening Log File");
  54. picopass_blink_stop(picopass);
  55. consumed = true;
  56. } else if(event.event == PicopassCustomEventViewExit) {
  57. consumed = scene_manager_previous_scene(picopass->scene_manager);
  58. }
  59. } else if(event.type == SceneManagerEventTypeBack) {
  60. consumed = scene_manager_previous_scene(picopass->scene_manager);
  61. }
  62. return consumed;
  63. }
  64. void picopass_scene_loclass_on_exit(void* context) {
  65. Picopass* picopass = context;
  66. picopass_blink_stop(picopass);
  67. // Stop worker
  68. picopass_worker_stop(picopass->worker);
  69. loclass_reset(picopass->loclass);
  70. // Clear view
  71. widget_reset(picopass->widget);
  72. }