From 09252f33ae6343499450234ba4103da9cee80c0c Mon Sep 17 00:00:00 2001 From: github-actions Date: Fri, 4 Oct 2024 12:01:52 -0400 Subject: [PATCH 1/3] fix duplicate uuid for scan events --- bbot/core/helpers/names_generator.py | 2 ++ bbot/scanner/scanner.py | 17 +++++++++++++---- 2 files changed, 15 insertions(+), 4 deletions(-) diff --git a/bbot/core/helpers/names_generator.py b/bbot/core/helpers/names_generator.py index 95130de90e..eec538bb35 100644 --- a/bbot/core/helpers/names_generator.py +++ b/bbot/core/helpers/names_generator.py @@ -212,6 +212,7 @@ "sneaky", "soft", "sophisticated", + "spicy", "spiteful", "squishy", "steamy", @@ -450,6 +451,7 @@ "hermione", "homer", "howard", + "hunter", "irene", "isaac", "isabella", diff --git a/bbot/scanner/scanner.py b/bbot/scanner/scanner.py index 19ea7106ae..a9df6fbc3e 100644 --- a/bbot/scanner/scanner.py +++ b/bbot/scanner/scanner.py @@ -116,6 +116,7 @@ def __init__( **kwargs (list[str], optional): Additional keyword arguments (passed through to `Preset`). """ self._root_event = None + self._finish_event = None self.start_time = None self.end_time = None self.duration = None @@ -377,8 +378,8 @@ async def async_start(self): new_activity = await self.finish() if not new_activity: self._success = True - await self._mark_finished() - yield self.root_event + scan_finish_event = await self._mark_finished() + yield scan_finish_event break await asyncio.sleep(0.1) @@ -434,8 +435,7 @@ async def _mark_finished(self): status_message = f"Scan {self.name} completed in {self.duration_human} with status {status}" - scan_finish_event = self.make_root_event(status_message) - scan_finish_event.data["status"] = status + scan_finish_event = self.finish_event(status_message, status) # queue final scan event with output modules output_modules = [m for m in self.modules.values() if m._type == "output" and m.name != "python"] @@ -451,6 +451,7 @@ async def _mark_finished(self): self.status = status log_fn(status_message) + return scan_finish_event def _start_modules(self): self.verbose(f"Starting module worker loops") @@ -990,6 +991,14 @@ def root_event(self): self._root_event.data["status"] = self.status return self._root_event + def finish_event(self, context=None, status=None): + if self._finish_event is None: + if context is None or status is None: + raise ValueError("Must specify context and status") + self._finish_event = self.make_root_event(context) + self._finish_event.status = status + return self._finish_event + def make_root_event(self, context): root_event = self.make_event(data=self.json, event_type="SCAN", dummy=True, context=context) root_event._id = self.id From 5b17891f35c35bed3ecf1e36315c167d4e290889 Mon Sep 17 00:00:00 2001 From: github-actions Date: Fri, 4 Oct 2024 12:53:23 -0400 Subject: [PATCH 2/3] added tests --- bbot/test/test_step_1/test_scan.py | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/bbot/test/test_step_1/test_scan.py b/bbot/test/test_step_1/test_scan.py index bbff8a60b1..d0223acabb 100644 --- a/bbot/test/test_step_1/test_scan.py +++ b/bbot/test/test_step_1/test_scan.py @@ -118,3 +118,26 @@ async def test_speed_counter(): await asyncio.sleep(0.2) # only 5 should show assert 4 <= counter.speed <= 5 + + +@pytest.mark.asyncio +async def test_python_output_matches_json(bbot_scanner): + import json + + scan = bbot_scanner( + "blacklanternsecurity.com", + config={"speculate": True, "dns": {"minimal": False}, "scope": {"report_distance": 10}}, + ) + await scan.helpers.dns._mock_dns({"blacklanternsecurity.com": {"A": ["127.0.0.1"]}}) + events = [e.json() async for e in scan.async_start()] + output_json = scan.home / "output.json" + json_events = [] + for line in open(output_json): + json_events.append(json.loads(line)) + + assert len(events) == 5 + assert len([e for e in events if e["type"] == "SCAN"]) == 2 + assert len([e for e in events if e["type"] == "DNS_NAME"]) == 1 + assert len([e for e in events if e["type"] == "ORG_STUB"]) == 1 + assert len([e for e in events if e["type"] == "IP_ADDRESS"]) == 1 + assert events == json_events From 80b466aaa9ff70ca8784861fd21ebd6c803f4f6e Mon Sep 17 00:00:00 2001 From: github-actions Date: Fri, 4 Oct 2024 13:09:12 -0400 Subject: [PATCH 3/3] ensure status --- bbot/scanner/scanner.py | 2 +- bbot/test/test_step_1/test_scan.py | 4 +++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/bbot/scanner/scanner.py b/bbot/scanner/scanner.py index a9df6fbc3e..85b9a00732 100644 --- a/bbot/scanner/scanner.py +++ b/bbot/scanner/scanner.py @@ -996,7 +996,7 @@ def finish_event(self, context=None, status=None): if context is None or status is None: raise ValueError("Must specify context and status") self._finish_event = self.make_root_event(context) - self._finish_event.status = status + self._finish_event.data["status"] = status return self._finish_event def make_root_event(self, context): diff --git a/bbot/test/test_step_1/test_scan.py b/bbot/test/test_step_1/test_scan.py index d0223acabb..3f80807afa 100644 --- a/bbot/test/test_step_1/test_scan.py +++ b/bbot/test/test_step_1/test_scan.py @@ -136,7 +136,9 @@ async def test_python_output_matches_json(bbot_scanner): json_events.append(json.loads(line)) assert len(events) == 5 - assert len([e for e in events if e["type"] == "SCAN"]) == 2 + scan_events = [e for e in events if e["type"] == "SCAN"] + assert len(scan_events) == 2 + assert all([isinstance(e["data"]["status"], str) for e in scan_events]) assert len([e for e in events if e["type"] == "DNS_NAME"]) == 1 assert len([e for e in events if e["type"] == "ORG_STUB"]) == 1 assert len([e for e in events if e["type"] == "IP_ADDRESS"]) == 1