From 59159ce891aa7dc1e85e2a20cc0da246d151f3dc Mon Sep 17 00:00:00 2001 From: thc202 Date: Thu, 12 Oct 2023 14:59:10 +0100 Subject: [PATCH] Handle missing license in SBOMs Handle missing licenses and different type of license metadata. Signed-off-by: thc202 --- .../website/WebsiteSbomPageGenerator.java | 43 ++++++++++++++----- 1 file changed, 32 insertions(+), 11 deletions(-) diff --git a/buildSrc/src/main/java/org/zaproxy/gradle/website/WebsiteSbomPageGenerator.java b/buildSrc/src/main/java/org/zaproxy/gradle/website/WebsiteSbomPageGenerator.java index c12ac741..7f5dd94a 100644 --- a/buildSrc/src/main/java/org/zaproxy/gradle/website/WebsiteSbomPageGenerator.java +++ b/buildSrc/src/main/java/org/zaproxy/gradle/website/WebsiteSbomPageGenerator.java @@ -55,21 +55,11 @@ public static void generate( .sorted(Comparator.comparing(jsonNode -> jsonNode.get("name").asText())) .collect(Collectors.toList()); for (JsonNode component : sortedComponentsList) { - var licenses = (ArrayNode) component.get("licenses"); - String licensesStr = - StreamSupport.stream(licenses.spliterator(), false) - .map(l -> l.get("license")) - .map( - l -> - l.has("id") - ? l.get("id").asText() - : l.has("name") ? l.get("name").asText() : "") - .collect(Collectors.joining(", ")); resultComponents.add( new PageFrontMatter.SbomDataComponent( component.get("name").asText(), component.get("version").asText(), - licensesStr)); + createLicensesString(component))); } frontMatter.setSbomData( new PageFrontMatter.SbomData( @@ -79,4 +69,35 @@ public static void generate( frontMatter.writeTo(NOTICE, writer); Files.write(outputFile, writer.toString().getBytes(StandardCharsets.UTF_8)); } + + private static String createLicensesString(JsonNode component) { + var licenses = (ArrayNode) component.get("licenses"); + if (licenses == null) { + return ""; + } + + return StreamSupport.stream(licenses.spliterator(), false) + .map(WebsiteSbomPageGenerator::licenseObjectToString) + .filter(e -> e != null) + .collect(Collectors.joining(", ")); + } + + private static String licenseObjectToString(JsonNode l) { + if (!l.has("license")) { + return get(l, "expression"); + } + var license = l.get("license"); + var id = get(license, "id"); + if (id != null) { + return id; + } + return get(license, "name"); + } + + private static String get(JsonNode node, String property) { + if (node.has(property)) { + return node.get(property).asText(); + } + return null; + } }