Island: Add NodeUpdateFacade.get_event_source_machine()
This commit is contained in:
parent
b6a6295ae8
commit
563957f9c2
|
@ -1,11 +1,15 @@
|
||||||
|
from functools import lru_cache
|
||||||
from ipaddress import IPv4Address, IPv4Interface
|
from ipaddress import IPv4Address, IPv4Interface
|
||||||
|
|
||||||
|
from common.agent_events import AbstractAgentEvent
|
||||||
|
from common.types import AgentID, MachineID
|
||||||
from monkey_island.cc.models import Machine
|
from monkey_island.cc.models import Machine
|
||||||
from monkey_island.cc.repository import IMachineRepository, UnknownRecordError
|
from monkey_island.cc.repository import IAgentRepository, IMachineRepository, UnknownRecordError
|
||||||
|
|
||||||
|
|
||||||
class NodeUpdateFacade:
|
class NodeUpdateFacade:
|
||||||
def __init__(self, machine_repository: IMachineRepository):
|
def __init__(self, agent_repository: IAgentRepository, machine_repository: IMachineRepository):
|
||||||
|
self._agent_repository = agent_repository
|
||||||
self._machine_repository = machine_repository
|
self._machine_repository = machine_repository
|
||||||
|
|
||||||
def get_or_create_target_machine(self, target: IPv4Address):
|
def get_or_create_target_machine(self, target: IPv4Address):
|
||||||
|
@ -19,3 +23,11 @@ class NodeUpdateFacade:
|
||||||
)
|
)
|
||||||
self._machine_repository.upsert_machine(machine)
|
self._machine_repository.upsert_machine(machine)
|
||||||
return machine
|
return machine
|
||||||
|
|
||||||
|
def get_event_source_machine(self, event: AbstractAgentEvent) -> Machine:
|
||||||
|
machine_id = self._get_machine_id_from_agent_id(event.source)
|
||||||
|
return self._machine_repository.get_machine_by_id(machine_id)
|
||||||
|
|
||||||
|
@lru_cache(maxsize=None)
|
||||||
|
def _get_machine_id_from_agent_id(self, agent_id: AgentID) -> MachineID:
|
||||||
|
return self._agent_repository.get_agent_by_id(agent_id).machine_id
|
||||||
|
|
|
@ -33,7 +33,7 @@ class ScanEventHandler:
|
||||||
machine_repository: IMachineRepository,
|
machine_repository: IMachineRepository,
|
||||||
node_repository: INodeRepository,
|
node_repository: INodeRepository,
|
||||||
):
|
):
|
||||||
self._node_update_facade = NodeUpdateFacade(machine_repository)
|
self._node_update_facade = NodeUpdateFacade(agent_repository, machine_repository)
|
||||||
self._agent_repository = agent_repository
|
self._agent_repository = agent_repository
|
||||||
self._machine_repository = machine_repository
|
self._machine_repository = machine_repository
|
||||||
self._node_repository = node_repository
|
self._node_repository = node_repository
|
||||||
|
|
|
@ -1,45 +1,87 @@
|
||||||
from ipaddress import IPv4Address, IPv4Interface
|
from ipaddress import IPv4Address, IPv4Interface
|
||||||
from unittest.mock import MagicMock
|
from unittest.mock import MagicMock
|
||||||
|
from uuid import UUID
|
||||||
|
|
||||||
import pytest
|
import pytest
|
||||||
|
|
||||||
|
from common.agent_events import AbstractAgentEvent
|
||||||
|
from common.types import AgentID, MachineID, SocketAddress
|
||||||
from monkey_island.cc.agent_event_handlers.node_update_facade import NodeUpdateFacade
|
from monkey_island.cc.agent_event_handlers.node_update_facade import NodeUpdateFacade
|
||||||
from monkey_island.cc.models import Machine
|
from monkey_island.cc.models import Agent, Machine
|
||||||
from monkey_island.cc.repository import IMachineRepository, UnknownRecordError
|
from monkey_island.cc.repository import IAgentRepository, IMachineRepository, UnknownRecordError
|
||||||
|
|
||||||
|
|
||||||
|
class TestEvent(AbstractAgentEvent):
|
||||||
|
success: bool
|
||||||
|
|
||||||
|
|
||||||
SEED_ID = 99
|
SEED_ID = 99
|
||||||
IP_ADDRESS = IPv4Address("10.10.10.99")
|
IP_ADDRESS = IPv4Address("10.10.10.99")
|
||||||
|
|
||||||
EXISTING_MACHINE = Machine(
|
SOURCE_MACHINE_ID = 1
|
||||||
id=1,
|
SOURCE_MACHINE = Machine(
|
||||||
|
id=SOURCE_MACHINE_ID,
|
||||||
hardware_id=5,
|
hardware_id=5,
|
||||||
network_interfaces=[IPv4Interface(IP_ADDRESS)],
|
network_interfaces=[IPv4Interface(IP_ADDRESS)],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
SOURCE_AGENT_ID = UUID("655fd01c-5eec-4e42-b6e3-1fb738c2978d")
|
||||||
|
SOURCE_AGENT = Agent(
|
||||||
|
id=SOURCE_AGENT_ID,
|
||||||
|
machine_id=SOURCE_MACHINE_ID,
|
||||||
|
start_time=0,
|
||||||
|
parent_id=None,
|
||||||
|
cc_server=(SocketAddress(ip="10.10.10.10", port=5000)),
|
||||||
|
)
|
||||||
|
|
||||||
EXPECTED_CREATED_MACHINE = Machine(
|
EXPECTED_CREATED_MACHINE = Machine(
|
||||||
id=SEED_ID,
|
id=SEED_ID,
|
||||||
network_interfaces=[IPv4Interface(IP_ADDRESS)],
|
network_interfaces=[IPv4Interface(IP_ADDRESS)],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
TEST_EVENT = TestEvent(source=SOURCE_AGENT_ID, success=True)
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def agent_repository() -> IAgentRepository:
|
||||||
|
def get_agent_by_id(agent_id: AgentID) -> Agent:
|
||||||
|
if agent_id == SOURCE_AGENT_ID:
|
||||||
|
return SOURCE_AGENT
|
||||||
|
|
||||||
|
raise UnknownRecordError()
|
||||||
|
|
||||||
|
agent_repository = MagicMock(spec=IAgentRepository)
|
||||||
|
agent_repository.get_agent_by_id = MagicMock(side_effect=get_agent_by_id)
|
||||||
|
return agent_repository
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def machine_repository() -> IMachineRepository:
|
def machine_repository() -> IMachineRepository:
|
||||||
|
def get_machine_by_id(machine_id: MachineID) -> Machine:
|
||||||
|
if machine_id == SOURCE_MACHINE_ID:
|
||||||
|
return SOURCE_MACHINE
|
||||||
|
|
||||||
|
raise UnknownRecordError()
|
||||||
|
|
||||||
machine_repository = MagicMock(spec=IMachineRepository)
|
machine_repository = MagicMock(spec=IMachineRepository)
|
||||||
machine_repository.get_new_id = MagicMock(return_value=SEED_ID)
|
machine_repository.get_new_id = MagicMock(return_value=SEED_ID)
|
||||||
|
machine_repository.get_machine_by_id = MagicMock(side_effect=get_machine_by_id)
|
||||||
return machine_repository
|
return machine_repository
|
||||||
|
|
||||||
|
|
||||||
@pytest.fixture
|
@pytest.fixture
|
||||||
def node_update_facade(machine_repository) -> NodeUpdateFacade:
|
def node_update_facade(
|
||||||
return NodeUpdateFacade(machine_repository)
|
agent_repository: IAgentRepository, machine_repository: IMachineRepository
|
||||||
|
) -> NodeUpdateFacade:
|
||||||
|
return NodeUpdateFacade(agent_repository, machine_repository)
|
||||||
|
|
||||||
|
|
||||||
def test_return_existing_machine(node_update_facade, machine_repository):
|
def test_return_existing_machine(node_update_facade, machine_repository):
|
||||||
machine_repository.get_machines_by_ip = MagicMock(return_value=[EXISTING_MACHINE])
|
machine_repository.get_machines_by_ip = MagicMock(return_value=[SOURCE_MACHINE])
|
||||||
|
|
||||||
target_machine = node_update_facade.get_or_create_target_machine(IP_ADDRESS)
|
target_machine = node_update_facade.get_or_create_target_machine(IP_ADDRESS)
|
||||||
|
|
||||||
assert target_machine == EXISTING_MACHINE
|
assert target_machine == SOURCE_MACHINE
|
||||||
|
|
||||||
|
|
||||||
def test_create_new_machine(node_update_facade, machine_repository):
|
def test_create_new_machine(node_update_facade, machine_repository):
|
||||||
|
@ -49,3 +91,7 @@ def test_create_new_machine(node_update_facade, machine_repository):
|
||||||
|
|
||||||
assert target_machine == EXPECTED_CREATED_MACHINE
|
assert target_machine == EXPECTED_CREATED_MACHINE
|
||||||
assert machine_repository.upsert_machine.called_once_with(target_machine)
|
assert machine_repository.upsert_machine.called_once_with(target_machine)
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_event_source_machine(node_update_facade):
|
||||||
|
assert node_update_facade.get_event_source_machine(TEST_EVENT) == SOURCE_MACHINE
|
||||||
|
|
Loading…
Reference in New Issue