Pil0tXia commented on code in PR #4831: URL: https://github.com/apache/eventmesh/pull/4831#discussion_r1568463511
########## build.gradle: ########## @@ -212,6 +212,107 @@ task printProjects() { }) } +cyclonedxBom { + includeConfigs = ["runtimeClasspath"] +} + +// TODO depend 'dist' on 'generateDistLicense' +tasks.register('generateDistLicense') { + dependsOn('cyclonedxBom') // Task from 'org.cyclonedx.bom' plugin + doLast { + // Inputs + def bomFile = file('build/reports/bom.json') + def bom = new JsonSlurper().parseText(bomFile.text) + def projectLicenseText = file('LICENSE').text + + // Outputs + def distLicenseFile = file('tools/dist-license/LICENSE') + def licensesDir = file('tools/dist-license/licenses/java/') + if (licensesDir.exists()) { + licensesDir.eachFile { it.delete() } + } else { + licensesDir.mkdirs() + } + + List<Map<String, String>> thirdPartyArtifacts = new ArrayList<Map<String, String>>() + // Parse BOM + bom.components.each { component -> + // Exclude project modules + if (!component.group.startsWith('org.apache.eventmesh')) { + component.licenses.each { artifactLicense -> + if (artifactLicense.license != null) { + Map<String, String> artifact = new HashMap<String, String>() + artifact.put("name", component.name) + artifact.put("version", component.version) + if (artifactLicense.license.id != null) { + artifact.put("license", artifactLicense.license.id) + if (artifactLicense.license.text != null) { + artifact.put("licenseContent", new String(artifactLicense.license.text.content.decodeBase64())) + } + } else { + artifact.put("license", artifactLicense.license.name) + artifact.put("licenseContent", artifactLicense.license.url) + } + thirdPartyArtifacts.add(artifact) + } + } + } + } + thirdPartyArtifacts.sort { a, b -> + def nameComparison = a.name <=> b.name + if (nameComparison == 0) { + return a.version <=> b.version + } else { + return nameComparison + } + } + + def distLicenseText = projectLicenseText + "\n=======================================================================\n" + + "This distribution contains the following third-party:\n\n" + thirdPartyArtifacts.each { artifact -> + // Write licenses + def artifactLicenseFilename = artifact.license.replaceAll("/", "-") + ".txt" + def artifactLicenseFile = new File(licensesDir, artifactLicenseFilename) + if (artifact.licenseContent != null) { + artifactLicenseFile.text = artifact.licenseContent + } else { + artifactLicenseFile.text = "No license content provided by the artifact." Review Comment: Updated in https://github.com/apache/eventmesh/pull/4831/commits/c644e65b2ced0c6834a4887c5a0afbf6c9bc43ea ########## build.gradle: ########## @@ -212,6 +212,107 @@ task printProjects() { }) } +cyclonedxBom { + includeConfigs = ["runtimeClasspath"] +} + +// TODO depend 'dist' on 'generateDistLicense' +tasks.register('generateDistLicense') { + dependsOn('cyclonedxBom') // Task from 'org.cyclonedx.bom' plugin + doLast { + // Inputs + def bomFile = file('build/reports/bom.json') + def bom = new JsonSlurper().parseText(bomFile.text) + def projectLicenseText = file('LICENSE').text + + // Outputs + def distLicenseFile = file('tools/dist-license/LICENSE') + def licensesDir = file('tools/dist-license/licenses/java/') + if (licensesDir.exists()) { + licensesDir.eachFile { it.delete() } + } else { + licensesDir.mkdirs() + } + + List<Map<String, String>> thirdPartyArtifacts = new ArrayList<Map<String, String>>() + // Parse BOM + bom.components.each { component -> + // Exclude project modules + if (!component.group.startsWith('org.apache.eventmesh')) { + component.licenses.each { artifactLicense -> + if (artifactLicense.license != null) { + Map<String, String> artifact = new HashMap<String, String>() + artifact.put("name", component.name) + artifact.put("version", component.version) + if (artifactLicense.license.id != null) { + artifact.put("license", artifactLicense.license.id) + if (artifactLicense.license.text != null) { + artifact.put("licenseContent", new String(artifactLicense.license.text.content.decodeBase64())) + } + } else { + artifact.put("license", artifactLicense.license.name) + artifact.put("licenseContent", artifactLicense.license.url) + } + thirdPartyArtifacts.add(artifact) + } + } + } + } + thirdPartyArtifacts.sort { a, b -> + def nameComparison = a.name <=> b.name + if (nameComparison == 0) { + return a.version <=> b.version + } else { + return nameComparison + } + } + + def distLicenseText = projectLicenseText + "\n=======================================================================\n" + + "This distribution contains the following third-party:\n\n" Review Comment: Fixed in https://github.com/apache/eventmesh/pull/4831/commits/c644e65b2ced0c6834a4887c5a0afbf6c9bc43ea -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: issues-unsubscr...@eventmesh.apache.org For queries about this service, please contact Infrastructure at: us...@infra.apache.org --------------------------------------------------------------------- To unsubscribe, e-mail: issues-unsubscr...@eventmesh.apache.org For additional commands, e-mail: issues-h...@eventmesh.apache.org