pin_lock.c 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  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. static const NotificationSequence sequence_pin_fail = {
  10. &message_display_on,
  11. &message_red_255,
  12. &message_vibro_on,
  13. &message_delay_100,
  14. &message_vibro_off,
  15. &message_red_0,
  16. &message_delay_250,
  17. &message_red_255,
  18. &message_vibro_on,
  19. &message_delay_100,
  20. &message_vibro_off,
  21. &message_red_0,
  22. NULL,
  23. };
  24. static const uint8_t desktop_helpers_fails_timeout[] = {
  25. 0,
  26. 0,
  27. 0,
  28. 0,
  29. 30,
  30. 60,
  31. 90,
  32. 120,
  33. 150,
  34. 180,
  35. /* +60 for every next fail */
  36. };
  37. void desktop_pin_lock_error_notify() {
  38. NotificationApp* notification = furi_record_open("notification");
  39. notification_message(notification, &sequence_pin_fail);
  40. furi_record_close("notification");
  41. }
  42. uint32_t desktop_pin_lock_get_fail_timeout() {
  43. uint32_t pin_fails = furi_hal_rtc_get_pin_fails();
  44. uint32_t pin_timeout = 0;
  45. uint32_t max_index = COUNT_OF(desktop_helpers_fails_timeout) - 1;
  46. if(pin_fails <= max_index) {
  47. pin_timeout = desktop_helpers_fails_timeout[pin_fails];
  48. } else {
  49. pin_timeout = desktop_helpers_fails_timeout[max_index] + (pin_fails - max_index) * 60;
  50. }
  51. return pin_timeout;
  52. }
  53. void desktop_pin_lock() {
  54. furi_hal_rtc_set_pin_fails(0);
  55. furi_hal_rtc_set_flag(FuriHalRtcFlagLock);
  56. furi_hal_usb_disable();
  57. }
  58. void desktop_pin_unlock() {
  59. furi_hal_rtc_reset_flag(FuriHalRtcFlagLock);
  60. furi_hal_usb_enable();
  61. }
  62. void desktop_pin_lock_init(DesktopSettings* settings) {
  63. if(settings->pin_code.length > 0) {
  64. furi_hal_rtc_set_flag(FuriHalRtcFlagLock);
  65. furi_hal_usb_disable();
  66. } else {
  67. furi_hal_rtc_reset_flag(FuriHalRtcFlagLock);
  68. furi_hal_usb_enable();
  69. }
  70. }
  71. bool desktop_pin_lock_verify(const PinCode* pin_set, const PinCode* pin_entered) {
  72. bool result = false;
  73. if(desktop_pins_are_equal(pin_set, pin_entered)) {
  74. furi_hal_rtc_set_pin_fails(0);
  75. result = true;
  76. } else {
  77. uint32_t pin_fails = furi_hal_rtc_get_pin_fails();
  78. furi_hal_rtc_set_pin_fails(pin_fails + 1);
  79. result = false;
  80. }
  81. return result;
  82. }
  83. bool desktop_pin_lock_is_locked() {
  84. return furi_hal_rtc_is_flag_set(FuriHalRtcFlagLock);
  85. }
  86. bool desktop_pins_are_equal(const PinCode* pin_code1, const PinCode* pin_code2) {
  87. furi_assert(pin_code1);
  88. furi_assert(pin_code2);
  89. bool result = false;
  90. if(pin_code1->length == pin_code2->length) {
  91. result = !memcmp(pin_code1->data, pin_code2->data, pin_code1->length);
  92. }
  93. return result;
  94. }