From 91a65ee58c0f1609e17c62600ad2b6b6da07fc91 Mon Sep 17 00:00:00 2001 From: Mike Salvatore Date: Wed, 13 Jul 2022 13:00:29 -0400 Subject: [PATCH] Island: Use AgentConfiguration to get network scan settings --- .../monkey_island/cc/services/initialize.py | 4 ++- .../cc/services/reporting/report.py | 29 ++++++++++--------- 2 files changed, 18 insertions(+), 15 deletions(-) diff --git a/monkey/monkey_island/cc/services/initialize.py b/monkey/monkey_island/cc/services/initialize.py index 9cf019421..eb21617ee 100644 --- a/monkey/monkey_island/cc/services/initialize.py +++ b/monkey/monkey_island/cc/services/initialize.py @@ -69,7 +69,9 @@ def initialize_services(data_dir: Path) -> DIContainer: _patch_credentials_parser(container) # This is temporary until we get DI all worked out. - ReportService.initialize(container.resolve(AWSService)) + ReportService.initialize( + container.resolve(AWSService), container.resolve(IAgentConfigurationRepository) + ) return container diff --git a/monkey/monkey_island/cc/services/reporting/report.py b/monkey/monkey_island/cc/services/reporting/report.py index 60d2d33ed..27e76db85 100644 --- a/monkey/monkey_island/cc/services/reporting/report.py +++ b/monkey/monkey_island/cc/services/reporting/report.py @@ -4,18 +4,13 @@ import itertools import logging from typing import List -from common.config_value_paths import ( - EXPLOITER_CLASSES_PATH, - LOCAL_NETWORK_SCAN_PATH, - PASSWORD_LIST_PATH, - SUBNET_SCAN_LIST_PATH, - USER_LIST_PATH, -) +from common.config_value_paths import EXPLOITER_CLASSES_PATH, PASSWORD_LIST_PATH, USER_LIST_PATH from common.network.network_range import NetworkRange from common.network.segmentation_utils import get_ip_in_src_and_not_in_dst from monkey_island.cc.database import mongo from monkey_island.cc.models import Monkey from monkey_island.cc.models.report import get_report, save_report +from monkey_island.cc.repository import IAgentConfigurationRepository from monkey_island.cc.services.config import ConfigService from monkey_island.cc.services.configuration.utils import ( get_config_network_segments_as_subnet_groups, @@ -47,6 +42,7 @@ logger = logging.getLogger(__name__) class ReportService: _aws_service = None + _agent_configuration_repository = None class DerivedIssueEnum: WEAK_PASSWORD = "weak_password" @@ -54,8 +50,11 @@ class ReportService: ZEROLOGON_PASS_RESTORE_FAILED = "zerologon_pass_restore_failed" @classmethod - def initialize(cls, aws_service: AWSService): + def initialize( + cls, aws_service: AWSService, agent_configuration_repository: IAgentConfigurationRepository + ): cls._aws_service = aws_service + cls._agent_configuration_repository = agent_configuration_repository # This should pull from Simulation entity @staticmethod @@ -405,13 +404,15 @@ class ReportService: ExploiterDescriptorEnum.get_by_class_name(exploit).display_name for exploit in exploits ] - @staticmethod - def get_config_ips(): - return ConfigService.get_config_value(SUBNET_SCAN_LIST_PATH, True) + @classmethod + def get_config_ips(cls): + agent_configuration = cls._agent_configuration_repository.get_configuration() + return agent_configuration.propagation.network_scan.targets.subnets - @staticmethod - def get_config_scan(): - return ConfigService.get_config_value(LOCAL_NETWORK_SCAN_PATH, True) + @classmethod + def get_config_scan(cls): + agent_configuration = cls._agent_configuration_repository.get_configuration() + return agent_configuration.propagation.network_scan.targets.local_network_scan @staticmethod def get_issue_set(issues, config_users, config_passwords):