hex_viewer_storage.c 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. #include "hex_viewer_storage.h"
  2. static Storage* hex_viewer_open_storage() {
  3. return furi_record_open(RECORD_STORAGE);
  4. }
  5. static void hex_viewer_close_storage() {
  6. furi_record_close(RECORD_STORAGE);
  7. }
  8. static void hex_viewer_close_config_file(FlipperFormat* file) {
  9. if (file == NULL) return;
  10. flipper_format_file_close(file);
  11. flipper_format_free(file);
  12. }
  13. void hex_viewer_save_settings(void* context) {
  14. HexViewer* app = context;
  15. if (app->save_settings == 0) {
  16. return;
  17. }
  18. FURI_LOG_D(TAG, "Saving Settings");
  19. Storage* storage = hex_viewer_open_storage();
  20. FlipperFormat* fff_file = flipper_format_file_alloc(storage);
  21. // Overwrite wont work, so delete first
  22. if(storage_file_exists(storage, HEX_VIEWER_SETTINGS_SAVE_PATH)) {
  23. storage_simply_remove(storage, HEX_VIEWER_SETTINGS_SAVE_PATH);
  24. }
  25. // Open File, create if not exists
  26. if(!storage_common_stat(storage, HEX_VIEWER_SETTINGS_SAVE_PATH, NULL) == FSE_OK) {
  27. FURI_LOG_D(TAG, "Config file %s is not found. Will create new.", HEX_VIEWER_SETTINGS_SAVE_PATH);
  28. if(storage_common_stat(storage, CONFIG_FILE_DIRECTORY_PATH, NULL) == FSE_NOT_EXIST) {
  29. FURI_LOG_D(
  30. TAG,
  31. "Directory %s doesn't exist. Will create new.",
  32. CONFIG_FILE_DIRECTORY_PATH);
  33. if(!storage_simply_mkdir(storage, CONFIG_FILE_DIRECTORY_PATH)) {
  34. FURI_LOG_E(TAG, "Error creating directory %s", CONFIG_FILE_DIRECTORY_PATH);
  35. }
  36. }
  37. }
  38. if(!flipper_format_file_open_new(fff_file, HEX_VIEWER_SETTINGS_SAVE_PATH)) {
  39. //totp_close_config_file(fff_file);
  40. FURI_LOG_E(TAG, "Error creating new file %s", HEX_VIEWER_SETTINGS_SAVE_PATH);
  41. hex_viewer_close_storage();
  42. return;
  43. }
  44. // Store Settings
  45. flipper_format_write_header_cstr(
  46. fff_file, HEX_VIEWER_SETTINGS_HEADER, HEX_VIEWER_SETTINGS_FILE_VERSION);
  47. flipper_format_write_uint32(
  48. fff_file, HEX_VIEWER_SETTINGS_KEY_HAPTIC, &app->haptic, 1);
  49. flipper_format_write_uint32(
  50. fff_file, HEX_VIEWER_SETTINGS_KEY_SPEAKER, &app->speaker, 1);
  51. flipper_format_write_uint32(
  52. fff_file, HEX_VIEWER_SETTINGS_KEY_LED, &app->led, 1);
  53. flipper_format_write_uint32(
  54. fff_file, HEX_VIEWER_SETTINGS_KEY_SAVE_SETTINGS, &app->save_settings, 1);
  55. if(!flipper_format_rewind(fff_file)) {
  56. hex_viewer_close_config_file(fff_file);
  57. FURI_LOG_E(TAG, "Rewind error");
  58. hex_viewer_close_storage();
  59. return;
  60. }
  61. hex_viewer_close_config_file(fff_file);
  62. hex_viewer_close_storage();
  63. }
  64. void hex_viewer_read_settings(void* context) {
  65. HexViewer* app = context;
  66. Storage* storage = hex_viewer_open_storage();
  67. FlipperFormat* fff_file = flipper_format_file_alloc(storage);
  68. if(storage_common_stat(storage, HEX_VIEWER_SETTINGS_SAVE_PATH, NULL) != FSE_OK) {
  69. hex_viewer_close_config_file(fff_file);
  70. hex_viewer_close_storage();
  71. return;
  72. }
  73. uint32_t file_version;
  74. FuriString* temp_str = furi_string_alloc();
  75. if (!flipper_format_file_open_existing(fff_file, HEX_VIEWER_SETTINGS_SAVE_PATH)) {
  76. FURI_LOG_E(TAG, "Cannot open file %s", HEX_VIEWER_SETTINGS_SAVE_PATH);
  77. hex_viewer_close_config_file(fff_file);
  78. hex_viewer_close_storage();
  79. return;
  80. }
  81. if(!flipper_format_read_header(fff_file, temp_str, &file_version)) {
  82. FURI_LOG_E(TAG, "Missing Header Data");
  83. hex_viewer_close_config_file(fff_file);
  84. hex_viewer_close_storage();
  85. return;
  86. }
  87. if(file_version < HEX_VIEWER_SETTINGS_FILE_VERSION) {
  88. FURI_LOG_I(TAG, "old config version, will be removed.");
  89. hex_viewer_close_config_file(fff_file);
  90. hex_viewer_close_storage();
  91. return;
  92. }
  93. flipper_format_read_uint32(fff_file, HEX_VIEWER_SETTINGS_KEY_HAPTIC, &app->haptic, 1);
  94. flipper_format_read_uint32(fff_file, HEX_VIEWER_SETTINGS_KEY_SPEAKER, &app->speaker, 1);
  95. flipper_format_read_uint32(fff_file, HEX_VIEWER_SETTINGS_KEY_LED, &app->led, 1);
  96. flipper_format_read_uint32(fff_file, HEX_VIEWER_SETTINGS_KEY_SAVE_SETTINGS, &app->save_settings, 1);
  97. flipper_format_rewind(fff_file);
  98. hex_viewer_close_config_file(fff_file);
  99. hex_viewer_close_storage();
  100. }
  101. bool hex_viewer_open_file(HexViewer* hex_viewer, const char* file_path) {
  102. furi_assert(hex_viewer);
  103. furi_assert(file_path);
  104. hex_viewer->model->stream = buffered_file_stream_alloc(hex_viewer->storage);
  105. bool isOk = true;
  106. do {
  107. if(!buffered_file_stream_open(
  108. hex_viewer->model->stream, file_path, FSAM_READ, FSOM_OPEN_EXISTING)) {
  109. FURI_LOG_E(TAG, "Unable to open stream: %s", file_path);
  110. isOk = false;
  111. break;
  112. };
  113. hex_viewer->model->file_size = stream_size(hex_viewer->model->stream);
  114. } while(false);
  115. return isOk;
  116. }
  117. bool hex_viewer_read_file(HexViewer* hex_viewer) {
  118. furi_assert(hex_viewer);
  119. furi_assert(hex_viewer->model->stream);
  120. furi_assert(hex_viewer->model->file_offset % HEX_VIEWER_BYTES_PER_LINE == 0);
  121. memset(hex_viewer->model->file_bytes, 0x0, HEX_VIEWER_BUF_SIZE);
  122. bool isOk = true;
  123. do {
  124. uint32_t offset = hex_viewer->model->file_offset;
  125. if(!stream_seek(hex_viewer->model->stream, offset, true)) {
  126. FURI_LOG_E(TAG, "Unable to seek stream");
  127. isOk = false;
  128. break;
  129. }
  130. hex_viewer->model->file_read_bytes = stream_read(
  131. hex_viewer->model->stream,
  132. (uint8_t*)hex_viewer->model->file_bytes,
  133. HEX_VIEWER_BUF_SIZE);
  134. } while(false);
  135. return isOk;
  136. }