evil_portal_scene_console_output.c 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  1. #include "../evil_portal_app_i.h"
  2. #include "../helpers/evil_portal_storage.h"
  3. #include <m-string.h>
  4. void evil_portal_console_output_handle_rx_data_cb(uint8_t* buf, size_t len, void* context) {
  5. furi_assert(context);
  6. Evil_PortalApp* app = context;
  7. if(app->capture_line) {
  8. furi_string_cat_printf(app->captured_line, "%s", buf);
  9. }
  10. // If text box store gets too big, then truncate it
  11. app->text_box_store_strlen += len;
  12. if(app->text_box_store_strlen >= EVIL_PORTAL_TEXT_BOX_STORE_SIZE - 1) {
  13. furi_string_right(app->text_box_store, app->text_box_store_strlen / 2);
  14. app->text_box_store_strlen = furi_string_size(app->text_box_store) + len;
  15. }
  16. // Null-terminate buf and append to text box store
  17. buf[len] = '\0';
  18. furi_string_cat_printf(app->text_box_store, "%s", buf);
  19. text_box_set_text(app->text_box, furi_string_get_cstr(app->text_box_store));
  20. }
  21. static inline bool captured(Evil_PortalApp* app, const char* str) {
  22. return furi_string_search_str(app->captured_line, str) != STRING_FAILURE;
  23. }
  24. void evil_portal_scene_console_output_on_enter(void* context) {
  25. Evil_PortalApp* app = context;
  26. TextBox* text_box = app->text_box;
  27. text_box_reset(app->text_box);
  28. text_box_set_font(text_box, TextBoxFontText);
  29. if(app->focus_console_start) {
  30. text_box_set_focus(text_box, TextBoxFocusStart);
  31. } else {
  32. text_box_set_focus(text_box, TextBoxFocusEnd);
  33. }
  34. if(app->is_command) {
  35. furi_string_reset(app->text_box_store);
  36. app->text_box_store_strlen = 0;
  37. app->sent_reset = false;
  38. if(0 == strncmp("help", app->selected_tx_string, strlen("help"))) {
  39. const char* help_msg = "BLUE = Waiting\nGREEN = Good\nRED = Bad\n\nThis project is a "
  40. "WIP.\ngithub.com/bigbrodude6119/flipper-zero-evil-portal\n\n"
  41. "Version 0.0.2\n\n";
  42. furi_string_cat_str(app->text_box_store, help_msg);
  43. app->text_box_store_strlen += strlen(help_msg);
  44. if(app->show_stopscan_tip) {
  45. const char* msg = "Press BACK to return\n";
  46. furi_string_cat_str(app->text_box_store, msg);
  47. app->text_box_store_strlen += strlen(msg);
  48. }
  49. }
  50. if(0 == strncmp("savelogs", app->selected_tx_string, strlen("savelogs"))) {
  51. const char* help_msg = "Logs saved.\n\n";
  52. furi_string_cat_str(app->text_box_store, help_msg);
  53. app->text_box_store_strlen += strlen(help_msg);
  54. furi_mutex_acquire(app->portal_logs_mutex, FuriWaitForever);
  55. write_logs(app->portal_logs);
  56. furi_string_reset(app->portal_logs);
  57. furi_mutex_release(app->portal_logs_mutex);
  58. if(app->show_stopscan_tip) {
  59. const char* msg = "Press BACK to return\n";
  60. furi_string_cat_str(app->text_box_store, msg);
  61. app->text_box_store_strlen += strlen(msg);
  62. }
  63. }
  64. if(0 == strncmp("setapname", app->selected_tx_string, strlen("setapname"))) {
  65. scene_manager_next_scene(app->scene_manager, Evil_PortalSceneRename);
  66. return;
  67. }
  68. if(0 == strncmp("selecthtml", app->selected_tx_string, strlen("selecthtml"))) {
  69. scene_manager_next_scene(app->scene_manager, Evil_PortalSceneSelectHtml);
  70. return;
  71. }
  72. if(0 == strncmp(SET_HTML_CMD, app->selected_tx_string, strlen(SET_HTML_CMD))) {
  73. if(app->show_stopscan_tip) {
  74. const char* msg =
  75. "Starting portal\nMarauder takes a few secs to start\nPress BACK to return\n";
  76. furi_string_cat_str(app->text_box_store, msg);
  77. app->text_box_store_strlen += strlen(msg);
  78. }
  79. }
  80. if(0 == strncmp(RESET_CMD, app->selected_tx_string, strlen(RESET_CMD))) {
  81. app->sent_reset = true;
  82. if(app->show_stopscan_tip) {
  83. const char* msg = "Reseting portal\nPress BACK to return\n\n\n\n";
  84. furi_string_cat_str(app->text_box_store, msg);
  85. app->text_box_store_strlen += strlen(msg);
  86. }
  87. }
  88. }
  89. text_box_set_text(app->text_box, furi_string_get_cstr(app->text_box_store));
  90. scene_manager_set_scene_state(app->scene_manager, Evil_PortalSceneConsoleOutput, 0);
  91. view_dispatcher_switch_to_view(app->view_dispatcher, Evil_PortalAppViewConsoleOutput);
  92. // Register callback to receive data
  93. evil_portal_uart_set_handle_rx_data_cb(
  94. app->uart, evil_portal_console_output_handle_rx_data_cb);
  95. if(app->is_command && app->selected_tx_string) {
  96. if(0 == strncmp(SET_HTML_CMD, app->selected_tx_string, strlen(SET_HTML_CMD))) {
  97. FuriString* data = furi_string_alloc();
  98. app->capture_line = true;
  99. evil_portal_read_ap_name(context);
  100. // Test evil portal syntax and response, marauder ignores it
  101. furi_string_printf(data, "setap=%s\n", (char*)app->ap_name);
  102. furi_string_reset(app->captured_line);
  103. evil_portal_uart_tx((uint8_t*)(furi_string_get_cstr(data)), furi_string_size(data));
  104. // For some reason evil portal messes up "ap set" with newlines and random letters, "p set" works
  105. for(uint8_t t = 0; t < 20 && !captured(app, "p set"); t++) furi_delay_ms(100);
  106. bool icanhazmarauder = !captured(app, "p set"); // Evil portal didn't respond
  107. // Not evil portal, set up marauder
  108. if(icanhazmarauder) {
  109. furi_string_printf(data, "clearlist -s\nssid -a -n '%s'\n", app->ap_name);
  110. furi_string_reset(app->captured_line);
  111. evil_portal_uart_tx(
  112. (uint8_t*)(furi_string_get_cstr(data)), furi_string_size(data));
  113. // Marauder echoes the command, maybe still init so wait a while for echo
  114. for(uint8_t t = 0; t < 42 && !captured(app, (char*)app->ap_name); t++)
  115. furi_delay_ms(100);
  116. }
  117. free(app->ap_name);
  118. evil_portal_read_index_html(context);
  119. if(icanhazmarauder) {
  120. furi_string_reset(app->captured_line);
  121. evil_portal_uart_tx(
  122. (uint8_t*)("evilportal -c sethtmlstr\n"),
  123. strlen("evilportal -c sethtmlstr\n"));
  124. for(uint8_t t = 0; t < 5 && !captured(app, "Setting HTML from serial..."); t++)
  125. furi_delay_ms(100);
  126. // Check for active attack
  127. if(captured(app, ">") && !captured(app, "Setting HTML from serial...")) {
  128. furi_string_reset(app->captured_line);
  129. } else {
  130. furi_string_reset(app->captured_line);
  131. evil_portal_uart_tx(app->index_html, strlen((char*)app->index_html));
  132. evil_portal_uart_tx((uint8_t*)("\n"), 1);
  133. for(uint8_t t = 0; t < 15 && !captured(app, "html set"); t++)
  134. furi_delay_ms(100);
  135. furi_delay_ms(100);
  136. evil_portal_uart_tx(
  137. (uint8_t*)("evilportal -c start\n"), strlen("evilportal -c start\n"));
  138. }
  139. } else {
  140. furi_string_set(data, "sethtml=");
  141. furi_string_cat(data, (char*)app->index_html);
  142. evil_portal_uart_tx(
  143. (uint8_t*)(furi_string_get_cstr(data)), strlen(furi_string_get_cstr(data)));
  144. evil_portal_uart_tx((uint8_t*)("\n"), 1);
  145. }
  146. free(app->index_html);
  147. app->capture_line = false;
  148. furi_string_reset(app->captured_line);
  149. furi_string_free(data);
  150. } else if(0 == strncmp(RESET_CMD, app->selected_tx_string, strlen(RESET_CMD))) {
  151. evil_portal_uart_tx(
  152. (uint8_t*)(app->selected_tx_string), strlen(app->selected_tx_string));
  153. evil_portal_uart_tx((uint8_t*)("\n"), 1);
  154. evil_portal_uart_tx((uint8_t*)("stopscan\n"), strlen("stopscan\n"));
  155. } else if(1 == strncmp("help", app->selected_tx_string, strlen("help"))) {
  156. evil_portal_uart_tx(
  157. (uint8_t*)(app->selected_tx_string), strlen(app->selected_tx_string));
  158. evil_portal_uart_tx((uint8_t*)("\n"), 1);
  159. }
  160. }
  161. }
  162. bool evil_portal_scene_console_output_on_event(void* context, SceneManagerEvent event) {
  163. UNUSED(context);
  164. bool consumed = false;
  165. if(event.type == SceneManagerEventTypeTick) {
  166. consumed = true;
  167. }
  168. return consumed;
  169. }
  170. void evil_portal_scene_console_output_on_exit(void* context) {
  171. Evil_PortalApp* app = context;
  172. // Unregister rx callback
  173. evil_portal_uart_set_handle_rx_data_cb(app->uart, NULL);
  174. }