evil_portal_scene_console_output.c 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. #include "../evil_portal_app_i.h"
  2. #include "../helpers/evil_portal_storage.h"
  3. void evil_portal_console_output_handle_rx_data_cb(uint8_t *buf, size_t len,
  4. void *context) {
  5. furi_assert(context);
  6. Evil_PortalApp *app = context;
  7. // If text box store gets too big, then truncate it
  8. app->text_box_store_strlen += len;
  9. if (app->text_box_store_strlen >= EVIL_PORTAL_TEXT_BOX_STORE_SIZE - 1) {
  10. furi_string_right(app->text_box_store, app->text_box_store_strlen / 2);
  11. app->text_box_store_strlen = furi_string_size(app->text_box_store) + len;
  12. }
  13. // Null-terminate buf and append to text box store
  14. buf[len] = '\0';
  15. furi_string_cat_printf(app->text_box_store, "%s", buf);
  16. view_dispatcher_send_custom_event(app->view_dispatcher,
  17. Evil_PortalEventRefreshConsoleOutput);
  18. }
  19. void evil_portal_scene_console_output_on_enter(void *context) {
  20. Evil_PortalApp *app = context;
  21. TextBox *text_box = app->text_box;
  22. text_box_reset(app->text_box);
  23. text_box_set_font(text_box, TextBoxFontText);
  24. if (app->focus_console_start) {
  25. text_box_set_focus(text_box, TextBoxFocusStart);
  26. } else {
  27. text_box_set_focus(text_box, TextBoxFocusEnd);
  28. }
  29. if (app->is_command) {
  30. furi_string_reset(app->text_box_store);
  31. app->text_box_store_strlen = 0;
  32. if (0 == strncmp("help", app->selected_tx_string, strlen("help"))) {
  33. const char *help_msg =
  34. "BLUE = Waiting\nGREEN = Good\nRED = Bad\n\nThis project is a "
  35. "WIP.\ngithub.com/bigbrodude6119/flipper-zero-evil-portal\n\n";
  36. furi_string_cat_str(app->text_box_store, help_msg);
  37. app->text_box_store_strlen += strlen(help_msg);
  38. if (app->show_stopscan_tip) {
  39. const char *msg = "Press BACK to return\n";
  40. furi_string_cat_str(app->text_box_store, msg);
  41. app->text_box_store_strlen += strlen(msg);
  42. }
  43. }
  44. if (0 == strncmp("savelogs", app->selected_tx_string, strlen("savelogs"))) {
  45. const char *help_msg = "Logs saved.\n\n";
  46. furi_string_cat_str(app->text_box_store, help_msg);
  47. app->text_box_store_strlen += strlen(help_msg);
  48. if(strlen(app->portal_logs) > 0) {
  49. write_logs(app->portal_logs);
  50. free(app->portal_logs);
  51. }
  52. if (app->show_stopscan_tip) {
  53. const char *msg = "Press BACK to return\n";
  54. furi_string_cat_str(app->text_box_store, msg);
  55. app->text_box_store_strlen += strlen(msg);
  56. }
  57. }
  58. if (0 == strncmp(SET_HTML_CMD, app->selected_tx_string, strlen(SET_HTML_CMD))) {
  59. app->command_queue[0] = SET_AP_CMD;
  60. app->has_command_queue = true;
  61. app->command_index = 0;
  62. if (app->show_stopscan_tip) {
  63. const char *msg =
  64. "Starting portal\nIf no response press\nBACK to return\n";
  65. furi_string_cat_str(app->text_box_store, msg);
  66. app->text_box_store_strlen += strlen(msg);
  67. }
  68. }
  69. if (0 == strncmp(RESET_CMD, app->selected_tx_string, strlen(RESET_CMD))) {
  70. if (app->show_stopscan_tip) {
  71. const char *msg = "Reseting portal\nPress BACK to return\n\n\n\n";
  72. furi_string_cat_str(app->text_box_store, msg);
  73. app->text_box_store_strlen += strlen(msg);
  74. }
  75. }
  76. }
  77. text_box_set_text(app->text_box, furi_string_get_cstr(app->text_box_store));
  78. scene_manager_set_scene_state(app->scene_manager,
  79. Evil_PortalSceneConsoleOutput, 0);
  80. view_dispatcher_switch_to_view(app->view_dispatcher,
  81. Evil_PortalAppViewConsoleOutput);
  82. // Register callback to receive data
  83. evil_portal_uart_set_handle_rx_data_cb(
  84. app->uart, evil_portal_console_output_handle_rx_data_cb);
  85. if (app->is_command && app->selected_tx_string) {
  86. if (0 == strncmp(SET_HTML_CMD, app->selected_tx_string, strlen(SET_HTML_CMD))) {
  87. evil_portal_read_index_html(context);
  88. char *data = malloc(
  89. (size_t)(strlen((char *)app->index_html) + strlen("sethtml=")));
  90. strcat(data, "sethtml=");
  91. strcat(data, (char *)app->index_html);
  92. evil_portal_uart_tx((uint8_t *)(data), strlen(data));
  93. evil_portal_uart_tx((uint8_t *)("\n"), 1);
  94. app->sent_html = true;
  95. free(data);
  96. free(app->index_html);
  97. evil_portal_read_ap_name(context);
  98. } else if (0 ==
  99. strncmp(RESET_CMD, app->selected_tx_string, strlen(RESET_CMD))) {
  100. app->sent_html = false;
  101. app->sent_ap = false;
  102. evil_portal_uart_tx((uint8_t *)(app->selected_tx_string),
  103. strlen(app->selected_tx_string));
  104. evil_portal_uart_tx((uint8_t *)("\n"), 1);
  105. } else if (1 == strncmp("help", app->selected_tx_string, strlen("help"))) {
  106. evil_portal_uart_tx((uint8_t *)(app->selected_tx_string),
  107. strlen(app->selected_tx_string));
  108. evil_portal_uart_tx((uint8_t *)("\n"), 1);
  109. }
  110. }
  111. }
  112. bool evil_portal_scene_console_output_on_event(void *context,
  113. SceneManagerEvent event) {
  114. Evil_PortalApp *app = context;
  115. bool consumed = false;
  116. if (event.type == SceneManagerEventTypeCustom) {
  117. text_box_set_text(app->text_box, furi_string_get_cstr(app->text_box_store));
  118. consumed = true;
  119. } else if (event.type == SceneManagerEventTypeTick) {
  120. consumed = true;
  121. }
  122. return consumed;
  123. }
  124. void evil_portal_scene_console_output_on_exit(void *context) {
  125. Evil_PortalApp *app = context;
  126. // Unregister rx callback
  127. evil_portal_uart_set_handle_rx_data_cb(app->uart, NULL);
  128. }