wifi_marauder_script.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584
  1. #include "../wifi_marauder_app_i.h"
  2. #include "wifi_marauder_script.h"
  3. #define WIFI_MARAUDER_DEFAULT_TIMEOUT_SCAN 15
  4. #define WIFI_MARAUDER_DEFAULT_TIMEOUT_DEAUTH 30
  5. #define WIFI_MARAUDER_DEFAULT_TIMEOUT_PROBE 60
  6. #define WIFI_MARAUDER_DEFAULT_TIMEOUT_SNIFF 60
  7. #define WIFI_MARAUDER_DEFAULT_TIMEOUT_BEACON 60
  8. #define WIFI_MARAUDER_DEFAULT_ENABLE_LED true
  9. #define WIFI_MARAUDER_DEFAULT_SAVE_PCAP true
  10. WifiMarauderScript *wifi_marauder_script_alloc() {
  11. WifiMarauderScript *script = (WifiMarauderScript *) malloc(sizeof(WifiMarauderScript));
  12. if (script == NULL) {
  13. return NULL;
  14. }
  15. script->name = NULL;
  16. script->description = NULL;
  17. script->first_stage = NULL;
  18. script->enable_led = WIFI_MARAUDER_DEFAULT_ENABLE_LED;
  19. script->save_pcap = WIFI_MARAUDER_DEFAULT_SAVE_PCAP;
  20. script->repeat = 1;
  21. return script;
  22. }
  23. void _wifi_marauder_script_load_meta(WifiMarauderScript *script, cJSON *meta_section) {
  24. if (meta_section != NULL) {
  25. // Script description
  26. cJSON* description = cJSON_GetObjectItem(meta_section, "description");
  27. if (description != NULL) {
  28. script->description = strdup(description->valuestring);
  29. }
  30. // Enable LED
  31. cJSON* enable_led_json = cJSON_GetObjectItemCaseSensitive(meta_section, "enableLed");
  32. if (cJSON_IsBool(enable_led_json)) {
  33. script->enable_led = enable_led_json->valueint;
  34. }
  35. // Save PCAP
  36. cJSON* save_pcap_json = cJSON_GetObjectItemCaseSensitive(meta_section, "savePcap");
  37. if (cJSON_IsBool(save_pcap_json)) {
  38. script->save_pcap = save_pcap_json->valueint;
  39. }
  40. // Times the script will be repeated
  41. cJSON* repeat = cJSON_GetObjectItem(meta_section, "repeat");
  42. if (repeat != NULL) {
  43. script->repeat = repeat->valueint;
  44. }
  45. }
  46. if (script->description == NULL) {
  47. script->description = strdup("My script");
  48. }
  49. }
  50. WifiMarauderScriptStageScan* _wifi_marauder_script_get_stage_scan(cJSON *stages) {
  51. cJSON* stage_scan = cJSON_GetObjectItem(stages, "scan");
  52. if (stage_scan == NULL) {
  53. return NULL;
  54. }
  55. cJSON* type = cJSON_GetObjectItem(stage_scan, "type");
  56. if (type == NULL) {
  57. return NULL;
  58. }
  59. WifiMarauderScriptScanType scan_type;
  60. if (strcmp(type->valuestring, "ap") == 0) {
  61. scan_type = WifiMarauderScriptScanTypeAp;
  62. } else if (strcmp(type->valuestring, "station") == 0) {
  63. scan_type = WifiMarauderScriptScanTypeStation;
  64. } else {
  65. return NULL;
  66. }
  67. cJSON* channel = cJSON_GetObjectItem(stage_scan, "channel");
  68. int scan_channel = channel != NULL ? (int)cJSON_GetNumberValue(channel) : 0;
  69. cJSON* timeout = cJSON_GetObjectItem(stage_scan, "timeout");
  70. int scan_timeout = timeout != NULL ? (int)cJSON_GetNumberValue(timeout) : WIFI_MARAUDER_DEFAULT_TIMEOUT_SCAN;
  71. WifiMarauderScriptStageScan *scan_stage = (WifiMarauderScriptStageScan*) malloc(sizeof(WifiMarauderScriptStageScan));
  72. scan_stage->type = scan_type;
  73. scan_stage->channel = scan_channel;
  74. scan_stage->timeout = scan_timeout;
  75. return scan_stage;
  76. }
  77. WifiMarauderScriptStageSelect* _wifi_marauder_script_get_stage_select(cJSON *stages) {
  78. cJSON *select_stage_json = cJSON_GetObjectItemCaseSensitive(stages, "select");
  79. if (select_stage_json == NULL) {
  80. return NULL;
  81. }
  82. cJSON *type_json = cJSON_GetObjectItemCaseSensitive(select_stage_json, "type");
  83. cJSON *filter_json = cJSON_GetObjectItemCaseSensitive(select_stage_json, "filter");
  84. cJSON *indexes_json = cJSON_GetObjectItemCaseSensitive(select_stage_json, "indexes");
  85. cJSON *index_json = cJSON_GetObjectItemCaseSensitive(select_stage_json, "index");
  86. cJSON *allow_repeat_json = cJSON_GetObjectItemCaseSensitive(select_stage_json, "allow_repeat");
  87. if (!cJSON_IsString(type_json) || !cJSON_IsString(filter_json)) {
  88. return NULL;
  89. }
  90. WifiMarauderScriptSelectType select_type;
  91. if (strcmp(type_json->valuestring, "ap") == 0) {
  92. select_type = WifiMarauderScriptSelectTypeAp;
  93. } else if (strcmp(type_json->valuestring, "station") == 0) {
  94. select_type = WifiMarauderScriptSelectTypeStation;
  95. } else if (strcmp(type_json->valuestring, "ssid") == 0) {
  96. select_type = WifiMarauderScriptSelectTypeSsid;
  97. } else {
  98. return NULL;
  99. }
  100. char *filter_str = strdup(filter_json->valuestring);
  101. WifiMarauderScriptStageSelect *stage_select = (WifiMarauderScriptStageSelect*) malloc(sizeof(WifiMarauderScriptStageSelect));
  102. stage_select->type = select_type;
  103. stage_select->filter = filter_str;
  104. stage_select->allow_repeat = cJSON_IsBool(allow_repeat_json) ? allow_repeat_json->valueint : true;
  105. if (cJSON_IsNumber(index_json)) {
  106. int* indexes = (int*) malloc(sizeof(int));
  107. indexes[0] = index_json->valueint;
  108. stage_select->indexes = indexes;
  109. } else if (cJSON_IsArray(indexes_json)) {
  110. int indexes_size = cJSON_GetArraySize(indexes_json);
  111. int* indexes = (int*) malloc(indexes_size * sizeof(int));
  112. for (int i = 0; i < indexes_size; i++) {
  113. cJSON *index_item = cJSON_GetArrayItem(indexes_json, i);
  114. if (cJSON_IsNumber(index_item)) {
  115. indexes[i] = index_item->valueint;
  116. }
  117. }
  118. stage_select->indexes = indexes;
  119. } else {
  120. stage_select->indexes = NULL;
  121. }
  122. return stage_select;
  123. }
  124. WifiMarauderScriptStageDeauth* _wifi_marauder_script_get_stage_deauth(cJSON *stages) {
  125. cJSON *deauth_stage_json = cJSON_GetObjectItemCaseSensitive(stages, "deauth");
  126. if (deauth_stage_json == NULL) {
  127. return NULL;
  128. }
  129. cJSON* timeout = cJSON_GetObjectItem(deauth_stage_json, "timeout");
  130. int deauth_timeout = timeout != NULL ? (int)cJSON_GetNumberValue(timeout) : WIFI_MARAUDER_DEFAULT_TIMEOUT_DEAUTH;
  131. WifiMarauderScriptStageDeauth *deauth_stage = (WifiMarauderScriptStageDeauth*) malloc(sizeof(WifiMarauderScriptStageDeauth));
  132. deauth_stage->timeout = deauth_timeout;
  133. return deauth_stage;
  134. }
  135. WifiMarauderScriptStageProbe* _wifi_marauder_script_get_stage_probe(cJSON *stages) {
  136. cJSON *probe_stage_json = cJSON_GetObjectItemCaseSensitive(stages, "probe");
  137. if (probe_stage_json == NULL) {
  138. return NULL;
  139. }
  140. cJSON* timeout = cJSON_GetObjectItem(probe_stage_json, "timeout");
  141. int probe_timeout = timeout != NULL ? (int)cJSON_GetNumberValue(timeout) : WIFI_MARAUDER_DEFAULT_TIMEOUT_PROBE;
  142. WifiMarauderScriptStageProbe *probe_stage = (WifiMarauderScriptStageProbe*) malloc(sizeof(WifiMarauderScriptStageProbe));
  143. probe_stage->timeout = probe_timeout;
  144. return probe_stage;
  145. }
  146. WifiMarauderScriptStageSniffRaw* _wifi_marauder_script_get_stage_sniff_raw(cJSON *stages) {
  147. cJSON* sniffraw_stage_json = cJSON_GetObjectItem(stages, "sniffraw");
  148. if (sniffraw_stage_json == NULL) {
  149. return NULL;
  150. }
  151. cJSON* timeout_json = cJSON_GetObjectItem(sniffraw_stage_json, "timeout");
  152. int timeout = timeout_json != NULL ? (int)cJSON_GetNumberValue(timeout_json) : WIFI_MARAUDER_DEFAULT_TIMEOUT_SNIFF;
  153. WifiMarauderScriptStageSniffRaw *sniff_raw_stage = (WifiMarauderScriptStageSniffRaw*) malloc(sizeof(WifiMarauderScriptStageSniffRaw));
  154. sniff_raw_stage->timeout = timeout;
  155. return sniff_raw_stage;
  156. }
  157. WifiMarauderScriptStageSniffBeacon* _wifi_marauder_script_get_stage_sniff_beacon(cJSON *stages) {
  158. cJSON* sniffbeacon_stage_json = cJSON_GetObjectItem(stages, "sniffbeacon");
  159. if (sniffbeacon_stage_json == NULL) {
  160. return NULL;
  161. }
  162. cJSON* timeout_json = cJSON_GetObjectItem(sniffbeacon_stage_json, "timeout");
  163. int timeout = timeout_json != NULL ? (int)cJSON_GetNumberValue(timeout_json) : WIFI_MARAUDER_DEFAULT_TIMEOUT_SNIFF;
  164. WifiMarauderScriptStageSniffBeacon *sniff_beacon_stage = (WifiMarauderScriptStageSniffBeacon*) malloc(sizeof(WifiMarauderScriptStageSniffBeacon));
  165. sniff_beacon_stage->timeout = timeout;
  166. return sniff_beacon_stage;
  167. }
  168. WifiMarauderScriptStageSniffDeauth* _wifi_marauder_script_get_stage_sniff_deauth(cJSON *stages) {
  169. cJSON* sniffdeauth_stage_json = cJSON_GetObjectItem(stages, "sniffdeauth");
  170. if (sniffdeauth_stage_json == NULL) {
  171. return NULL;
  172. }
  173. cJSON* timeout_json = cJSON_GetObjectItem(sniffdeauth_stage_json, "timeout");
  174. int timeout = timeout_json != NULL ? (int)cJSON_GetNumberValue(timeout_json) : WIFI_MARAUDER_DEFAULT_TIMEOUT_SNIFF;
  175. WifiMarauderScriptStageSniffDeauth *sniff_deauth_stage = (WifiMarauderScriptStageSniffDeauth*) malloc(sizeof(WifiMarauderScriptStageSniffDeauth));
  176. sniff_deauth_stage->timeout = timeout;
  177. return sniff_deauth_stage;
  178. }
  179. WifiMarauderScriptStageSniffEsp* _wifi_marauder_script_get_stage_sniff_esp(cJSON *stages) {
  180. cJSON* sniffesp_stage_json = cJSON_GetObjectItem(stages, "sniffesp");
  181. if (sniffesp_stage_json == NULL) {
  182. return NULL;
  183. }
  184. cJSON* timeout_json = cJSON_GetObjectItem(sniffesp_stage_json, "timeout");
  185. int timeout = timeout_json != NULL ? (int)cJSON_GetNumberValue(timeout_json) : WIFI_MARAUDER_DEFAULT_TIMEOUT_SNIFF;
  186. WifiMarauderScriptStageSniffEsp *sniff_esp_stage = (WifiMarauderScriptStageSniffEsp*) malloc(sizeof(WifiMarauderScriptStageSniffEsp));
  187. sniff_esp_stage->timeout = timeout;
  188. return sniff_esp_stage;
  189. }
  190. WifiMarauderScriptStageSniffPmkid* _wifi_marauder_script_get_stage_sniff_pmkid(cJSON *stages) {
  191. cJSON* sniffpmkid_stage_json = cJSON_GetObjectItem(stages, "sniffpmkid");
  192. if (sniffpmkid_stage_json == NULL) {
  193. return NULL;
  194. }
  195. cJSON* channel_json = cJSON_GetObjectItem(sniffpmkid_stage_json, "channel");
  196. int channel = channel_json != NULL ? (int)cJSON_GetNumberValue(channel_json) : 0;
  197. cJSON* timeout_json = cJSON_GetObjectItem(sniffpmkid_stage_json, "timeout");
  198. int timeout = timeout_json != NULL ? (int)cJSON_GetNumberValue(timeout_json) : WIFI_MARAUDER_DEFAULT_TIMEOUT_SNIFF;
  199. cJSON* force_deauth_json = cJSON_GetObjectItemCaseSensitive(sniffpmkid_stage_json, "forceDeauth");
  200. bool force_deauth = cJSON_IsBool(force_deauth_json) ? force_deauth_json->valueint : true;
  201. WifiMarauderScriptStageSniffPmkid *sniff_pmkid_stage = (WifiMarauderScriptStageSniffPmkid*) malloc(sizeof(WifiMarauderScriptStageSniffPmkid));
  202. sniff_pmkid_stage->channel = channel;
  203. sniff_pmkid_stage->timeout = timeout;
  204. sniff_pmkid_stage->force_deauth = force_deauth;
  205. return sniff_pmkid_stage;
  206. }
  207. WifiMarauderScriptStageSniffPwn* _wifi_marauder_script_get_stage_sniff_pwn(cJSON *stages) {
  208. cJSON* sniffpwn_stage_json = cJSON_GetObjectItem(stages, "sniffpwn");
  209. if (sniffpwn_stage_json == NULL) {
  210. return NULL;
  211. }
  212. cJSON* timeout_json = cJSON_GetObjectItem(sniffpwn_stage_json, "timeout");
  213. int timeout = timeout_json != NULL ? (int)cJSON_GetNumberValue(timeout_json) : WIFI_MARAUDER_DEFAULT_TIMEOUT_SNIFF;
  214. WifiMarauderScriptStageSniffPwn *sniff_pwn_stage = (WifiMarauderScriptStageSniffPwn*) malloc(sizeof(WifiMarauderScriptStageSniffPwn));
  215. sniff_pwn_stage->timeout = timeout;
  216. return sniff_pwn_stage;
  217. }
  218. WifiMarauderScriptStageBeaconList* _wifi_marauder_script_get_stage_beacon_list(cJSON *stages) {
  219. cJSON* stage_beaconlist = cJSON_GetObjectItem(stages, "beaconList");
  220. if (stage_beaconlist == NULL) {
  221. return NULL;
  222. }
  223. WifiMarauderScriptStageBeaconList *beaconlist_stage = (WifiMarauderScriptStageBeaconList*) malloc(sizeof(WifiMarauderScriptStageBeaconList));
  224. if (beaconlist_stage == NULL) {
  225. return NULL;
  226. }
  227. cJSON* ssids = cJSON_GetObjectItem(stage_beaconlist, "ssids");
  228. if (ssids == NULL) {
  229. return NULL;
  230. }
  231. // SSID count
  232. int ssid_count = cJSON_GetArraySize(ssids);
  233. if (ssid_count == 0) {
  234. return NULL;
  235. }
  236. beaconlist_stage->ssid_count = ssid_count;
  237. // SSIDs
  238. beaconlist_stage->ssids = (char**) malloc(sizeof(char*) * ssid_count);
  239. if (beaconlist_stage->ssids == NULL) {
  240. return NULL;
  241. }
  242. for (int i = 0; i < ssid_count; i++) {
  243. cJSON* ssid = cJSON_GetArrayItem(ssids, i);
  244. if (ssid == NULL) {
  245. continue;
  246. }
  247. char* ssid_string = cJSON_GetStringValue(ssid);
  248. if (ssid_string == NULL) {
  249. continue;
  250. }
  251. beaconlist_stage->ssids[i] = (char*) malloc(sizeof(char) * (strlen(ssid_string) + 1));
  252. strcpy(beaconlist_stage->ssids[i], ssid_string);
  253. }
  254. // Timeout
  255. cJSON* timeout = cJSON_GetObjectItem(stage_beaconlist, "timeout");
  256. beaconlist_stage->timeout = timeout != NULL ? (int)cJSON_GetNumberValue(timeout) : WIFI_MARAUDER_DEFAULT_TIMEOUT_BEACON;
  257. // Random SSIDs
  258. cJSON* random_ssids = cJSON_GetObjectItem(stage_beaconlist, "generate");
  259. beaconlist_stage->random_ssids = random_ssids != NULL ? (int)cJSON_GetNumberValue(random_ssids) : 0;
  260. return beaconlist_stage;
  261. }
  262. WifiMarauderScriptStageBeaconAp* _wifi_marauder_script_get_stage_beacon_ap(cJSON *stages) {
  263. cJSON* beaconap_stage_json = cJSON_GetObjectItem(stages, "beaconAp");
  264. if (beaconap_stage_json == NULL) {
  265. return NULL;
  266. }
  267. cJSON* timeout_json = cJSON_GetObjectItem(beaconap_stage_json, "timeout");
  268. int timeout = timeout_json != NULL ? (int)cJSON_GetNumberValue(timeout_json) : WIFI_MARAUDER_DEFAULT_TIMEOUT_BEACON;
  269. WifiMarauderScriptStageBeaconAp *beacon_ap_stage = (WifiMarauderScriptStageBeaconAp*) malloc(sizeof(WifiMarauderScriptStageBeaconAp));
  270. beacon_ap_stage->timeout = timeout;
  271. return beacon_ap_stage;
  272. }
  273. WifiMarauderScriptStage* _wifi_marauder_script_create_stage(WifiMarauderScriptStageType type, void* stage_data) {
  274. WifiMarauderScriptStage* stage = (WifiMarauderScriptStage*) malloc(sizeof(WifiMarauderScriptStage));
  275. stage->type = type;
  276. stage->stage = stage_data;
  277. stage->next_stage = NULL;
  278. return stage;
  279. }
  280. void _wifi_marauder_script_add_stage(WifiMarauderScript *script, WifiMarauderScriptStage *stage, WifiMarauderScriptStage **prev_stage) {
  281. if (*prev_stage != NULL) {
  282. (*prev_stage)->next_stage = stage;
  283. } else {
  284. script->first_stage = stage;
  285. }
  286. *prev_stage = stage;
  287. }
  288. void _wifi_marauder_script_load_stages(WifiMarauderScript *script, cJSON *stages) {
  289. WifiMarauderScriptStage *prev_stage = NULL;
  290. // Scan stage
  291. WifiMarauderScriptStageScan *stage_scan = _wifi_marauder_script_get_stage_scan(stages);
  292. if (stage_scan != NULL) {
  293. _wifi_marauder_script_add_stage(
  294. script,
  295. _wifi_marauder_script_create_stage(WifiMarauderScriptStageTypeScan, stage_scan),
  296. &prev_stage
  297. );
  298. }
  299. // Select stage
  300. WifiMarauderScriptStageSelect *stage_select = _wifi_marauder_script_get_stage_select(stages);
  301. if (stage_select != NULL) {
  302. _wifi_marauder_script_add_stage(
  303. script,
  304. _wifi_marauder_script_create_stage(WifiMarauderScriptStageTypeSelect, stage_select),
  305. &prev_stage
  306. );
  307. }
  308. // Deauth stage
  309. WifiMarauderScriptStageDeauth *stage_deauth = _wifi_marauder_script_get_stage_deauth(stages);
  310. if (stage_deauth != NULL) {
  311. _wifi_marauder_script_add_stage(
  312. script,
  313. _wifi_marauder_script_create_stage(WifiMarauderScriptStageTypeDeauth, stage_deauth),
  314. &prev_stage
  315. );
  316. }
  317. // Probe stage
  318. WifiMarauderScriptStageProbe *stage_probe = _wifi_marauder_script_get_stage_probe(stages);
  319. if (stage_probe != NULL) {
  320. _wifi_marauder_script_add_stage(
  321. script,
  322. _wifi_marauder_script_create_stage(WifiMarauderScriptStageTypeProbe, stage_probe),
  323. &prev_stage
  324. );
  325. }
  326. // Sniff raw stage
  327. WifiMarauderScriptStageSniffRaw *sniff_raw = _wifi_marauder_script_get_stage_sniff_raw(stages);
  328. if (sniff_raw != NULL) {
  329. _wifi_marauder_script_add_stage(
  330. script,
  331. _wifi_marauder_script_create_stage(WifiMarauderScriptStageTypeSniffRaw, sniff_raw),
  332. &prev_stage
  333. );
  334. }
  335. // Sniff beacon stage
  336. WifiMarauderScriptStageSniffBeacon *sniff_beacon = _wifi_marauder_script_get_stage_sniff_beacon(stages);
  337. if (sniff_beacon != NULL) {
  338. _wifi_marauder_script_add_stage(
  339. script,
  340. _wifi_marauder_script_create_stage(WifiMarauderScriptStageTypeSniffBeacon, sniff_beacon),
  341. &prev_stage
  342. );
  343. }
  344. // Sniff deauth stage
  345. WifiMarauderScriptStageSniffDeauth *sniff_deauth = _wifi_marauder_script_get_stage_sniff_deauth(stages);
  346. if (sniff_deauth != NULL) {
  347. _wifi_marauder_script_add_stage(
  348. script,
  349. _wifi_marauder_script_create_stage(WifiMarauderScriptStageTypeSniffDeauth, sniff_deauth),
  350. &prev_stage
  351. );
  352. }
  353. // Sniff esp stage
  354. WifiMarauderScriptStageSniffEsp *sniff_esp = _wifi_marauder_script_get_stage_sniff_esp(stages);
  355. if (sniff_esp != NULL) {
  356. _wifi_marauder_script_add_stage(
  357. script,
  358. _wifi_marauder_script_create_stage(WifiMarauderScriptStageTypeSniffEsp, sniff_esp),
  359. &prev_stage
  360. );
  361. }
  362. // Sniff PMKID stage
  363. WifiMarauderScriptStageSniffPmkid *sniff_pmkid = _wifi_marauder_script_get_stage_sniff_pmkid(stages);
  364. if (sniff_pmkid != NULL) {
  365. _wifi_marauder_script_add_stage(
  366. script,
  367. _wifi_marauder_script_create_stage(WifiMarauderScriptStageTypeSniffPmkid, sniff_pmkid),
  368. &prev_stage
  369. );
  370. }
  371. // Sniff pwn stage
  372. WifiMarauderScriptStageSniffPwn *sniff_pwn = _wifi_marauder_script_get_stage_sniff_pwn(stages);
  373. if (sniff_pwn != NULL) {
  374. _wifi_marauder_script_add_stage(
  375. script,
  376. _wifi_marauder_script_create_stage(WifiMarauderScriptStageTypeSniffPwn, sniff_pwn),
  377. &prev_stage
  378. );
  379. }
  380. // Beacon List stage
  381. WifiMarauderScriptStageBeaconList *stage_beacon_list = _wifi_marauder_script_get_stage_beacon_list(stages);
  382. if (stage_beacon_list != NULL) {
  383. _wifi_marauder_script_add_stage(
  384. script,
  385. _wifi_marauder_script_create_stage(WifiMarauderScriptStageTypeBeaconList, stage_beacon_list),
  386. &prev_stage
  387. );
  388. }
  389. // Beacon Ap stage
  390. WifiMarauderScriptStageBeaconAp *stage_beacon_ap = _wifi_marauder_script_get_stage_beacon_ap(stages);
  391. if (stage_beacon_ap != NULL) {
  392. _wifi_marauder_script_add_stage(
  393. script,
  394. _wifi_marauder_script_create_stage(WifiMarauderScriptStageTypeBeaconAp, stage_beacon_ap),
  395. &prev_stage
  396. );
  397. }
  398. }
  399. WifiMarauderScript *wifi_marauder_script_parse_raw(const char* json_raw) {
  400. WifiMarauderScript *script = wifi_marauder_script_alloc();
  401. if (script == NULL) {
  402. return NULL;
  403. }
  404. cJSON* json = cJSON_Parse(json_raw);
  405. if (json == NULL) {
  406. return NULL;
  407. }
  408. cJSON* meta = cJSON_GetObjectItem(json, "meta");
  409. _wifi_marauder_script_load_meta(script, meta);
  410. cJSON* stages = cJSON_GetObjectItem(json, "stages");
  411. _wifi_marauder_script_load_stages(script, stages);
  412. return script;
  413. }
  414. WifiMarauderScript *wifi_marauder_script_parse_file(const char* file_path, Storage* storage) {
  415. WifiMarauderScript *script = NULL;
  416. File* script_file = storage_file_alloc(storage);
  417. if (storage_file_open(script_file, file_path, FSAM_READ, FSOM_OPEN_EXISTING)) {
  418. uint32_t file_size = storage_file_size(script_file);
  419. char* json_buffer = (char*)malloc(file_size + 1);
  420. uint16_t bytes_read = storage_file_read(script_file, json_buffer, file_size);
  421. json_buffer[bytes_read] = '\0';
  422. script = wifi_marauder_script_parse_raw(json_buffer);
  423. if (script != NULL) {
  424. // Set script name
  425. FuriString* script_name = furi_string_alloc();
  426. path_extract_filename_no_ext(file_path, script_name);
  427. script->name = strdup(furi_string_get_cstr(script_name));
  428. furi_string_free(script_name);
  429. }
  430. storage_file_close(script_file);
  431. }
  432. storage_file_free(script_file);
  433. return script;
  434. }
  435. WifiMarauderScriptStage* wifi_marauder_script_get_stage(WifiMarauderScript* script, WifiMarauderScriptStageType stage_type) {
  436. if (script == NULL) {
  437. return NULL;
  438. }
  439. WifiMarauderScriptStage* current_stage = script->first_stage;
  440. while (current_stage != NULL) {
  441. if (current_stage->type == stage_type) {
  442. return current_stage;
  443. }
  444. current_stage = current_stage->next_stage;
  445. }
  446. return NULL;
  447. }
  448. void wifi_marauder_script_free(WifiMarauderScript *script) {
  449. if (script == NULL) {
  450. return;
  451. }
  452. WifiMarauderScriptStage *current_stage = script->first_stage;
  453. while (current_stage != NULL) {
  454. WifiMarauderScriptStage *next_stage = current_stage->next_stage;
  455. switch (current_stage->type) {
  456. case WifiMarauderScriptStageTypeScan:
  457. free(current_stage->stage);
  458. break;
  459. case WifiMarauderScriptStageTypeSelect:
  460. if (((WifiMarauderScriptStageSelect *) current_stage->stage)->filter != NULL) {
  461. free(((WifiMarauderScriptStageSelect *) current_stage->stage)->filter);
  462. }
  463. if (((WifiMarauderScriptStageSelect *) current_stage->stage)->indexes != NULL) {
  464. free(((WifiMarauderScriptStageSelect *) current_stage->stage)->indexes);
  465. }
  466. free(current_stage->stage);
  467. break;
  468. case WifiMarauderScriptStageTypeDeauth:
  469. free(current_stage->stage);
  470. break;
  471. case WifiMarauderScriptStageTypeProbe:
  472. free(current_stage->stage);
  473. break;
  474. case WifiMarauderScriptStageTypeSniffRaw:
  475. free(current_stage->stage);
  476. break;
  477. case WifiMarauderScriptStageTypeSniffBeacon:
  478. free(current_stage->stage);
  479. break;
  480. case WifiMarauderScriptStageTypeSniffDeauth:
  481. free(current_stage->stage);
  482. break;
  483. case WifiMarauderScriptStageTypeSniffEsp:
  484. free(current_stage->stage);
  485. break;
  486. case WifiMarauderScriptStageTypeSniffPmkid:
  487. free(current_stage->stage);
  488. break;
  489. case WifiMarauderScriptStageTypeSniffPwn:
  490. free(current_stage->stage);
  491. break;
  492. case WifiMarauderScriptStageTypeBeaconList:
  493. for (int i = 0; i < ((WifiMarauderScriptStageBeaconList *) current_stage->stage)->ssid_count; i++) {
  494. free(((WifiMarauderScriptStageBeaconList *) current_stage->stage)->ssids[i]);
  495. }
  496. free(((WifiMarauderScriptStageBeaconList *) current_stage->stage)->ssids);
  497. free(current_stage->stage);
  498. break;
  499. case WifiMarauderScriptStageTypeBeaconAp:
  500. free(current_stage->stage);
  501. break;
  502. }
  503. free(current_stage);
  504. current_stage = next_stage;
  505. }
  506. free(script->name);
  507. free(script->description);
  508. free(script);
  509. }