Island: Move error handling to private methods in
MongoCredentialsRepository
This commit is contained in:
parent
c48b38fb01
commit
4226cb5b9e
|
@ -1,6 +1,6 @@
|
||||||
from typing import Sequence
|
from typing import Sequence
|
||||||
|
|
||||||
from flask_pymongo import PyMongo
|
from pymongo import MongoClient
|
||||||
|
|
||||||
from common.credentials import Credentials
|
from common.credentials import Credentials
|
||||||
from monkey_island.cc.repository import RemovalError, RetrievalError, StorageError
|
from monkey_island.cc.repository import RemovalError, RetrievalError, StorageError
|
||||||
|
@ -12,87 +12,70 @@ class MongoCredentialsRepository(ICredentialsRepository):
|
||||||
Store credentials in a mongo database that can be used to propagate around the network.
|
Store credentials in a mongo database that can be used to propagate around the network.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, mongo_db: PyMongo):
|
def __init__(self, mongo: MongoClient):
|
||||||
self._mongo = mongo_db
|
self._mongo = mongo
|
||||||
|
|
||||||
def get_configured_credentials(self) -> Sequence[Credentials]:
|
def get_configured_credentials(self) -> Sequence[Credentials]:
|
||||||
try:
|
return MongoCredentialsRepository._get_credentials_from_collection(
|
||||||
|
self._mongo.db.configured_credentials
|
||||||
return MongoCredentialsRepository._get_credentials_from_collection(
|
)
|
||||||
self._mongo.db.configured_credentials
|
|
||||||
)
|
|
||||||
except Exception as err:
|
|
||||||
raise RetrievalError(err)
|
|
||||||
|
|
||||||
def get_stolen_credentials(self) -> Sequence[Credentials]:
|
def get_stolen_credentials(self) -> Sequence[Credentials]:
|
||||||
try:
|
return MongoCredentialsRepository._get_credentials_from_collection(
|
||||||
return MongoCredentialsRepository._get_credentials_from_collection(
|
self._mongo.db.stolen_credentials
|
||||||
self._mongo.db.stolen_credentials
|
)
|
||||||
)
|
|
||||||
except Exception as err:
|
|
||||||
raise RetrievalError(err)
|
|
||||||
|
|
||||||
def get_all_credentials(self) -> Sequence[Credentials]:
|
def get_all_credentials(self) -> Sequence[Credentials]:
|
||||||
try:
|
configured_credentials = self.get_configured_credentials()
|
||||||
configured_credentials = self.get_configured_credentials()
|
stolen_credentials = self.get_stolen_credentials()
|
||||||
stolen_credentials = self.get_stolen_credentials()
|
|
||||||
|
|
||||||
return [*configured_credentials, *stolen_credentials]
|
return [*configured_credentials, *stolen_credentials]
|
||||||
except RetrievalError as err:
|
|
||||||
raise err
|
|
||||||
|
|
||||||
def save_configured_credentials(self, credentials: Sequence[Credentials]):
|
def save_configured_credentials(self, credentials: Sequence[Credentials]):
|
||||||
# TODO: Fix deduplication of Credentials in mongo
|
# TODO: Fix deduplication of Credentials in mongo
|
||||||
try:
|
MongoCredentialsRepository._save_credentials_to_collection(
|
||||||
MongoCredentialsRepository._save_credentials_to_collection(
|
credentials, self._mongo.db.configured_credentials
|
||||||
credentials, self._mongo.db.configured_credentials
|
)
|
||||||
)
|
|
||||||
except Exception as err:
|
|
||||||
raise StorageError(err)
|
|
||||||
|
|
||||||
def save_stolen_credentials(self, credentials: Sequence[Credentials]):
|
def save_stolen_credentials(self, credentials: Sequence[Credentials]):
|
||||||
# TODO: Fix deduplication of Credentials in mongo
|
MongoCredentialsRepository._save_credentials_to_collection(
|
||||||
try:
|
credentials, self._mongo.db.stolen_credentials
|
||||||
MongoCredentialsRepository._save_credentials_to_collection(
|
)
|
||||||
credentials, self._mongo.db.stolen_credentials
|
|
||||||
)
|
|
||||||
except Exception as err:
|
|
||||||
raise StorageError(err)
|
|
||||||
|
|
||||||
def remove_configured_credentials(self):
|
def remove_configured_credentials(self):
|
||||||
try:
|
MongoCredentialsRepository._delete_collection(self._mongo.db.configured_credentials)
|
||||||
MongoCredentialsRepository._delete_collection(self._mongo.db.configured_credentials)
|
|
||||||
except Exception as err:
|
|
||||||
raise RemovalError(err)
|
|
||||||
|
|
||||||
def remove_stolen_credentials(self):
|
def remove_stolen_credentials(self):
|
||||||
try:
|
MongoCredentialsRepository._delete_collection(self._mongo.db.stolen_credentials)
|
||||||
MongoCredentialsRepository._delete_collection(self._mongo.db.stolen_credentials)
|
|
||||||
except Exception as err:
|
|
||||||
raise RemovalError(err)
|
|
||||||
|
|
||||||
def remove_all_credentials(self):
|
def remove_all_credentials(self):
|
||||||
try:
|
self.remove_configured_credentials()
|
||||||
self.remove_configured_credentials()
|
self.remove_stolen_credentials()
|
||||||
self.remove_stolen_credentials()
|
|
||||||
except RemovalError as err:
|
|
||||||
raise err
|
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _get_credentials_from_collection(collection) -> Sequence[Credentials]:
|
def _get_credentials_from_collection(collection) -> Sequence[Credentials]:
|
||||||
collection_result = []
|
try:
|
||||||
list_collection_result = list(collection.find({}))
|
collection_result = []
|
||||||
for c in list_collection_result:
|
list_collection_result = list(collection.find({}))
|
||||||
del c["_id"]
|
for c in list_collection_result:
|
||||||
collection_result.append(Credentials.from_mapping(c))
|
del c["_id"]
|
||||||
|
collection_result.append(Credentials.from_mapping(c))
|
||||||
|
|
||||||
return collection_result
|
return collection_result
|
||||||
|
except Exception as err:
|
||||||
|
raise RetrievalError(err)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _save_credentials_to_collection(credentials: Sequence[Credentials], collection):
|
def _save_credentials_to_collection(credentials: Sequence[Credentials], collection):
|
||||||
for c in credentials:
|
try:
|
||||||
collection.insert_one(Credentials.to_mapping(c))
|
for c in credentials:
|
||||||
|
collection.insert_one(Credentials.to_mapping(c))
|
||||||
|
except Exception as err:
|
||||||
|
raise StorageError(err)
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def _delete_collection(collection):
|
def _delete_collection(collection):
|
||||||
collection.delete_many({})
|
try:
|
||||||
|
collection.delete_many({})
|
||||||
|
except RemovalError as err:
|
||||||
|
raise err
|
||||||
|
|
Loading…
Reference in New Issue