forked from p15670423/monkey
Island: Remove ScoutSuiteFinding
This commit is contained in:
parent
039a62a224
commit
b23360db37
|
@ -1,20 +0,0 @@
|
|||
from __future__ import annotations
|
||||
|
||||
from mongoengine import LazyReferenceField
|
||||
|
||||
from monkey_island.cc.models.zero_trust.finding import Finding
|
||||
from monkey_island.cc.models.zero_trust.scoutsuite_finding_details import ScoutSuiteFindingDetails
|
||||
|
||||
|
||||
class ScoutSuiteFinding(Finding):
|
||||
# We put additional info into a lazy reference field, because this info should be only
|
||||
# pulled when explicitly needed due to performance
|
||||
details = LazyReferenceField(ScoutSuiteFindingDetails, required=True)
|
||||
|
||||
@staticmethod
|
||||
def save_finding(
|
||||
test: str, status: str, detail_ref: ScoutSuiteFindingDetails
|
||||
) -> ScoutSuiteFinding:
|
||||
finding = ScoutSuiteFinding(test=test, status=status, details=detail_ref)
|
||||
finding.save()
|
||||
return finding
|
|
@ -1,13 +0,0 @@
|
|||
from mongoengine import Document, EmbeddedDocumentListField
|
||||
|
||||
from monkey_island.cc.models.zero_trust.scoutsuite_rule import ScoutSuiteRule
|
||||
|
||||
|
||||
class ScoutSuiteFindingDetails(Document):
|
||||
# SCHEMA
|
||||
scoutsuite_rules = EmbeddedDocumentListField(document_type=ScoutSuiteRule, required=False)
|
||||
|
||||
def add_rule(self, rule: ScoutSuiteRule) -> None:
|
||||
if rule not in self.scoutsuite_rules:
|
||||
self.scoutsuite_rules.append(rule)
|
||||
self.save()
|
|
@ -1,25 +0,0 @@
|
|||
from mongoengine import DynamicField, EmbeddedDocument, IntField, ListField, StringField
|
||||
|
||||
from monkey_island.cc.services.zero_trust.scoutsuite.consts import rule_consts
|
||||
|
||||
|
||||
class ScoutSuiteRule(EmbeddedDocument):
|
||||
"""
|
||||
This model represents ScoutSuite security rule check results:
|
||||
how many resources break the security rule
|
||||
security rule description and remediation and etc.
|
||||
"""
|
||||
|
||||
# SCHEMA
|
||||
description = StringField(required=True)
|
||||
path = StringField(required=True)
|
||||
level = StringField(required=True, options=rule_consts.RULE_LEVELS)
|
||||
items = ListField()
|
||||
dashboard_name = StringField(required=True)
|
||||
checked_items = IntField(min_value=0)
|
||||
flagged_items = IntField(min_value=0)
|
||||
service = StringField(required=True)
|
||||
rationale = StringField(required=True)
|
||||
remediation = StringField(required=False)
|
||||
compliance = DynamicField(required=False)
|
||||
references = ListField(required=False)
|
|
@ -1,4 +0,0 @@
|
|||
RULE_LEVEL_DANGER = "danger"
|
||||
RULE_LEVEL_WARNING = "warning"
|
||||
|
||||
RULE_LEVELS = (RULE_LEVEL_DANGER, RULE_LEVEL_WARNING)
|
|
@ -7,7 +7,6 @@ from common.common_consts import zero_trust_consts
|
|||
from common.utils.exceptions import UnknownFindingError
|
||||
from monkey_island.cc.models.zero_trust.finding import Finding
|
||||
from monkey_island.cc.models.zero_trust.monkey_finding import MonkeyFinding
|
||||
from monkey_island.cc.models.zero_trust.scoutsuite_finding import ScoutSuiteFinding
|
||||
from monkey_island.cc.services.zero_trust.monkey_findings.monkey_zt_details_service import (
|
||||
MonkeyZTDetailsService,
|
||||
)
|
||||
|
@ -55,7 +54,5 @@ class FindingService:
|
|||
def _get_finding_details(finding: Finding) -> Union[dict, SON]:
|
||||
if type(finding) == MonkeyFinding:
|
||||
return MonkeyZTDetailsService.fetch_details_for_display(finding.details.id)
|
||||
elif type(finding) == ScoutSuiteFinding:
|
||||
return finding.details.fetch().to_mongo()
|
||||
else:
|
||||
raise UnknownFindingError(f"Unknown finding type {str(type(finding))}")
|
||||
|
|
Loading…
Reference in New Issue