Agent: Pass list of servers to Exploiter.exploit_hosts

This commit is contained in:
Ilija Lazoroski 2022-09-05 13:07:05 +02:00 committed by Mike Salvatore
parent 8b2107d197
commit f104f31dcd
2 changed files with 13 additions and 5 deletions

View File

@ -53,6 +53,7 @@ class Exploiter:
exploitation_config: ExploitationConfiguration, exploitation_config: ExploitationConfiguration,
hosts_to_exploit: Queue, hosts_to_exploit: Queue,
current_depth: int, current_depth: int,
servers: Sequence[str],
results_callback: Callback, results_callback: Callback,
scan_completed: Event, scan_completed: Event,
stop: Event, stop: Event,
@ -67,6 +68,7 @@ class Exploiter:
exploiters_to_run, exploiters_to_run,
hosts_to_exploit, hosts_to_exploit,
current_depth, current_depth,
servers,
results_callback, results_callback,
scan_completed, scan_completed,
stop, stop,
@ -103,6 +105,7 @@ class Exploiter:
exploiters_to_run: Sequence[PluginConfiguration], exploiters_to_run: Sequence[PluginConfiguration],
hosts_to_exploit: Queue, hosts_to_exploit: Queue,
current_depth: int, current_depth: int,
servers: Sequence[str],
results_callback: Callback, results_callback: Callback,
scan_completed: Event, scan_completed: Event,
stop: Event, stop: Event,
@ -113,7 +116,7 @@ class Exploiter:
try: try:
victim_host = hosts_to_exploit.get(timeout=QUEUE_TIMEOUT) victim_host = hosts_to_exploit.get(timeout=QUEUE_TIMEOUT)
self._run_all_exploiters( self._run_all_exploiters(
exploiters_to_run, victim_host, current_depth, results_callback, stop exploiters_to_run, victim_host, current_depth, servers, results_callback, stop
) )
except queue.Empty: except queue.Empty:
if _all_hosts_have_been_processed(scan_completed, hosts_to_exploit): if _all_hosts_have_been_processed(scan_completed, hosts_to_exploit):
@ -130,6 +133,7 @@ class Exploiter:
exploiters_to_run: Sequence[PluginConfiguration], exploiters_to_run: Sequence[PluginConfiguration],
victim_host: VictimHost, victim_host: VictimHost,
current_depth: int, current_depth: int,
servers: Sequence[str],
results_callback: Callback, results_callback: Callback,
stop: Event, stop: Event,
): ):
@ -147,7 +151,7 @@ class Exploiter:
continue continue
exploiter_results = self._run_exploiter( exploiter_results = self._run_exploiter(
exploiter_name, exploiter.options, victim_host, current_depth, stop exploiter_name, exploiter.options, victim_host, current_depth, servers, stop
) )
results_callback(exploiter_name, victim_host, exploiter_results) results_callback(exploiter_name, victim_host, exploiter_results)
@ -160,6 +164,7 @@ class Exploiter:
options: Dict, options: Dict,
victim_host: VictimHost, victim_host: VictimHost,
current_depth: int, current_depth: int,
servers: Sequence[str],
stop: Event, stop: Event,
) -> ExploiterResultData: ) -> ExploiterResultData:
logger.debug(f"Attempting to use {exploiter_name} on {victim_host.ip_addr}") logger.debug(f"Attempting to use {exploiter_name} on {victim_host.ip_addr}")
@ -169,7 +174,7 @@ class Exploiter:
try: try:
return self._puppet.exploit_host( return self._puppet.exploit_host(
exploiter_name, victim_host, current_depth, options, stop exploiter_name, victim_host, current_depth, servers, options, stop
) )
except Exception as ex: except Exception as ex:
msg = ( msg = (

View File

@ -85,6 +85,7 @@ def get_host_exploit_combos_from_call_args_list(call_args_list):
CREDENTIALS_FOR_PROPAGATION = {"usernames": ["m0nk3y", "user"], "passwords": ["1234", "pword"]} CREDENTIALS_FOR_PROPAGATION = {"usernames": ["m0nk3y", "user"], "passwords": ["1234", "pword"]}
SERVERS = ["127.0.0.1:5000", "10.10.10.10:5007"]
def get_credentials_for_propagation(): def get_credentials_for_propagation():
@ -98,7 +99,7 @@ def run_exploiters(exploiter_config, hosts_to_exploit, callback, scan_completed,
scan_completed.set() scan_completed.set()
e = Exploiter(puppet, num_workers, get_credentials_for_propagation) e = Exploiter(puppet, num_workers, get_credentials_for_propagation)
e.exploit_hosts(exploiter_config, hosts, 1, callback, scan_completed, stop) e.exploit_hosts(exploiter_config, hosts, 1, SERVERS, callback, scan_completed, stop)
return inner return inner
@ -143,7 +144,9 @@ def test_stop_after_callback(exploiter_config, callback, scan_completed, stop, h
# Intentionally NOT setting scan_completed.set(); _callback() will set stop # Intentionally NOT setting scan_completed.set(); _callback() will set stop
e = Exploiter(MockPuppet(), callback_barrier_count + 2, get_credentials_for_propagation) e = Exploiter(MockPuppet(), callback_barrier_count + 2, get_credentials_for_propagation)
e.exploit_hosts(exploiter_config, hosts_to_exploit, 1, stoppable_callback, scan_completed, stop) e.exploit_hosts(
exploiter_config, hosts_to_exploit, 1, SERVERS, stoppable_callback, scan_completed, stop
)
assert stoppable_callback.call_count == 2 assert stoppable_callback.call_count == 2