diff --git a/monkey/monkey_island/cc/agent_event_subscribers/__init__.py b/monkey/monkey_island/cc/agent_event_subscribers/__init__.py new file mode 100644 index 000000000..f206087d7 --- /dev/null +++ b/monkey/monkey_island/cc/agent_event_subscribers/__init__.py @@ -0,0 +1 @@ +from .save_event_to_event_repository import save_event_to_event_repository diff --git a/monkey/monkey_island/cc/agent_event_subscribers/save_event_to_event_repository.py b/monkey/monkey_island/cc/agent_event_subscribers/save_event_to_event_repository.py new file mode 100644 index 000000000..0249369b3 --- /dev/null +++ b/monkey/monkey_island/cc/agent_event_subscribers/save_event_to_event_repository.py @@ -0,0 +1,17 @@ +import logging + +from common.events import AbstractAgentEvent +from monkey_island.cc.repository import IEventRepository, StorageError + +logger = logging.getLogger(__name__) + + +class save_event_to_event_repository: + def __init__(self, event_repository: IEventRepository): + self._event_repository = event_repository + + def __call__(self, event: AbstractAgentEvent): + try: + self._event_repository.save_event(event) + except StorageError as err: + logger.error(f"Error occured storing event {event}: {err}")