subbrute_scene_setup_attack.c 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. #include "../subbrute_i.h"
  2. #include "../subbrute_custom_event.h"
  3. #include "../views/subbrute_attack_view.h"
  4. #define TAG "SubBruteSceneSetupAttack"
  5. static void subbrute_scene_setup_attack_callback(SubBruteCustomEvent event, void* context) {
  6. furi_assert(context);
  7. SubBruteState* instance = (SubBruteState*)context;
  8. view_dispatcher_send_custom_event(instance->view_dispatcher, event);
  9. }
  10. void subbrute_scene_setup_attack_on_enter(void* context) {
  11. furi_assert(context);
  12. SubBruteState* instance = (SubBruteState*)context;
  13. SubBruteAttackView* view = instance->view_attack;
  14. #ifdef FURI_DEBUG
  15. FURI_LOG_D(TAG, "Enter Attack: %d", instance->device->attack);
  16. #endif
  17. subbrute_attack_view_init_values(
  18. view,
  19. instance->device->attack,
  20. instance->device->max_value,
  21. instance->device->key_index,
  22. false);
  23. if(!subbrute_worker_init_manual_transmit(
  24. instance->worker,
  25. instance->device->frequency,
  26. instance->device->preset,
  27. string_get_cstr(instance->device->protocol_name))) {
  28. FURI_LOG_W(TAG, "Worker init failed!");
  29. }
  30. instance->current_view = SubBruteViewAttack;
  31. subbrute_attack_view_set_callback(view, subbrute_scene_setup_attack_callback, instance);
  32. view_dispatcher_switch_to_view(instance->view_dispatcher, instance->current_view);
  33. }
  34. void subbrute_scene_setup_attack_on_exit(void* context) {
  35. furi_assert(context);
  36. #ifdef FURI_DEBUG
  37. FURI_LOG_D(TAG, "subbrute_scene_setup_attack_on_exit");
  38. #endif
  39. SubBruteState* instance = (SubBruteState*)context;
  40. subbrute_worker_manual_transmit_stop(instance->worker);
  41. notification_message(instance->notifications, &sequence_blink_stop);
  42. }
  43. bool subbrute_scene_setup_attack_on_event(void* context, SceneManagerEvent event) {
  44. SubBruteState* instance = (SubBruteState*)context;
  45. SubBruteAttackView* view = instance->view_attack;
  46. bool consumed = false;
  47. if(event.type == SceneManagerEventTypeCustom) {
  48. if(event.event == SubBruteCustomEventTypeTransmitStarted) {
  49. subbrute_worker_set_continuous_worker(instance->worker, false);
  50. subbrute_attack_view_set_worker_type(view, false);
  51. scene_manager_next_scene(instance->scene_manager, SubBruteSceneRunAttack);
  52. } else if(event.event == SubBruteCustomEventTypeTransmitContinuousStarted) {
  53. // Setting different type of worker
  54. subbrute_worker_set_continuous_worker(instance->worker, true);
  55. subbrute_attack_view_set_worker_type(view, true);
  56. scene_manager_next_scene(instance->scene_manager, SubBruteSceneRunAttack);
  57. } else if(event.event == SubBruteCustomEventTypeSaveFile) {
  58. subbrute_worker_manual_transmit_stop(instance->worker);
  59. subbrute_attack_view_init_values(
  60. view,
  61. instance->device->attack,
  62. instance->device->max_value,
  63. instance->device->key_index,
  64. false);
  65. scene_manager_next_scene(instance->scene_manager, SubBruteSceneSaveName);
  66. } else if(event.event == SubBruteCustomEventTypeBackPressed) {
  67. #ifdef FURI_DEBUG
  68. FURI_LOG_D(TAG, "SubBruteCustomEventTypeBackPressed");
  69. #endif
  70. instance->device->key_index = 0x00;
  71. //subbrute_attack_view_stop_worker(view);
  72. subbrute_attack_view_init_values(
  73. view,
  74. instance->device->attack,
  75. instance->device->max_value,
  76. instance->device->key_index,
  77. false);
  78. scene_manager_next_scene(instance->scene_manager, SubBruteSceneStart);
  79. } else if(event.event == SubBruteCustomEventTypeChangeStepUp) {
  80. // +1
  81. if((instance->device->key_index + 1) - instance->device->max_value == 1) {
  82. instance->device->key_index = 0x00;
  83. } else {
  84. uint64_t value = instance->device->key_index + 1;
  85. if(value == instance->device->max_value) {
  86. instance->device->key_index = value;
  87. } else {
  88. instance->device->key_index = value % instance->device->max_value;
  89. }
  90. }
  91. subbrute_attack_view_set_current_step(view, instance->device->key_index);
  92. } else if(event.event == SubBruteCustomEventTypeChangeStepUpMore) {
  93. // +50
  94. uint64_t value = instance->device->key_index + 50;
  95. if(value == instance->device->max_value) {
  96. instance->device->key_index += value;
  97. } else {
  98. instance->device->key_index = value % instance->device->max_value;
  99. }
  100. subbrute_attack_view_set_current_step(view, instance->device->key_index);
  101. } else if(event.event == SubBruteCustomEventTypeChangeStepDown) {
  102. // -1
  103. if(instance->device->key_index - 1 == 0) {
  104. instance->device->key_index = 0x00;
  105. } else if(instance->device->key_index == 0) {
  106. instance->device->key_index = instance->device->max_value;
  107. } else {
  108. uint64_t value = ((instance->device->key_index - 1) + instance->device->max_value);
  109. if(value == instance->device->max_value) {
  110. instance->device->key_index = value;
  111. } else {
  112. instance->device->key_index = value % instance->device->max_value;
  113. }
  114. }
  115. subbrute_attack_view_set_current_step(view, instance->device->key_index);
  116. } else if(event.event == SubBruteCustomEventTypeChangeStepDownMore) {
  117. // -50
  118. uint64_t value = ((instance->device->key_index - 50) + instance->device->max_value);
  119. if(value == instance->device->max_value) {
  120. instance->device->key_index = value;
  121. } else {
  122. instance->device->key_index = value % instance->device->max_value;
  123. }
  124. subbrute_attack_view_set_current_step(view, instance->device->key_index);
  125. } else if(event.event == SubBruteCustomEventTypeTransmitCustom) {
  126. if(subbrute_worker_can_manual_transmit(instance->worker, true)) {
  127. // Blink
  128. notification_message(instance->notifications, &sequence_blink_green_100);
  129. // if(!subbrute_attack_view_is_worker_running(view)) {
  130. // subbrute_attack_view_start_worker(
  131. // view,
  132. // instance->device->frequency,
  133. // instance->device->preset,
  134. // string_get_cstr(instance->device->protocol_name));
  135. // }
  136. subbrute_device_create_packet_parsed(
  137. instance->device, instance->device->key_index, false);
  138. subbrute_worker_manual_transmit(instance->worker, instance->device->payload);
  139. // Stop
  140. notification_message(instance->notifications, &sequence_blink_stop);
  141. }
  142. }
  143. consumed = true;
  144. }
  145. // if(event.type == SceneManagerEventTypeCustom) {
  146. // switch(event.event) {
  147. // case SubBruteCustomEventTypeMenuSelected:
  148. // with_view_model(
  149. // view, (SubBruteMainViewModel * model) {
  150. // instance->menu_index = model->index;
  151. // return false;
  152. // });
  153. // scene_manager_next_scene(instance->scene_manager, SubBruteSceneLoadFile);
  154. // consumed = true;
  155. // break;
  156. // case SubBruteCustomEventTypeLoadFile:
  157. // with_view_model(
  158. // view, (SubBruteMainViewModel * model) {
  159. // instance->menu_index = model->index;
  160. // return false;
  161. // });
  162. // scene_manager_next_scene(instance->scene_manager, SubBruteSceneSetupAttack);
  163. // consumed = true;
  164. // break;
  165. // }
  166. // }
  167. return consumed;
  168. }