From e7b0e6babf7c885b875a3af78267e20de58baecb Mon Sep 17 00:00:00 2001 From: Shreya Malviya Date: Mon, 29 Aug 2022 13:43:43 +0530 Subject: [PATCH] Common: Create ScanTargetConfiguration using pydantic --- .../agent_sub_configurations.py | 46 ++++++++++++++++++- 1 file changed, 45 insertions(+), 1 deletion(-) diff --git a/monkey/common/agent_configuration/agent_sub_configurations.py b/monkey/common/agent_configuration/agent_sub_configurations.py index a01767227..c8eb5ec64 100644 --- a/monkey/common/agent_configuration/agent_sub_configurations.py +++ b/monkey/common/agent_configuration/agent_sub_configurations.py @@ -5,7 +5,15 @@ from pydantic import validator from common.base_models import MutableInfectionMonkeyBaseModel -from .validators import validate_linux_filename, validate_windows_filename +from .validators import ( + validate_hostname, + validate_ip, + validate_ip_network, + validate_ip_range, + validate_linux_filename, + validate_subnet_range, + validate_windows_filename, +) @dataclass(frozen=True) @@ -138,6 +146,42 @@ class ScanTargetConfiguration: subnets: Tuple[str, ...] +class Pydantic___ScanTargetConfiguration(MutableInfectionMonkeyBaseModel): + """ + Configuration of network targets to scan and exploit + + Attributes: + :param blocked_ips: IP's that won't be scanned + Example: ("1.1.1.1", "2.2.2.2") + :param inaccessible_subnets: Subnet ranges that shouldn't be accessible for the agent + Example: ("1.1.1.1", "2.2.2.2/24", "myserver") + :param local_network_scan: Whether or not the agent should scan the local network + :param subnets: Subnet ranges to scan + Example: ("192.168.1.1-192.168.2.255", "3.3.3.3", "2.2.2.2/24", + "myHostname") + """ + + blocked_ips: Tuple[str, ...] + inaccessible_subnets: Tuple[str, ...] + local_network_scan: bool + subnets: Tuple[str, ...] + + @validator("blocked_ips", each_item=True) + def blocked_ips_valid(cls, ip): + validate_ip(ip) + return ip + + @validator("inaccessible_subnets", each_item=True) + def inaccessible_subnets_valid(cls, subnet_range): + validate_subnet_range(subnet_range) + return subnet_range + + @validator("subnets", each_item=True) + def subnets_valid(cls, subnet_range): + validate_subnet_range(subnet_range) + return subnet_range + + @dataclass(frozen=True) class ICMPScanConfiguration: """