pin_lock.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. #include <notification/notification.h>
  2. #include <notification/notification_messages.h>
  3. #include <stddef.h>
  4. #include <furi.h>
  5. #include <furi_hal.h>
  6. #include <gui/gui.h>
  7. #include "../helpers/pin_lock.h"
  8. #include "../desktop_i.h"
  9. #include <cli/cli_vcp.h>
  10. static const NotificationSequence sequence_pin_fail = {
  11. &message_display_backlight_on,
  12. &message_red_255,
  13. &message_vibro_on,
  14. &message_delay_100,
  15. &message_vibro_off,
  16. &message_red_0,
  17. &message_delay_250,
  18. &message_red_255,
  19. &message_vibro_on,
  20. &message_delay_100,
  21. &message_vibro_off,
  22. &message_red_0,
  23. NULL,
  24. };
  25. static const uint8_t desktop_helpers_fails_timeout[] = {
  26. 0,
  27. 0,
  28. 0,
  29. 0,
  30. 30,
  31. 60,
  32. 90,
  33. 120,
  34. 150,
  35. 180,
  36. /* +60 for every next fail */
  37. };
  38. void desktop_pin_lock_error_notify() {
  39. NotificationApp* notification = furi_record_open("notification");
  40. notification_message(notification, &sequence_pin_fail);
  41. furi_record_close("notification");
  42. }
  43. uint32_t desktop_pin_lock_get_fail_timeout() {
  44. uint32_t pin_fails = furi_hal_rtc_get_pin_fails();
  45. uint32_t pin_timeout = 0;
  46. uint32_t max_index = COUNT_OF(desktop_helpers_fails_timeout) - 1;
  47. if(pin_fails <= max_index) {
  48. pin_timeout = desktop_helpers_fails_timeout[pin_fails];
  49. } else {
  50. pin_timeout = desktop_helpers_fails_timeout[max_index] + (pin_fails - max_index) * 60;
  51. }
  52. return pin_timeout;
  53. }
  54. void desktop_pin_lock(DesktopSettings* settings) {
  55. furi_assert(settings);
  56. furi_hal_rtc_set_pin_fails(0);
  57. furi_hal_rtc_set_flag(FuriHalRtcFlagLock);
  58. Cli* cli = furi_record_open("cli");
  59. cli_session_close(cli);
  60. furi_record_close("cli");
  61. settings->is_locked = 1;
  62. SAVE_DESKTOP_SETTINGS(settings);
  63. }
  64. void desktop_pin_unlock(DesktopSettings* settings) {
  65. furi_assert(settings);
  66. furi_hal_rtc_reset_flag(FuriHalRtcFlagLock);
  67. Cli* cli = furi_record_open("cli");
  68. cli_session_open(cli, &cli_vcp);
  69. furi_record_close("cli");
  70. settings->is_locked = 0;
  71. SAVE_DESKTOP_SETTINGS(settings);
  72. }
  73. void desktop_pin_lock_init(DesktopSettings* settings) {
  74. furi_assert(settings);
  75. if(settings->pin_code.length > 0) {
  76. if(settings->is_locked == 1) {
  77. furi_hal_rtc_set_flag(FuriHalRtcFlagLock);
  78. } else {
  79. if(desktop_pin_lock_is_locked()) {
  80. settings->is_locked = 1;
  81. SAVE_DESKTOP_SETTINGS(settings);
  82. }
  83. }
  84. } else {
  85. furi_hal_rtc_set_pin_fails(0);
  86. furi_hal_rtc_reset_flag(FuriHalRtcFlagLock);
  87. furi_hal_usb_enable();
  88. }
  89. if(desktop_pin_lock_is_locked()) {
  90. furi_hal_usb_disable();
  91. }
  92. }
  93. bool desktop_pin_lock_verify(const PinCode* pin_set, const PinCode* pin_entered) {
  94. bool result = false;
  95. if(desktop_pins_are_equal(pin_set, pin_entered)) {
  96. furi_hal_rtc_set_pin_fails(0);
  97. result = true;
  98. } else {
  99. uint32_t pin_fails = furi_hal_rtc_get_pin_fails();
  100. furi_hal_rtc_set_pin_fails(pin_fails + 1);
  101. result = false;
  102. }
  103. return result;
  104. }
  105. bool desktop_pin_lock_is_locked() {
  106. return furi_hal_rtc_is_flag_set(FuriHalRtcFlagLock);
  107. }
  108. bool desktop_pins_are_equal(const PinCode* pin_code1, const PinCode* pin_code2) {
  109. furi_assert(pin_code1);
  110. furi_assert(pin_code2);
  111. bool result = false;
  112. if(pin_code1->length == pin_code2->length) {
  113. result = !memcmp(pin_code1->data, pin_code2->data, pin_code1->length);
  114. }
  115. return result;
  116. }