From 7a40b5155475b029303e8da34c744fa9dffd69c3 Mon Sep 17 00:00:00 2001 From: Daniel D'Avella Date: Tue, 17 Dec 2024 14:38:01 -0500 Subject: [PATCH] Use proper finding IDs for sonar and semgrep SARIF --- src/codemodder/semgrep.py | 14 ++++++-------- src/core_codemods/sonar/results.py | 2 +- 2 files changed, 7 insertions(+), 9 deletions(-) diff --git a/src/codemodder/semgrep.py b/src/codemodder/semgrep.py index 7c6e7a32..2dc6f3eb 100644 --- a/src/codemodder/semgrep.py +++ b/src/codemodder/semgrep.py @@ -54,20 +54,18 @@ def from_sarif( # avoid circular import from core_codemods.semgrep.api import semgrep_url_from_id + rule_id = cls.extract_rule_id(sarif_result, sarif_run, truncate_rule_id) + finding_id = cls.extract_finding_id(sarif_result) or rule_id return cls( - rule_id=( - rule_id := cls.extract_rule_id( - sarif_result, sarif_run, truncate_rule_id - ) - ), + rule_id=rule_id, locations=cls.extract_locations(sarif_result), codeflows=cls.extract_code_flows(sarif_result), related_locations=cls.extract_related_locations(sarif_result), - finding_id=rule_id, + finding_id=finding_id, finding=Finding( - id=rule_id, + id=cls.extract_finding_id(sarif_result) or rule_id, rule=Rule( - id=rule_id, + id=finding_id, name=rule_id, url=semgrep_url_from_id(rule_id), ), diff --git a/src/core_codemods/sonar/results.py b/src/core_codemods/sonar/results.py index 316ce944..79026a52 100644 --- a/src/core_codemods/sonar/results.py +++ b/src/core_codemods/sonar/results.py @@ -69,7 +69,7 @@ def from_result(cls, result: dict) -> Self: locations=locations, codeflows=all_flows, finding=Finding( - id=rule_id, + id=finding_id, rule=Rule( id=rule_id, name=name,