detect_reader.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. #include "detect_reader.h"
  2. #include <gui/elements.h>
  3. struct DetectReader {
  4. View* view;
  5. DetectReaderDoneCallback callback;
  6. void* context;
  7. };
  8. typedef struct {
  9. uint16_t nonces;
  10. } DetectReaderViewModel;
  11. static void detect_reader_draw_callback(Canvas* canvas, void* model) {
  12. DetectReaderViewModel* m = model;
  13. char text[32] = {};
  14. snprintf(text, sizeof(text), "Tap the reader several times");
  15. canvas_draw_str_aligned(canvas, 64, 0, AlignCenter, AlignTop, "Tap the reader several times");
  16. if(m->nonces == 0) {
  17. canvas_set_font(canvas, FontPrimary);
  18. canvas_draw_str_aligned(canvas, 52, 22, AlignLeft, AlignTop, "Emulating...");
  19. canvas_set_font(canvas, FontSecondary);
  20. canvas_draw_str_aligned(canvas, 52, 35, AlignLeft, AlignTop, "MIFARE Classic");
  21. canvas_draw_icon(canvas, 0, 13, &I_Tap_reader_36x38);
  22. } else {
  23. canvas_set_font(canvas, FontPrimary);
  24. canvas_draw_str_aligned(canvas, 54, 22, AlignLeft, AlignTop, "Collecting...");
  25. canvas_set_font(canvas, FontSecondary);
  26. snprintf(text, sizeof(text), "Nonces: %d", m->nonces);
  27. canvas_draw_str_aligned(canvas, 54, 35, AlignLeft, AlignTop, text);
  28. elements_button_right(canvas, "Next");
  29. canvas_draw_icon(canvas, 6, 15, &I_ArrowC_1_36x36);
  30. }
  31. }
  32. static bool detect_reader_input_callback(InputEvent* event, void* context) {
  33. DetectReader* detect_reader = context;
  34. furi_assert(detect_reader->callback);
  35. bool consumed = false;
  36. uint8_t nonces = 0;
  37. with_view_model(
  38. detect_reader->view, (DetectReaderViewModel * model) {
  39. nonces = model->nonces;
  40. return false;
  41. });
  42. if(event->type == InputTypeShort) {
  43. if(event->key == InputKeyRight) {
  44. if(nonces > 0) {
  45. detect_reader->callback(detect_reader->context);
  46. consumed = true;
  47. }
  48. }
  49. }
  50. return consumed;
  51. }
  52. DetectReader* detect_reader_alloc() {
  53. DetectReader* detect_reader = malloc(sizeof(DetectReader));
  54. detect_reader->view = view_alloc();
  55. view_allocate_model(detect_reader->view, ViewModelTypeLocking, sizeof(DetectReaderViewModel));
  56. view_set_draw_callback(detect_reader->view, detect_reader_draw_callback);
  57. view_set_input_callback(detect_reader->view, detect_reader_input_callback);
  58. view_set_context(detect_reader->view, detect_reader);
  59. return detect_reader;
  60. }
  61. void detect_reader_free(DetectReader* detect_reader) {
  62. furi_assert(detect_reader);
  63. view_free(detect_reader->view);
  64. free(detect_reader);
  65. }
  66. void detect_reader_reset(DetectReader* detect_reader) {
  67. furi_assert(detect_reader);
  68. with_view_model(
  69. detect_reader->view, (DetectReaderViewModel * model) {
  70. model->nonces = 0;
  71. return false;
  72. });
  73. }
  74. View* detect_reader_get_view(DetectReader* detect_reader) {
  75. furi_assert(detect_reader);
  76. return detect_reader->view;
  77. }
  78. void detect_reader_set_callback(
  79. DetectReader* detect_reader,
  80. DetectReaderDoneCallback callback,
  81. void* context) {
  82. furi_assert(detect_reader);
  83. furi_assert(callback);
  84. detect_reader->callback = callback;
  85. detect_reader->context = context;
  86. }
  87. void detect_reader_inc_nonce_cnt(DetectReader* detect_reader) {
  88. furi_assert(detect_reader);
  89. with_view_model(
  90. detect_reader->view, (DetectReaderViewModel * model) {
  91. model->nonces++;
  92. return false;
  93. });
  94. }