evil_portal_scene_console_output.c 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  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. app->sent_reset = false;
  33. if (0 == strncmp("help", app->selected_tx_string, strlen("help"))) {
  34. const char *help_msg =
  35. "BLUE = Waiting\nGREEN = Good\nRED = Bad\n\nThis project is a "
  36. "WIP.\ngithub.com/bigbrodude6119/flipper-zero-evil-portal\n\n"
  37. "Version 0.0.2\n\n";
  38. furi_string_cat_str(app->text_box_store, help_msg);
  39. app->text_box_store_strlen += strlen(help_msg);
  40. if (app->show_stopscan_tip) {
  41. const char *msg = "Press BACK to return\n";
  42. furi_string_cat_str(app->text_box_store, msg);
  43. app->text_box_store_strlen += strlen(msg);
  44. }
  45. }
  46. if (0 == strncmp("savelogs", app->selected_tx_string, strlen("savelogs"))) {
  47. const char *help_msg = "Logs saved.\n\n";
  48. furi_string_cat_str(app->text_box_store, help_msg);
  49. app->text_box_store_strlen += strlen(help_msg);
  50. write_logs(app->portal_logs);
  51. free(app->portal_logs);
  52. strcpy(app->portal_logs, "");
  53. if (app->show_stopscan_tip) {
  54. const char *msg = "Press BACK to return\n";
  55. furi_string_cat_str(app->text_box_store, msg);
  56. app->text_box_store_strlen += strlen(msg);
  57. }
  58. }
  59. if (0 ==
  60. strncmp(SET_HTML_CMD, app->selected_tx_string, strlen(SET_HTML_CMD))) {
  61. app->command_queue[0] = SET_AP_CMD;
  62. app->has_command_queue = true;
  63. app->command_index = 0;
  64. if (app->show_stopscan_tip) {
  65. const char *msg =
  66. "Starting portal\nIf no response press\nBACK to return\n";
  67. furi_string_cat_str(app->text_box_store, msg);
  68. app->text_box_store_strlen += strlen(msg);
  69. }
  70. }
  71. if (0 == strncmp(RESET_CMD, app->selected_tx_string, strlen(RESET_CMD))) {
  72. app->sent_reset = true;
  73. if (app->show_stopscan_tip) {
  74. const char *msg = "Reseting portal\nPress BACK to return\n\n\n\n";
  75. furi_string_cat_str(app->text_box_store, msg);
  76. app->text_box_store_strlen += strlen(msg);
  77. }
  78. }
  79. }
  80. text_box_set_text(app->text_box, furi_string_get_cstr(app->text_box_store));
  81. scene_manager_set_scene_state(app->scene_manager,
  82. Evil_PortalSceneConsoleOutput, 0);
  83. view_dispatcher_switch_to_view(app->view_dispatcher,
  84. Evil_PortalAppViewConsoleOutput);
  85. // Register callback to receive data
  86. evil_portal_uart_set_handle_rx_data_cb(
  87. app->uart, evil_portal_console_output_handle_rx_data_cb);
  88. if (app->is_command && app->selected_tx_string) {
  89. if (0 ==
  90. strncmp(SET_HTML_CMD, app->selected_tx_string, strlen(SET_HTML_CMD))) {
  91. evil_portal_read_index_html(context);
  92. char *data = malloc(
  93. (size_t)(strlen((char *)app->index_html) + strlen("sethtml=")));
  94. strcat(data, "sethtml=");
  95. strcat(data, (char *)app->index_html);
  96. evil_portal_uart_tx((uint8_t *)(data), strlen(data));
  97. evil_portal_uart_tx((uint8_t *)("\n"), 1);
  98. app->sent_html = true;
  99. free(data);
  100. free(app->index_html);
  101. evil_portal_read_ap_name(context);
  102. } else if (0 ==
  103. strncmp(RESET_CMD, app->selected_tx_string, strlen(RESET_CMD))) {
  104. app->sent_html = false;
  105. app->sent_ap = false;
  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. } else if (1 == strncmp("help", app->selected_tx_string, strlen("help"))) {
  110. evil_portal_uart_tx((uint8_t *)(app->selected_tx_string),
  111. strlen(app->selected_tx_string));
  112. evil_portal_uart_tx((uint8_t *)("\n"), 1);
  113. }
  114. }
  115. }
  116. bool evil_portal_scene_console_output_on_event(void *context,
  117. SceneManagerEvent event) {
  118. Evil_PortalApp *app = context;
  119. bool consumed = false;
  120. if (event.type == SceneManagerEventTypeCustom) {
  121. text_box_set_text(app->text_box, furi_string_get_cstr(app->text_box_store));
  122. consumed = true;
  123. } else if (event.type == SceneManagerEventTypeTick) {
  124. consumed = true;
  125. }
  126. return consumed;
  127. }
  128. void evil_portal_scene_console_output_on_exit(void *context) {
  129. Evil_PortalApp *app = context;
  130. // Unregister rx callback
  131. evil_portal_uart_set_handle_rx_data_cb(app->uart, NULL);
  132. }