forked from p15670423/monkey
Merge pull request #1306 from guardicore/ransomware-exploitation-details-report-service
Ransomware exploitation details report service
This commit is contained in:
commit
a794a5777a
|
@ -2,9 +2,12 @@ import flask_restful
|
||||||
from flask import jsonify
|
from flask import jsonify
|
||||||
|
|
||||||
from monkey_island.cc.resources.auth.auth import jwt_required
|
from monkey_island.cc.resources.auth.auth import jwt_required
|
||||||
|
from monkey_island.cc.services.ransomware import ransomware_report
|
||||||
|
|
||||||
|
|
||||||
class RansomwareReport(flask_restful.Resource):
|
class RansomwareReport(flask_restful.Resource):
|
||||||
@jwt_required
|
@jwt_required
|
||||||
def get(self):
|
def get(self):
|
||||||
return jsonify({"report": None})
|
return jsonify(
|
||||||
|
{"report": None, "propagation_stats": ransomware_report.get_propagation_stats()}
|
||||||
|
)
|
||||||
|
|
|
@ -0,0 +1,24 @@
|
||||||
|
from typing import Dict, List
|
||||||
|
|
||||||
|
from monkey_island.cc.services.reporting.report import ReportService
|
||||||
|
|
||||||
|
|
||||||
|
def get_propagation_stats() -> Dict:
|
||||||
|
scanned = ReportService.get_scanned()
|
||||||
|
exploited = ReportService.get_exploited()
|
||||||
|
|
||||||
|
return {
|
||||||
|
"num_scanned_nodes": len(scanned),
|
||||||
|
"num_exploited_nodes": len(exploited),
|
||||||
|
"num_exploited_per_exploit": _get_exploit_counts(exploited),
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
def _get_exploit_counts(exploited: List[Dict]) -> Dict:
|
||||||
|
exploit_counts = {}
|
||||||
|
|
||||||
|
for node in exploited:
|
||||||
|
for exploit in node["exploits"]:
|
||||||
|
exploit_counts[exploit] = exploit_counts.get(exploit, 0) + 1
|
||||||
|
|
||||||
|
return exploit_counts
|
|
@ -0,0 +1,37 @@
|
||||||
|
import pytest
|
||||||
|
|
||||||
|
from monkey_island.cc.services.ransomware import ransomware_report
|
||||||
|
from monkey_island.cc.services.reporting.report import ReportService
|
||||||
|
|
||||||
|
|
||||||
|
@pytest.fixture
|
||||||
|
def patch_report_service_for_stats(monkeypatch):
|
||||||
|
TEST_SCANNED_RESULTS = [{}, {}, {}, {}]
|
||||||
|
TEST_EXPLOITED_RESULTS = [
|
||||||
|
{"exploits": ["SSH Exploiter"]},
|
||||||
|
{"exploits": ["SSH Exploiter", "SMB Exploiter"]},
|
||||||
|
{"exploits": ["WMI Exploiter"]},
|
||||||
|
]
|
||||||
|
|
||||||
|
monkeypatch.setattr(ReportService, "get_scanned", lambda: TEST_SCANNED_RESULTS)
|
||||||
|
monkeypatch.setattr(ReportService, "get_exploited", lambda: TEST_EXPLOITED_RESULTS)
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_propagation_stats__num_scanned(patch_report_service_for_stats):
|
||||||
|
stats = ransomware_report.get_propagation_stats()
|
||||||
|
|
||||||
|
assert stats["num_scanned_nodes"] == 4
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_propagation_stats__num_exploited(patch_report_service_for_stats):
|
||||||
|
stats = ransomware_report.get_propagation_stats()
|
||||||
|
|
||||||
|
assert stats["num_exploited_nodes"] == 3
|
||||||
|
|
||||||
|
|
||||||
|
def test_get_propagation_stats__num_exploited_per_exploit(patch_report_service_for_stats):
|
||||||
|
stats = ransomware_report.get_propagation_stats()
|
||||||
|
|
||||||
|
assert stats["num_exploited_per_exploit"]["SSH Exploiter"] == 2
|
||||||
|
assert stats["num_exploited_per_exploit"]["SMB Exploiter"] == 1
|
||||||
|
assert stats["num_exploited_per_exploit"]["WMI Exploiter"] == 1
|
Loading…
Reference in New Issue