bt_api.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. #include "bt_i.h"
  2. bool bt_set_profile(Bt* bt, BtProfile profile) {
  3. furi_assert(bt);
  4. // Send message
  5. bool result = false;
  6. BtMessage message = {
  7. .type = BtMessageTypeSetProfile, .data.profile = profile, .result = &result};
  8. furi_check(
  9. furi_message_queue_put(bt->message_queue, &message, FuriWaitForever) == FuriStatusOk);
  10. // Wait for unlock
  11. furi_event_flag_wait(bt->api_event, BT_API_UNLOCK_EVENT, FuriFlagWaitAny, FuriWaitForever);
  12. return result;
  13. }
  14. void bt_disconnect(Bt* bt) {
  15. furi_assert(bt);
  16. // Send message
  17. BtMessage message = {.type = BtMessageTypeDisconnect};
  18. furi_check(
  19. furi_message_queue_put(bt->message_queue, &message, FuriWaitForever) == FuriStatusOk);
  20. // Wait for unlock
  21. furi_event_flag_wait(bt->api_event, BT_API_UNLOCK_EVENT, FuriFlagWaitAny, FuriWaitForever);
  22. }
  23. void bt_set_status_changed_callback(Bt* bt, BtStatusChangedCallback callback, void* context) {
  24. furi_assert(bt);
  25. bt->status_changed_cb = callback;
  26. bt->status_changed_ctx = context;
  27. }
  28. void bt_forget_bonded_devices(Bt* bt) {
  29. furi_assert(bt);
  30. BtMessage message = {.type = BtMessageTypeForgetBondedDevices};
  31. furi_check(
  32. furi_message_queue_put(bt->message_queue, &message, FuriWaitForever) == FuriStatusOk);
  33. }
  34. void bt_keys_storage_set_storage_path(Bt* bt, const char* keys_storage_path) {
  35. furi_assert(bt);
  36. furi_assert(bt->keys_storage);
  37. furi_assert(keys_storage_path);
  38. bt_keys_storage_set_file_path(bt->keys_storage, keys_storage_path);
  39. }
  40. void bt_keys_storage_set_default_path(Bt* bt) {
  41. furi_assert(bt);
  42. furi_assert(bt->keys_storage);
  43. bt_keys_storage_set_file_path(bt->keys_storage, BT_KEYS_STORAGE_PATH);
  44. }