CommandLine.cpp 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759
  1. #include "CommandLine.h"
  2. CommandLine::CommandLine() {
  3. }
  4. void CommandLine::RunSetup() {
  5. Serial.println(this->ascii_art);
  6. Serial.println(F("\n\n--------------------------------\n"));
  7. Serial.println(F(" ESP32 Marauder \n"));
  8. Serial.println(" " + version_number + "\n");
  9. Serial.println(F(" By: justcallmekoko\n"));
  10. Serial.println(F("--------------------------------\n\n"));
  11. Serial.print("> ");
  12. }
  13. String CommandLine::getSerialInput() {
  14. String input = "";
  15. if (Serial.available() > 0)
  16. input = Serial.readStringUntil('\n');
  17. input.trim();
  18. return input;
  19. }
  20. void CommandLine::main(uint32_t currentTime) {
  21. String input = this->getSerialInput();
  22. this->runCommand(input);
  23. if (input != "")
  24. Serial.print("> ");
  25. }
  26. LinkedList<String> CommandLine::parseCommand(String input, char* delim) {
  27. LinkedList<String> cmd_args;
  28. if (input != "") {
  29. char fancy[input.length() + 1] = {};
  30. input.toCharArray(fancy, input.length() + 1);
  31. char* ptr = strtok(fancy, delim);
  32. while (ptr != NULL) {
  33. cmd_args.add(String(ptr));
  34. ptr = strtok(NULL, delim);
  35. }
  36. }
  37. return cmd_args;
  38. }
  39. int CommandLine::argSearch(LinkedList<String>* cmd_args_list, String key) {
  40. for (int i = 0; i < cmd_args_list->size(); i++) {
  41. if (cmd_args_list->get(i) == key)
  42. return i;
  43. }
  44. return -1;
  45. }
  46. bool CommandLine::checkValueExists(LinkedList<String>* cmd_args_list, int index) {
  47. if (index < cmd_args_list->size() - 1)
  48. return true;
  49. return false;
  50. }
  51. bool CommandLine::inRange(int max, int index) {
  52. if ((index >= 0) && (index < max))
  53. return true;
  54. return false;
  55. }
  56. bool CommandLine::apSelected() {
  57. for (int i = 0; i < access_points->size(); i++) {
  58. if (access_points->get(i).selected)
  59. return true;
  60. }
  61. return false;
  62. }
  63. bool CommandLine::hasSSIDs() {
  64. if (ssids->size() == 0)
  65. return false;
  66. return true;
  67. }
  68. void CommandLine::runCommand(String input) {
  69. if (input != "")
  70. Serial.println("#" + input);
  71. else
  72. return;
  73. LinkedList<String> cmd_args = this->parseCommand(input, " ");
  74. //// Admin commands
  75. // Help
  76. if (cmd_args.get(0) == HELP_CMD) {
  77. Serial.println(HELP_HEAD);
  78. Serial.println(HELP_CH_CMD);
  79. Serial.println(HELP_SETTINGS_CMD);
  80. Serial.println(HELP_CLEARAP_CMD_A);
  81. Serial.println(HELP_REBOOT_CMD);
  82. Serial.println(HELP_UPDATE_CMD_A);
  83. // WiFi sniff/scan
  84. Serial.println(HELP_SCANAP_CMD);
  85. Serial.println(HELP_SCANSTA_CMD);
  86. Serial.println(HELP_SNIFF_RAW_CMD);
  87. Serial.println(HELP_SNIFF_BEACON_CMD);
  88. Serial.println(HELP_SNIFF_PROBE_CMD);
  89. Serial.println(HELP_SNIFF_PWN_CMD);
  90. Serial.println(HELP_SNIFF_ESP_CMD);
  91. Serial.println(HELP_SNIFF_DEAUTH_CMD);
  92. Serial.println(HELP_SNIFF_PMKID_CMD);
  93. Serial.println(HELP_STOPSCAN_CMD);
  94. // WiFi attack
  95. Serial.println(HELP_ATTACK_CMD);
  96. // WiFi Aux
  97. Serial.println(HELP_LIST_AP_CMD_A);
  98. Serial.println(HELP_LIST_AP_CMD_B);
  99. Serial.println(HELP_LIST_AP_CMD_C);
  100. Serial.println(HELP_SEL_CMD_A);
  101. Serial.println(HELP_SSID_CMD_A);
  102. Serial.println(HELP_SSID_CMD_B);
  103. // Bluetooth sniff/scan
  104. Serial.println(HELP_BT_SNIFF_CMD);
  105. Serial.println(HELP_BT_SKIM_CMD);
  106. Serial.println(HELP_FOOT);
  107. return;
  108. }
  109. // Stop Scan
  110. if (cmd_args.get(0) == STOPSCAN_CMD) {
  111. if (wifi_scan_obj.currentScanMode == OTA_UPDATE) {
  112. wifi_scan_obj.currentScanMode = WIFI_SCAN_OFF;
  113. //#ifdef HAS_SCREEN
  114. // menu_function_obj.changeMenu(menu_function_obj.updateMenu.parentMenu);
  115. //#endif
  116. WiFi.softAPdisconnect(true);
  117. web_obj.shutdownServer();
  118. return;
  119. }
  120. wifi_scan_obj.StartScan(WIFI_SCAN_OFF);
  121. Serial.println("Stopping WiFi tran/recv");
  122. // If we don't do this, the text and button coordinates will be off
  123. #ifdef HAS_SCREEN
  124. display_obj.tft.init();
  125. menu_function_obj.changeMenu(menu_function_obj.current_menu);
  126. #endif
  127. }
  128. // Channel command
  129. else if (cmd_args.get(0) == CH_CMD) {
  130. // Search for channel set arg
  131. int ch_set = this->argSearch(&cmd_args, "-s");
  132. if (cmd_args.size() == 1) {
  133. Serial.println("Current channel: " + (String)wifi_scan_obj.set_channel);
  134. }
  135. else if (ch_set != -1) {
  136. wifi_scan_obj.set_channel = cmd_args.get(ch_set + 1).toInt();
  137. wifi_scan_obj.changeChannel();
  138. Serial.println("Set channel: " + (String)wifi_scan_obj.set_channel);
  139. }
  140. }
  141. #ifdef ESP32_CAM
  142. else if (cmd_args.get(0) == CAM_PHOTO) {
  143. pinMode(4,OUTPUT);
  144. digitalWrite(4,HIGH);
  145. delay(200);
  146. digitalWrite(4,LOW);
  147. Serial.println("Saved to SD");
  148. }
  149. #endif
  150. // Clear APs
  151. else if (cmd_args.get(0) == CLEARAP_CMD) {
  152. int ap_sw = this->argSearch(&cmd_args, "-a"); // APs
  153. int ss_sw = this->argSearch(&cmd_args, "-s"); // SSIDs
  154. int cl_sw = this->argSearch(&cmd_args, "-c"); // Stations
  155. if (ap_sw != -1) {
  156. #ifdef HAS_SCREEN
  157. menu_function_obj.changeMenu(&menu_function_obj.clearAPsMenu);
  158. #endif
  159. wifi_scan_obj.RunClearAPs();
  160. }
  161. if (ss_sw != -1) {
  162. #ifdef HAS_SCREEN
  163. menu_function_obj.changeMenu(&menu_function_obj.clearSSIDsMenu);
  164. #endif
  165. wifi_scan_obj.RunClearSSIDs();
  166. }
  167. if (cl_sw != -1) {
  168. #ifdef HAS_SCREEN
  169. menu_function_obj.changeMenu(&menu_function_obj.clearAPsMenu);
  170. #endif
  171. wifi_scan_obj.RunClearStations();
  172. }
  173. }
  174. else if (cmd_args.get(0) == SETTINGS_CMD) {
  175. int ss_sw = this->argSearch(&cmd_args, "-s"); // Set setting
  176. int re_sw = this->argSearch(&cmd_args, "-r"); // Reset setting
  177. int en_sw = this->argSearch(&cmd_args, "enable"); // enable setting
  178. int da_sw = this->argSearch(&cmd_args, "disable"); // disable setting
  179. if (re_sw != -1) {
  180. settings_obj.createDefaultSettings(SPIFFS);
  181. return;
  182. }
  183. if (ss_sw == -1) {
  184. settings_obj.printJsonSettings(settings_obj.getSettingsString());
  185. }
  186. else {
  187. bool result = false;
  188. String setting_name = cmd_args.get(ss_sw + 1);
  189. if (en_sw != -1)
  190. result = settings_obj.saveSetting<bool>(setting_name, true);
  191. else if (da_sw != -1)
  192. result = settings_obj.saveSetting<bool>(setting_name, false);
  193. else {
  194. Serial.println("You did not properly enable/disable this setting.");
  195. return;
  196. }
  197. if (!result) {
  198. Serial.println("Could not successfully update setting \"" + setting_name + "\"");
  199. return;
  200. }
  201. }
  202. }
  203. else if (cmd_args.get(0) == REBOOT_CMD) {
  204. Serial.println("Rebooting...");
  205. ESP.restart();
  206. }
  207. //// WiFi/Bluetooth Scan/Attack commands
  208. if (!wifi_scan_obj.scanning()) {
  209. // AP Scan
  210. if (cmd_args.get(0) == SCANAP_CMD) {
  211. int full_sw = -1;
  212. #ifdef HAS_SCREEN
  213. display_obj.clearScreen();
  214. menu_function_obj.drawStatusBar();
  215. #endif
  216. if (full_sw == -1) {
  217. Serial.println("Starting AP scan. Stop with " + (String)STOPSCAN_CMD);
  218. wifi_scan_obj.StartScan(WIFI_SCAN_TARGET_AP, TFT_MAGENTA);
  219. }
  220. else {
  221. Serial.println("Starting Full AP scan. Stop with " + (String)STOPSCAN_CMD);
  222. wifi_scan_obj.StartScan(WIFI_SCAN_TARGET_AP_FULL, TFT_MAGENTA);
  223. }
  224. }
  225. // Raw sniff
  226. else if (cmd_args.get(0) == SNIFF_RAW_CMD) {
  227. Serial.println("Starting Raw sniff. Stop with " + (String)STOPSCAN_CMD);
  228. #ifdef HAS_SCREEN
  229. display_obj.clearScreen();
  230. menu_function_obj.drawStatusBar();
  231. #endif
  232. wifi_scan_obj.StartScan(WIFI_SCAN_RAW_CAPTURE, TFT_WHITE);
  233. }
  234. // Scan stations
  235. else if (cmd_args.get(0) == SCANSTA_CMD) {
  236. Serial.println("Starting Station scan. Stop with " + (String)STOPSCAN_CMD);
  237. #ifdef HAS_SCREEN
  238. display_obj.clearScreen();
  239. menu_function_obj.drawStatusBar();
  240. #endif
  241. wifi_scan_obj.StartScan(WIFI_SCAN_STATION, TFT_ORANGE);
  242. }
  243. // Beacon sniff
  244. else if (cmd_args.get(0) == SNIFF_BEACON_CMD) {
  245. Serial.println("Starting Beacon sniff. Stop with " + (String)STOPSCAN_CMD);
  246. #ifdef HAS_SCREEN
  247. display_obj.clearScreen();
  248. menu_function_obj.drawStatusBar();
  249. #endif
  250. wifi_scan_obj.StartScan(WIFI_SCAN_AP, TFT_MAGENTA);
  251. }
  252. // Probe sniff
  253. else if (cmd_args.get(0) == SNIFF_PROBE_CMD) {
  254. Serial.println("Starting Probe sniff. Stop with " + (String)STOPSCAN_CMD);
  255. #ifdef HAS_SCREEN
  256. display_obj.clearScreen();
  257. menu_function_obj.drawStatusBar();
  258. #endif
  259. wifi_scan_obj.StartScan(WIFI_SCAN_PROBE, TFT_MAGENTA);
  260. }
  261. // Deauth sniff
  262. else if (cmd_args.get(0) == SNIFF_DEAUTH_CMD) {
  263. Serial.println("Starting Deauth sniff. Stop with " + (String)STOPSCAN_CMD);
  264. #ifdef HAS_SCREEN
  265. display_obj.clearScreen();
  266. menu_function_obj.drawStatusBar();
  267. #endif
  268. wifi_scan_obj.StartScan(WIFI_SCAN_DEAUTH, TFT_RED);
  269. }
  270. // Pwn sniff
  271. else if (cmd_args.get(0) == SNIFF_PWN_CMD) {
  272. Serial.println("Starting Pwnagotchi sniff. Stop with " + (String)STOPSCAN_CMD);
  273. #ifdef HAS_SCREEN
  274. display_obj.clearScreen();
  275. menu_function_obj.drawStatusBar();
  276. #endif
  277. wifi_scan_obj.StartScan(WIFI_SCAN_PWN, TFT_MAGENTA);
  278. }
  279. // Espressif sniff
  280. else if (cmd_args.get(0) == SNIFF_ESP_CMD) {
  281. Serial.println("Starting Espressif device sniff. Stop with " + (String)STOPSCAN_CMD);
  282. #ifdef HAS_SCREEN
  283. display_obj.clearScreen();
  284. menu_function_obj.drawStatusBar();
  285. #endif
  286. wifi_scan_obj.StartScan(WIFI_SCAN_ESPRESSIF, TFT_MAGENTA);
  287. }
  288. // PMKID sniff
  289. else if (cmd_args.get(0) == SNIFF_PMKID_CMD) {
  290. int ch_sw = this->argSearch(&cmd_args, "-c");
  291. int d_sw = this->argSearch(&cmd_args, "-d"); // Deauth for pmkid
  292. if (ch_sw != -1) {
  293. wifi_scan_obj.set_channel = cmd_args.get(ch_sw + 1).toInt();
  294. wifi_scan_obj.changeChannel();
  295. Serial.println("Set channel: " + (String)wifi_scan_obj.set_channel);
  296. }
  297. if (d_sw == -1) {
  298. Serial.println("Starting PMKID sniff on channel " + (String)wifi_scan_obj.set_channel + ". Stop with " + (String)STOPSCAN_CMD);
  299. wifi_scan_obj.StartScan(WIFI_SCAN_EAPOL, TFT_VIOLET);
  300. }
  301. else {
  302. Serial.println("Starting PMKID sniff with deauthentication on channel " + (String)wifi_scan_obj.set_channel + ". Stop with " + (String)STOPSCAN_CMD);
  303. wifi_scan_obj.StartScan(WIFI_SCAN_ACTIVE_EAPOL, TFT_VIOLET);
  304. }
  305. }
  306. //// WiFi attack commands
  307. // attack
  308. if (cmd_args.get(0) == ATTACK_CMD) {
  309. int attack_type_switch = this->argSearch(&cmd_args, "-t"); // Required
  310. int list_beacon_sw = this->argSearch(&cmd_args, "-l");
  311. int rand_beacon_sw = this->argSearch(&cmd_args, "-r");
  312. int ap_beacon_sw = this->argSearch(&cmd_args, "-a");
  313. int src_addr_sw = this->argSearch(&cmd_args, "-s");
  314. int dst_addr_sw = this->argSearch(&cmd_args, "-d");
  315. int targ_sw = this->argSearch(&cmd_args, "-c");
  316. if (attack_type_switch == -1) {
  317. Serial.println("You must specify an attack type");
  318. return;
  319. }
  320. else {
  321. String attack_type = cmd_args.get(attack_type_switch + 1);
  322. // Branch on attack type
  323. // Deauth
  324. if (attack_type == ATTACK_TYPE_DEAUTH) {
  325. // Default to broadcast
  326. if ((dst_addr_sw == -1) && (targ_sw == -1)) {
  327. Serial.println("Sending to broadcast...");
  328. wifi_scan_obj.dst_mac = "ff:ff:ff:ff:ff:ff";
  329. }
  330. // Dest addr specified
  331. else if (dst_addr_sw != -1) {
  332. wifi_scan_obj.dst_mac = cmd_args.get(dst_addr_sw + 1);
  333. Serial.println("Sending to " + wifi_scan_obj.dst_mac + "...");
  334. }
  335. // Station list specified
  336. else if (targ_sw != -1)
  337. Serial.println("Sending to Station list");
  338. // Source addr not specified
  339. if (src_addr_sw == -1) {
  340. if (!this->apSelected()) {
  341. Serial.println("You don't have any targets selected. Use " + (String)SEL_CMD);
  342. return;
  343. }
  344. #ifdef HAS_SCREEN
  345. display_obj.clearScreen();
  346. menu_function_obj.drawStatusBar();
  347. #endif
  348. Serial.println("Starting Deauthentication attack. Stop with " + (String)STOPSCAN_CMD);
  349. // Station list not specified
  350. if (targ_sw == -1)
  351. wifi_scan_obj.StartScan(WIFI_ATTACK_DEAUTH, TFT_RED);
  352. // Station list specified
  353. else
  354. wifi_scan_obj.StartScan(WIFI_ATTACK_DEAUTH_TARGETED, TFT_ORANGE);
  355. }
  356. // Source addr specified
  357. else {
  358. String src_mac_str = cmd_args.get(src_addr_sw + 1);
  359. sscanf(src_mac_str.c_str(), "%2hhx:%2hhx:%2hhx:%2hhx:%2hhx:%2hhx",
  360. &wifi_scan_obj.src_mac[0], &wifi_scan_obj.src_mac[1], &wifi_scan_obj.src_mac[2], &wifi_scan_obj.src_mac[3], &wifi_scan_obj.src_mac[4], &wifi_scan_obj.src_mac[5]);
  361. #ifdef HAS_SCREEN
  362. display_obj.clearScreen();
  363. menu_function_obj.drawStatusBar();
  364. #endif
  365. Serial.println("Starting Manual Deauthentication attack. Stop with " + (String)STOPSCAN_CMD);
  366. wifi_scan_obj.StartScan(WIFI_ATTACK_DEAUTH_MANUAL, TFT_RED);
  367. }
  368. }
  369. // Beacon
  370. else if (attack_type == ATTACK_TYPE_BEACON) {
  371. // spam by list
  372. if (list_beacon_sw != -1) {
  373. if (!this->hasSSIDs()) {
  374. Serial.println("You don't have any SSIDs in your list. Use " + (String)SSID_CMD);
  375. return;
  376. }
  377. #ifdef HAS_SCREEN
  378. display_obj.clearScreen();
  379. menu_function_obj.drawStatusBar();
  380. #endif
  381. Serial.println("Starting Beacon list spam. Stop with " + (String)STOPSCAN_CMD);
  382. wifi_scan_obj.StartScan(WIFI_ATTACK_BEACON_LIST, TFT_RED);
  383. }
  384. // spam with random
  385. else if (rand_beacon_sw != -1) {
  386. #ifdef HAS_SCREEN
  387. display_obj.clearScreen();
  388. menu_function_obj.drawStatusBar();
  389. #endif
  390. Serial.println("Starting random Beacon spam. Stop with " + (String)STOPSCAN_CMD);
  391. wifi_scan_obj.StartScan(WIFI_ATTACK_BEACON_SPAM, TFT_ORANGE);
  392. }
  393. // Spam from AP list
  394. else if (ap_beacon_sw != -1) {
  395. if (!this->apSelected()) {
  396. Serial.println("You don't have any targets selected. Use " + (String)SEL_CMD);
  397. return;
  398. }
  399. #ifdef HAS_SCREEN
  400. display_obj.clearScreen();
  401. menu_function_obj.drawStatusBar();
  402. #endif
  403. Serial.println("Starting Targeted AP Beacon spam. Stop with " + (String)STOPSCAN_CMD);
  404. wifi_scan_obj.StartScan(WIFI_ATTACK_AP_SPAM, TFT_MAGENTA);
  405. }
  406. else {
  407. Serial.println("You did not specify a beacon attack type");
  408. }
  409. }
  410. else if (attack_type == ATTACK_TYPE_PROBE) {
  411. if (!this->apSelected()) {
  412. Serial.println("You don't have any targets selected. Use " + (String)SEL_CMD);
  413. return;
  414. }
  415. Serial.println("Starting Probe spam. Stop with " + (String)STOPSCAN_CMD);
  416. #ifdef HAS_SCREEN
  417. display_obj.clearScreen();
  418. menu_function_obj.drawStatusBar();
  419. #endif
  420. wifi_scan_obj.StartScan(WIFI_ATTACK_AUTH, TFT_RED);
  421. }
  422. else if (attack_type == ATTACK_TYPE_RR) {
  423. Serial.println("Starting Rick Roll Beacon spam. Stop with " + (String)STOPSCAN_CMD);
  424. #ifdef HAS_SCREEN
  425. display_obj.clearScreen();
  426. menu_function_obj.drawStatusBar();
  427. #endif
  428. wifi_scan_obj.StartScan(WIFI_ATTACK_RICK_ROLL, TFT_YELLOW);
  429. }
  430. else {
  431. Serial.println("Attack type not properly defined");
  432. return;
  433. }
  434. }
  435. }
  436. //// Bluetooth scan/attack commands
  437. // Bluetooth scan
  438. if (cmd_args.get(0) == BT_SNIFF_CMD) {
  439. Serial.println("Starting Bluetooth scan. Stop with " + (String)STOPSCAN_CMD);
  440. #ifdef HAS_SCREEN
  441. display_obj.clearScreen();
  442. menu_function_obj.drawStatusBar();
  443. #endif
  444. wifi_scan_obj.StartScan(BT_SCAN_ALL, TFT_GREEN);
  445. }
  446. // Bluetooth CC Skimmer scan
  447. else if (cmd_args.get(0) == BT_SKIM_CMD) {
  448. Serial.println("Starting Bluetooth CC Skimmer scan. Stop with " + (String)STOPSCAN_CMD);
  449. #ifdef HAS_SCREEN
  450. display_obj.clearScreen();
  451. menu_function_obj.drawStatusBar();
  452. #endif
  453. wifi_scan_obj.StartScan(BT_SCAN_SKIMMERS, TFT_MAGENTA);
  454. }
  455. // Update command
  456. if (cmd_args.get(0) == UPDATE_CMD) {
  457. int w_sw = this->argSearch(&cmd_args, "-w"); // Web update
  458. int sd_sw = this->argSearch(&cmd_args, "-s"); // SD Update
  459. // Update via OTA
  460. if (w_sw != -1) {
  461. Serial.println("Starting Marauder OTA Update. Stop with " + (String)STOPSCAN_CMD);
  462. wifi_scan_obj.currentScanMode = OTA_UPDATE;
  463. //#ifdef HAS_SCREEN
  464. // menu_function_obj.changeMenu(menu_function_obj.updateMenu);
  465. //#endif
  466. web_obj.setupOTAupdate();
  467. }
  468. // Update via SD
  469. else if (sd_sw != -1) {
  470. if (!sd_obj.supported) {
  471. Serial.println("SD card is not connected. Cannot perform SD Update");
  472. return;
  473. }
  474. wifi_scan_obj.currentScanMode = OTA_UPDATE;
  475. sd_obj.runUpdate();
  476. }
  477. }
  478. }
  479. //// WiFi aux commands
  480. // List access points
  481. if (cmd_args.get(0) == LIST_AP_CMD) {
  482. int ap_sw = this->argSearch(&cmd_args, "-a");
  483. int ss_sw = this->argSearch(&cmd_args, "-s");
  484. int cl_sw = this->argSearch(&cmd_args, "-c");
  485. // List APs
  486. if (ap_sw != -1) {
  487. for (int i = 0; i < access_points->size(); i++) {
  488. if (access_points->get(i).selected)
  489. Serial.println("[" + (String)i + "] " + access_points->get(i).essid + " " + (String)access_points->get(i).rssi + " (selected)");
  490. else
  491. Serial.println("[" + (String)i + "] " + access_points->get(i).essid + " " + (String)access_points->get(i).rssi);
  492. }
  493. }
  494. // List SSIDs
  495. else if (ss_sw != -1) {
  496. for (int i = 0; i < ssids->size(); i++) {
  497. if (ssids->get(i).selected)
  498. Serial.println("[" + (String)i + "] " + ssids->get(i).essid + " (selected)");
  499. else
  500. Serial.println("[" + (String)i + "] " + ssids->get(i).essid);
  501. }
  502. }
  503. // List Stations
  504. else if (cl_sw != -1) {
  505. char sta_mac[] = "00:00:00:00:00:00";
  506. for (int x = 0; x < access_points->size(); x++) {
  507. Serial.println("[" + (String)x + "] " + access_points->get(x).essid + " " + (String)access_points->get(x).rssi + ":");
  508. for (int i = 0; i < access_points->get(x).stations->size(); i++) {
  509. wifi_scan_obj.getMAC(sta_mac, stations->get(access_points->get(x).stations->get(i)).mac, 0);
  510. if (stations->get(access_points->get(x).stations->get(i)).selected) {
  511. Serial.print(" [" + (String)access_points->get(x).stations->get(i) + "] ");
  512. Serial.print(sta_mac);
  513. Serial.println(" (selected)");
  514. }
  515. else {
  516. Serial.print(" [" + (String)access_points->get(x).stations->get(i) + "] ");
  517. Serial.println(sta_mac);
  518. }
  519. }
  520. }
  521. }
  522. else {
  523. Serial.println("You did not specify which list to show");
  524. return;
  525. }
  526. }
  527. // Select access points or stations
  528. else if (cmd_args.get(0) == SEL_CMD) {
  529. // Get switches
  530. int ap_sw = this->argSearch(&cmd_args, "-a");
  531. int ss_sw = this->argSearch(&cmd_args, "-s");
  532. int cl_sw = this->argSearch(&cmd_args, "-c");
  533. // select Access points
  534. if (ap_sw != -1) {
  535. // Get list of indices
  536. LinkedList<String> ap_index = this->parseCommand(cmd_args.get(ap_sw + 1), ",");
  537. // Select ALL APs
  538. if (cmd_args.get(ap_sw + 1) == "all") {
  539. for (int i = 0; i < access_points->size(); i++) {
  540. if (access_points->get(i).selected) {
  541. // Unselect "selected" ap
  542. AccessPoint new_ap = access_points->get(i);
  543. new_ap.selected = false;
  544. access_points->set(i, new_ap);
  545. }
  546. else {
  547. // Select "unselected" ap
  548. AccessPoint new_ap = access_points->get(i);
  549. new_ap.selected = true;
  550. access_points->set(i, new_ap);
  551. }
  552. }
  553. }
  554. // Select specific APs
  555. else {
  556. // Mark APs as selected
  557. for (int i = 0; i < ap_index.size(); i++) {
  558. int index = ap_index.get(i).toInt();
  559. if (!this->inRange(access_points->size(), index)) {
  560. Serial.println("Index not in range: " + (String)index);
  561. continue;
  562. }
  563. if (access_points->get(index).selected) {
  564. // Unselect "selected" ap
  565. AccessPoint new_ap = access_points->get(index);
  566. new_ap.selected = false;
  567. access_points->set(index, new_ap);
  568. }
  569. else {
  570. // Select "unselected" ap
  571. AccessPoint new_ap = access_points->get(index);
  572. new_ap.selected = true;
  573. access_points->set(index, new_ap);
  574. }
  575. }
  576. }
  577. }
  578. else if (cl_sw != -1) {
  579. LinkedList<String> sta_index = this->parseCommand(cmd_args.get(cl_sw + 1), ",");
  580. // Select all Stations
  581. if (cmd_args.get(cl_sw + 1) == "all") {
  582. for (int i = 0; i < stations->size(); i++) {
  583. if (stations->get(i).selected) {
  584. // Unselect "selected" ap
  585. Station new_sta = stations->get(i);
  586. new_sta.selected = false;
  587. stations->set(i, new_sta);
  588. }
  589. else {
  590. // Select "unselected" ap
  591. Station new_sta = stations->get(i);
  592. new_sta.selected = true;
  593. stations->set(i, new_sta);
  594. }
  595. }
  596. }
  597. // Select specific Stations
  598. else {
  599. // Mark Stations as selected
  600. for (int i = 0; i < sta_index.size(); i++) {
  601. int index = sta_index.get(i).toInt();
  602. if (!this->inRange(stations->size(), index)) {
  603. Serial.println("Index not in range: " + (String)index);
  604. continue;
  605. }
  606. if (stations->get(index).selected) {
  607. // Unselect "selected" ap
  608. Station new_sta = stations->get(index);
  609. new_sta.selected = false;
  610. stations->set(index, new_sta);
  611. }
  612. else {
  613. // Select "unselected" ap
  614. Station new_sta = stations->get(index);
  615. new_sta.selected = true;
  616. stations->set(index, new_sta);
  617. }
  618. }
  619. }
  620. }
  621. // select ssids
  622. else if (ss_sw != -1) {
  623. // Get list of indices
  624. LinkedList<String> ss_index = this->parseCommand(cmd_args.get(ss_sw + 1), ",");
  625. // Mark APs as selected
  626. for (int i = 0; i < ss_index.size(); i++) {
  627. int index = ss_index.get(i).toInt();
  628. if (!this->inRange(ssids->size(), index)) {
  629. Serial.println("Index not in range: " + (String)index);
  630. continue;
  631. }
  632. if (ssids->get(index).selected) {
  633. // Unselect "selected" ap
  634. ssid new_ssid = ssids->get(index);
  635. new_ssid.selected = false;
  636. ssids->set(index, new_ssid);
  637. }
  638. else {
  639. // Select "unselected" ap
  640. ssid new_ssid = ssids->get(index);
  641. new_ssid.selected = true;
  642. ssids->set(index, new_ssid);
  643. }
  644. }
  645. }
  646. else {
  647. Serial.println("You did not specify which list to select from");
  648. return;
  649. }
  650. }
  651. // SSID stuff
  652. else if (cmd_args.get(0) == SSID_CMD) {
  653. int add_sw = this->argSearch(&cmd_args, "-a");
  654. int gen_sw = this->argSearch(&cmd_args, "-g");
  655. int spc_sw = this->argSearch(&cmd_args, "-n");
  656. int rem_sw = this->argSearch(&cmd_args, "-r");
  657. // Add ssid
  658. if (add_sw != -1) {
  659. // Generate random
  660. if (gen_sw != -1) {
  661. int gen_count = cmd_args.get(gen_sw + 1).toInt();
  662. wifi_scan_obj.generateSSIDs(gen_count);
  663. }
  664. // Add specific
  665. else if (spc_sw != -1) {
  666. String essid = cmd_args.get(spc_sw + 1);
  667. wifi_scan_obj.addSSID(essid);
  668. }
  669. else {
  670. Serial.println("You did not specify how to add SSIDs");
  671. }
  672. }
  673. // Remove SSID
  674. else if (rem_sw != -1) {
  675. int index = cmd_args.get(rem_sw + 1).toInt();
  676. if (!this->inRange(ssids->size(), index)) {
  677. Serial.println("Index not in range: " + (String)index);
  678. return;
  679. }
  680. ssids->remove(index);
  681. }
  682. else {
  683. Serial.println("You did not specify whether to add or remove SSIDs");
  684. return;
  685. }
  686. }
  687. }