Skip to content

Commit

Permalink
use metadata properties in UUID #420
Browse files Browse the repository at this point in the history
Signed-off-by: Hervé Boutemy <hboutemy@apache.org>
  • Loading branch information
hboutemy committed Dec 9, 2023
1 parent e8dd5cb commit d76e887
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 9 deletions.
1 change: 0 additions & 1 deletion src/it/makeBom/verify.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ assert bomFileXml.text.contains('<reference type="website"><url>https://github.c
assert !bomFileXml.text.contains('<property name="maven.optional.unused">')

// Reproducible Builds
assert !bomFileJson.text.contains('"serialNumber"')
assert !bomFileJson.text.contains('"timestamp"')
assert bomFileJson.text.contains('"name" : "cdx:reproducible",')
assert bomFileJson.text.contains('"value" : "enabled"')
Expand Down
17 changes: 13 additions & 4 deletions src/main/java/org/cyclonedx/maven/BaseCycloneDxMojo.java
Original file line number Diff line number Diff line change
Expand Up @@ -341,7 +341,7 @@ private void generateBom(String analysis, Metadata metadata, List<Component> com
}

if (schemaVersion().getVersion() >= 1.1 && includeBomSerialNumber) {
String serialNumber = generateSerialNumber();
String serialNumber = generateSerialNumber(metadata.getProperties());
bom.setSerialNumber(serialNumber);
}

Expand Down Expand Up @@ -371,9 +371,18 @@ private void generateBom(String analysis, Metadata metadata, List<Component> com
}
}

private String generateSerialNumber() {
String seed = String.format("%s:%s:%s", project.getGroupId(), project.getArtifactId(), project.getVersion());
UUID uuid = UUID.nameUUIDFromBytes(seed.getBytes(StandardCharsets.UTF_8));
private String generateSerialNumber(List<Property> properties) {
String gav = String.format("%s:%s:%s", project.getGroupId(), project.getArtifactId(), project.getVersion());
StringBuilder sb = new StringBuilder(gav);
if (properties != null) {
for(Property prop: properties) {
sb.append(';');
sb.append(prop.getName());
sb.append('=');
sb.append(prop.getValue());
}
}
UUID uuid = UUID.nameUUIDFromBytes(sb.toString().getBytes(StandardCharsets.UTF_8));
return String.format("urn:uuid:%s", uuid);
}

Expand Down
6 changes: 2 additions & 4 deletions src/test/java/org/cyclonedx/maven/Issue420Test.java
Original file line number Diff line number Diff line change
Expand Up @@ -22,15 +22,13 @@
@MavenVersions({"3.6.3"})
public class Issue420Test extends BaseMavenVerifier {

private static final String SERIAL_NUMBER = "urn:uuid:f1a73cb3-dab9-3592-a2a9-825cf9eab862";

public Issue420Test(MavenRuntimeBuilder runtimeBuilder) throws Exception {
super(runtimeBuilder);
}

@Test
public void testDefaults() throws Exception {
test(new String[0], SERIAL_NUMBER);
test(new String[0], "urn:uuid:af111a48-2091-3e2e-ad2e-60b1975b651d");
}

@Test
Expand All @@ -40,7 +38,7 @@ public void testDefaultsWhenSerialNumberIsDisabled() throws Exception {

@Test
public void testWhenOutputTimestampIsSet() throws Exception {
test(new String[]{"-Dproject.build.outputTimestamp=2023-11-08T00:00:00Z"}, SERIAL_NUMBER);
test(new String[]{"-Dproject.build.outputTimestamp=2023-11-08T00:00:00Z"}, "urn:uuid:3e383c4c-ef61-3eba-8214-3ecd46c4bbee");
}

@Test
Expand Down

0 comments on commit d76e887

Please sign in to comment.