flipbip_file.c 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. #include "flipbip_file.h"
  2. #include "../helpers/flipbip_string.h"
  3. #include "../crypto/memzero.h"
  4. #include "../crypto/rand.h"
  5. #include <storage/storage.h>
  6. #define FLIPBIP_APP_BASE_FOLDER EXT_PATH("apps_data/flipbip")
  7. // #define FLIPBIP_DAT_FILE_NAME ".flipbip.dat"
  8. #define FLIPBIP_DAT_FILE_NAME ".flipbip.dat.txt"
  9. #define FLIPBIP_DAT_FILE_NAME_BAK ".flipbip.dat.bak"
  10. // #define FLIPBIP_KEY_FILE_NAME ".flipbip.key"
  11. #define FLIPBIP_KEY_FILE_NAME ".flipbip.key.txt"
  12. #define FLIPBIP_KEY_FILE_NAME_BAK ".flipbip.key.bak"
  13. #define FLIPBIP_DAT_PATH FLIPBIP_APP_BASE_FOLDER "/" FLIPBIP_DAT_FILE_NAME
  14. #define FLIPBIP_DAT_PATH_BAK FLIPBIP_APP_BASE_FOLDER "/" FLIPBIP_DAT_FILE_NAME_BAK
  15. #define FLIPBIP_KEY_PATH FLIPBIP_APP_BASE_FOLDER "/" FLIPBIP_KEY_FILE_NAME
  16. #define FLIPBIP_KEY_PATH_BAK FLIPBIP_APP_BASE_FOLDER "/" FLIPBIP_KEY_FILE_NAME_BAK
  17. const size_t FILE_HLEN = 4;
  18. const size_t FILE_KLEN = 256;
  19. const size_t FILE_SLEN = 512;
  20. const char* FILE_HSTR = "fb01";
  21. const char* FILE_K1 = "fb0131d5cf688221c109163908ebe51debb46227c6cc8b37641910833222772a"
  22. "baefe6d9ceb651842260e0d1e05e3b90d15e7d5ffaaabc0207bf200a117793a2";
  23. bool flipbip_load_settings(char* settings, bool key_file) {
  24. Storage *fs_api = furi_record_open(RECORD_STORAGE);
  25. File* settings_file = storage_file_alloc(fs_api);
  26. const char* path;
  27. if(key_file) {
  28. path = FLIPBIP_KEY_PATH;
  29. } else {
  30. path = FLIPBIP_DAT_PATH;
  31. }
  32. if(storage_file_open(settings_file, path, FSAM_READ, FSOM_OPEN_EXISTING)) {
  33. char chr;
  34. int i = 0;
  35. while((storage_file_read(settings_file, &chr, 1) == 1) &&
  36. !storage_file_eof(settings_file) && !isspace(chr)) {
  37. settings[i] = chr;
  38. i++;
  39. }
  40. } else {
  41. memzero(settings, strlen(settings));
  42. settings[0] = '\0';
  43. return false;
  44. }
  45. storage_file_close(settings_file);
  46. storage_file_free(settings_file);
  47. furi_record_close(RECORD_STORAGE);
  48. if(!strlen(settings) == 0) {
  49. Storage* fs_api = furi_record_open(RECORD_STORAGE);
  50. FileInfo layout_file_info;
  51. FS_Error file_check_err = storage_common_stat(
  52. fs_api, path, &layout_file_info);
  53. furi_record_close(RECORD_STORAGE);
  54. if(file_check_err != FSE_OK) {
  55. memzero(settings, strlen(settings));
  56. settings[0] = '\0';
  57. return false;
  58. }
  59. // if(layout_file_info.size != 256) {
  60. // memzero(settings, strlen(settings));
  61. // settings[0] = '\0';
  62. // }
  63. }
  64. return true;
  65. }
  66. bool flipbip_save_settings(const char* settings, bool key_file, bool append) {
  67. Storage* fs_api = furi_record_open(RECORD_STORAGE);
  68. storage_common_mkdir(fs_api, FLIPBIP_APP_BASE_FOLDER);
  69. int open_mode = FSOM_OPEN_ALWAYS;
  70. if(append) {
  71. open_mode = FSOM_OPEN_APPEND;
  72. }
  73. File* settings_file = storage_file_alloc(fs_api);
  74. const char* path;
  75. const char* path_bak;
  76. if(key_file) {
  77. path = FLIPBIP_KEY_PATH;
  78. path_bak = FLIPBIP_KEY_PATH_BAK;
  79. } else {
  80. path = FLIPBIP_DAT_PATH;
  81. path_bak = FLIPBIP_DAT_PATH_BAK;
  82. }
  83. if(storage_file_open(settings_file, path, FSAM_WRITE, open_mode)) {
  84. storage_file_write(
  85. settings_file,
  86. settings,
  87. strlen(settings));
  88. storage_file_write(settings_file, "\n", 1);
  89. }
  90. storage_file_close(settings_file);
  91. storage_file_free(settings_file);
  92. File* settings_file_bak = storage_file_alloc(fs_api);
  93. if(storage_file_open(settings_file_bak, path_bak, FSAM_WRITE, open_mode)) {
  94. storage_file_write(
  95. settings_file_bak,
  96. settings,
  97. strlen(settings));
  98. storage_file_write(settings_file_bak, "\n", 1);
  99. }
  100. storage_file_close(settings_file_bak);
  101. storage_file_free(settings_file_bak);
  102. furi_record_close(RECORD_STORAGE);
  103. return true;
  104. }
  105. bool flipbip_load_settings_secure(char* settings) {
  106. const size_t dlen = FILE_HLEN + FILE_SLEN + 1;
  107. // allocate memory for key/data
  108. char *data = malloc(dlen);
  109. memzero(data, dlen);
  110. // load k2 from file
  111. if (!flipbip_load_settings(data, true)) return false;
  112. // check header
  113. if (data[0] != FILE_HSTR[0] || data[1] != FILE_HSTR[1] || data[2] != FILE_HSTR[2] || data[3] != FILE_HSTR[3]) {
  114. memzero(data, dlen);
  115. free(data);
  116. return false;
  117. }
  118. // seek --> header
  119. data += FILE_HLEN;
  120. // prepare k1
  121. uint8_t k1[64];
  122. flipbip_xtob(FILE_K1, k1, strlen(FILE_K1) / 2);
  123. // load k2 from file buffer (secured by k1)
  124. flipbip_cipher(k1, strlen(FILE_K1) / 2, data, data, FILE_KLEN);
  125. uint8_t k2[128];
  126. flipbip_xtob(data, k2, FILE_KLEN / 2);
  127. // zero k2 buffer
  128. memzero(data, FILE_KLEN);
  129. // seek <-- header
  130. data -= FILE_HLEN;
  131. // load data from file
  132. if (!flipbip_load_settings(data, false)) return false;
  133. // check header
  134. if (data[0] != FILE_HSTR[0] || data[1] != FILE_HSTR[1] || data[2] != FILE_HSTR[2] || data[3] != FILE_HSTR[3]) {
  135. memzero(data, dlen);
  136. free(data);
  137. return false;
  138. }
  139. // seek --> header
  140. data += FILE_HLEN;
  141. // load settings from file buffer (secured by k2)
  142. flipbip_cipher(k2, FILE_KLEN / 2, data, data, FILE_SLEN);
  143. flipbip_xtob(data, (unsigned char*)data, FILE_SLEN / 2);
  144. // copy to output
  145. strcpy(settings, data);
  146. // seek <-- header
  147. data -= FILE_HLEN;
  148. // clear memory
  149. memzero(data, dlen);
  150. free(data);
  151. return true;
  152. }
  153. bool flipbip_save_settings_secure(const char* settings) {
  154. const size_t dlen = FILE_HLEN + FILE_SLEN + 1;
  155. // cap settings to 256 bytes
  156. size_t len = strlen(settings);
  157. if (len > (FILE_SLEN / 2)) len = FILE_SLEN / 2;
  158. // allocate memory for key/data
  159. char *data = malloc(dlen);
  160. memzero(data, dlen);
  161. // write header
  162. strncpy(data, FILE_HSTR, FILE_HLEN);
  163. // seek --> header
  164. data += FILE_HLEN;
  165. // prepare k1
  166. uint8_t k1[64];
  167. flipbip_xtob(FILE_K1, k1, strlen(FILE_K1) / 2);
  168. // generate k2
  169. uint8_t k2[128];
  170. random_buffer(k2, FILE_KLEN / 2);
  171. // write k2 to file buffer (secured by k1)
  172. for (size_t i = 0; i < (FILE_KLEN / 2); i++) {
  173. flipbip_btox(k2[i], data + (i * 2));
  174. }
  175. flipbip_cipher(k1, strlen(FILE_K1) / 2, data, data, FILE_KLEN);
  176. // seek <-- header
  177. data -= FILE_HLEN;
  178. // save k2 to file
  179. flipbip_save_settings(data, true, false);
  180. // seek --> header
  181. data += FILE_HLEN;
  182. // zero k2 memory
  183. memzero(data, FILE_KLEN);
  184. // write settings to file buffer (secured by k2)
  185. for (size_t i = 0; i < len; i++) {
  186. flipbip_btox((uint8_t)settings[i], data + (i * 2));
  187. }
  188. flipbip_cipher(k2, FILE_KLEN / 2, data, data, FILE_SLEN);
  189. // seek <-- header
  190. data -= FILE_HLEN;
  191. // save data to file
  192. flipbip_save_settings(data, false, false);
  193. // clear memory
  194. memzero(data, dlen);
  195. free(data);
  196. return true;
  197. }