| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- #include "nameflood.h"
- #include "_protocols.h"
- // Hacked together by @Willy-JL
- static const char* names[] = {
- "Assquach💦",
- "Flipper 🐬",
- "iOS 17 🍎",
- "Kink💦",
- "👉👌",
- "🔵🦷",
- };
- static const uint8_t names_count = COUNT_OF(names);
- static const char* get_name(const Payload* payload) {
- UNUSED(payload);
- return "NameFlood";
- }
- static void make_packet(uint8_t* _size, uint8_t** _packet, Payload* payload) {
- NamefloodCfg* cfg = payload ? &payload->cfg.nameflood : NULL;
- const char* name;
- switch(cfg ? payload->mode : PayloadModeRandom) {
- case PayloadModeRandom:
- default:
- name = names[rand() % names_count];
- break;
- case PayloadModeValue:
- name = cfg->name;
- break;
- }
- uint8_t name_len = strlen(name);
- uint8_t size = 12 + name_len;
- uint8_t* packet = malloc(size);
- uint8_t i = 0;
- packet[i++] = 2; // Size
- packet[i++] = 0x01; // AD Type (Flags)
- packet[i++] = 0x06; // Flags
- packet[i++] = name_len + 1; // Size
- packet[i++] = 0x09; // AD Type (Complete Local Name)
- memcpy(&packet[i], name, name_len); // Device Name
- i += name_len;
- packet[i++] = 3; // Size
- packet[i++] = 0x02; // AD Type (Incomplete Service UUID List)
- packet[i++] = 0x12; // Service UUID (Human Interface Device)
- packet[i++] = 0x18; // ...
- packet[i++] = 2; // Size
- packet[i++] = 0x0A; // AD Type (Tx Power Level)
- packet[i++] = 0x00; // 0dBm
- *_size = size;
- *_packet = packet;
- }
- enum {
- _ConfigExtraStart = ConfigExtraStart,
- ConfigName,
- ConfigInfoSettings,
- ConfigCOUNT,
- };
- static void config_callback(void* _ctx, uint32_t index) {
- Ctx* ctx = _ctx;
- scene_manager_set_scene_state(ctx->scene_manager, SceneConfig, index);
- switch(index) {
- case ConfigName:
- scene_manager_next_scene(ctx->scene_manager, SceneNamefloodName);
- break;
- case ConfigInfoSettings:
- break;
- default:
- ctx->fallback_config_enter(ctx, index);
- break;
- }
- }
- static void extra_config(Ctx* ctx) {
- Payload* payload = &ctx->attack->payload;
- NamefloodCfg* cfg = &payload->cfg.nameflood;
- VariableItemList* list = ctx->variable_item_list;
- VariableItem* item;
- item = variable_item_list_add(list, "Display Name", 0, NULL, NULL);
- variable_item_set_current_value_text(
- item, payload->mode == PayloadModeRandom ? "Random" : cfg->name);
- variable_item_list_add(list, "See in phone BT settings", 0, NULL, NULL);
- variable_item_list_set_enter_callback(list, config_callback, ctx);
- }
- static uint8_t config_count(const Payload* payload) {
- UNUSED(payload);
- return ConfigCOUNT - ConfigExtraStart - 1;
- }
- const Protocol protocol_nameflood = {
- .icon = &I_ble_spam,
- .get_name = get_name,
- .make_packet = make_packet,
- .extra_config = extra_config,
- .config_count = config_count,
- };
- static void name_callback(void* _ctx) {
- Ctx* ctx = _ctx;
- Payload* payload = &ctx->attack->payload;
- payload->mode = PayloadModeValue;
- scene_manager_previous_scene(ctx->scene_manager);
- }
- void scene_nameflood_name_on_enter(void* _ctx) {
- Ctx* ctx = _ctx;
- Payload* payload = &ctx->attack->payload;
- NamefloodCfg* cfg = &payload->cfg.nameflood;
- TextInput* text_input = ctx->text_input;
- text_input_set_header_text(text_input, "Press back for random");
- text_input_set_result_callback(
- text_input, name_callback, ctx, cfg->name, sizeof(cfg->name), true);
- text_input_set_minimum_length(text_input, 0);
- view_dispatcher_switch_to_view(ctx->view_dispatcher, ViewTextInput);
- }
- bool scene_nameflood_name_on_event(void* _ctx, SceneManagerEvent event) {
- Ctx* ctx = _ctx;
- Payload* payload = &ctx->attack->payload;
- if(event.type == SceneManagerEventTypeBack) {
- payload->mode = PayloadModeRandom;
- }
- return false;
- }
- void scene_nameflood_name_on_exit(void* _ctx) {
- Ctx* ctx = _ctx;
- text_input_reset(ctx->text_input);
- }
|