Skip to content

Commit

Permalink
feat!: adapt to osv metrics
Browse files Browse the repository at this point in the history
Signed-off-by: Ruben Romero Montes <rromerom@redhat.com>
  • Loading branch information
ruromero committed Apr 12, 2024
1 parent 6d7bcfa commit eb9ecb7
Show file tree
Hide file tree
Showing 3 changed files with 183 additions and 203 deletions.
6 changes: 6 additions & 0 deletions pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@
<spdx.version>1.1.9.1</spdx.version>
<htmlunit.version>2.70.0</htmlunit.version>
<wiremock.version>3.4.2</wiremock.version>
<cvss-calculator.version>1.4.2</cvss-calculator.version>

<!-- Node and Yarn -->
<node.version>v20.9.0</node.version>
Expand Down Expand Up @@ -198,6 +199,11 @@
<artifactId>sentry</artifactId>
<version>${sentry.version}</version>
</dependency>
<dependency>
<groupId>us.springett</groupId>
<artifactId>cvss-calculator</artifactId>
<version>${cvss-calculator.version}</version>
</dependency>
<dependency>
<groupId>org.apache.camel.quarkus</groupId>
<artifactId>camel-quarkus-junit5</artifactId>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
Expand All @@ -46,6 +47,7 @@

import jakarta.enterprise.context.ApplicationScoped;
import jakarta.inject.Inject;
import us.springett.cvss.Cvss;

@ApplicationScoped
@RegisterForReflection
Expand Down Expand Up @@ -90,9 +92,9 @@ private List<Issue> toIssues(String ref, ArrayNode response) {
if (issue.getTitle() == null || issue.getTitle().isEmpty()) {
issue.title(getTextValue(data, "description"));
}
var metrics = data.get("metrics");
if (metrics != null) {
setMetrics(metrics, issue);
var severity = data.get("severity");
if (severity != null) {
setSeverity(severity, issue);
}
var affected = data.get("affected");
if (affected != null) {
Expand All @@ -105,30 +107,37 @@ private List<Issue> toIssues(String ref, ArrayNode response) {
return issues;
}

// Parse only V3.1, V3.0 and V2 CVSS vectors
private void setMetrics(JsonNode metrics, Issue issue) {
ArrayNode metricsNode = null;
if (metrics.has("cvssMetricV31")) {
metricsNode = (ArrayNode) metrics.get("cvssMetricV31");
} else if (metrics.has("cvssMetricV30")) {
metricsNode = (ArrayNode) metrics.get("cvssMetricV30");
} else if (metrics.has("cvssMetricV2")) {
metricsNode = (ArrayNode) metrics.get("cvssMetricV2");
// Prefer V3.1 and V3.0 over V2 CVSS vectors
private void setSeverity(JsonNode severity, Issue issue) {
Map<String, String> severities = new HashMap<>();

severity.forEach(
metricNode -> {
var vector = metricNode.get("score").asText();
var type = metricNode.get("type").asText();
severities.put(type, vector);
});
var cvss = severities.get("CVSS_V3");
if (cvss != null) {
setCvssData(issue, cvss);
} else {
cvss = severities.get("CVSS_V2");
if (cvss != null) {
setCvssData(issue, cvss);
}
}
if (metricsNode == null) {
}

private void setCvssData(Issue issue, String vector) {
if (issue.getCvss() != null) {
return;
}
metricsNode.forEach(
metricNode -> {
if ("Primary".equalsIgnoreCase(getTextValue(metricNode, "type"))) {
var cvssData = (JsonNode) metricNode.get("cvssData");
var score = getFloatValue(cvssData, "baseScore");
issue
.cvssScore(score)
.cvss(CvssParser.fromVectorString(getTextValue(cvssData, "vectorString")))
.severity(SeverityUtils.fromScore(score));
}
});
var cvss = Cvss.fromVector(vector);
var score = Double.valueOf(cvss.calculateScore().getBaseScore()).floatValue();
issue
.cvssScore(score)
.cvss(CvssParser.fromVectorString(vector))
.severity(SeverityUtils.fromScore(score));
}

private Remediation getRemediation(ArrayNode affected) {
Expand Down
Loading

0 comments on commit eb9ecb7

Please sign in to comment.