forked from p15670423/monkey
Island: Simplify event query and deserialization
This commit is contained in:
parent
8311fc79a9
commit
cd84280e79
|
@ -1,4 +1,4 @@
|
||||||
from typing import Any, MutableMapping, Sequence, Type
|
from typing import Any, Dict, MutableMapping, Sequence, Type
|
||||||
|
|
||||||
from pymongo import MongoClient
|
from pymongo import MongoClient
|
||||||
|
|
||||||
|
@ -28,8 +28,7 @@ class MongoEventRepository(IEventRepository):
|
||||||
|
|
||||||
def get_events(self) -> Sequence[AbstractAgentEvent]:
|
def get_events(self) -> Sequence[AbstractAgentEvent]:
|
||||||
try:
|
try:
|
||||||
serialized_events = list(self._events_collection.find())
|
return self._query_events({})
|
||||||
return list(map(self._deserialize, serialized_events))
|
|
||||||
except Exception as err:
|
except Exception as err:
|
||||||
raise RetrievalError(f"Error retrieving events: {err}")
|
raise RetrievalError(f"Error retrieving events: {err}")
|
||||||
|
|
||||||
|
@ -37,24 +36,19 @@ class MongoEventRepository(IEventRepository):
|
||||||
self, event_type: Type[AbstractAgentEvent]
|
self, event_type: Type[AbstractAgentEvent]
|
||||||
) -> Sequence[AbstractAgentEvent]:
|
) -> Sequence[AbstractAgentEvent]:
|
||||||
try:
|
try:
|
||||||
serialized_events = list(
|
return self._query_events({EVENT_TYPE_FIELD: event_type.__name__})
|
||||||
self._events_collection.find({EVENT_TYPE_FIELD: event_type.__name__})
|
|
||||||
)
|
|
||||||
return list(map(self._deserialize, serialized_events))
|
|
||||||
except Exception as err:
|
except Exception as err:
|
||||||
raise RetrievalError(f"Error retrieving events for type {event_type}: {err}")
|
raise RetrievalError(f"Error retrieving events for type {event_type}: {err}")
|
||||||
|
|
||||||
def get_events_by_tag(self, tag: str) -> Sequence[AbstractAgentEvent]:
|
def get_events_by_tag(self, tag: str) -> Sequence[AbstractAgentEvent]:
|
||||||
try:
|
try:
|
||||||
serialized_events = list(self._events_collection.find({"tags": {"$in": [tag]}}))
|
return self._query_events({"tags": {"$in": [tag]}})
|
||||||
return list(map(self._deserialize, serialized_events))
|
|
||||||
except Exception as err:
|
except Exception as err:
|
||||||
raise RetrievalError(f"Error retrieving events for tag {tag}: {err}")
|
raise RetrievalError(f"Error retrieving events for tag {tag}: {err}")
|
||||||
|
|
||||||
def get_events_by_source(self, source: AgentID) -> Sequence[AbstractAgentEvent]:
|
def get_events_by_source(self, source: AgentID) -> Sequence[AbstractAgentEvent]:
|
||||||
try:
|
try:
|
||||||
serialized_events = list(self._events_collection.find({"source": str(source)}))
|
return self._query_events({"source": str(source)})
|
||||||
return list(map(self._deserialize, serialized_events))
|
|
||||||
except Exception as err:
|
except Exception as err:
|
||||||
raise RetrievalError(f"Error retrieving events for source {source}: {err}")
|
raise RetrievalError(f"Error retrieving events for source {source}: {err}")
|
||||||
|
|
||||||
|
@ -65,7 +59,10 @@ class MongoEventRepository(IEventRepository):
|
||||||
raise RemovalError(f"Error resetting the repository: {err}")
|
raise RemovalError(f"Error resetting the repository: {err}")
|
||||||
|
|
||||||
def _deserialize(self, mongo_record: MutableMapping[str, Any]) -> AbstractAgentEvent:
|
def _deserialize(self, mongo_record: MutableMapping[str, Any]) -> AbstractAgentEvent:
|
||||||
del mongo_record[MONGO_OBJECT_ID_KEY]
|
|
||||||
event_type = mongo_record[EVENT_TYPE_FIELD]
|
event_type = mongo_record[EVENT_TYPE_FIELD]
|
||||||
serializer = self._serializers[event_type]
|
serializer = self._serializers[event_type]
|
||||||
return serializer.deserialize(mongo_record)
|
return serializer.deserialize(mongo_record)
|
||||||
|
|
||||||
|
def _query_events(self, query: Dict[Any, Any]) -> Sequence[AbstractAgentEvent]:
|
||||||
|
serialized_events = list(self._events_collection.find(query, {MONGO_OBJECT_ID_KEY: False}))
|
||||||
|
return list(map(self._deserialize, serialized_events))
|
||||||
|
|
Loading…
Reference in New Issue