Build: Allow license header check to be customized

This change allows setting which license families are approved, as well
as adding matchers for additional license types.
This commit is contained in:
Ryan Ernst 2016-07-25 17:05:40 -07:00
parent cd596772ee
commit 0ecaa6ec3c
1 changed files with 60 additions and 31 deletions

View File

@ -23,6 +23,7 @@ import org.apache.rat.anttasks.SubstringLicenseMatcher
import org.apache.rat.license.SimpleLicenseFamily import org.apache.rat.license.SimpleLicenseFamily
import org.elasticsearch.gradle.AntTask import org.elasticsearch.gradle.AntTask
import org.gradle.api.file.FileCollection import org.gradle.api.file.FileCollection
import org.gradle.api.tasks.Input
import org.gradle.api.tasks.OutputFile import org.gradle.api.tasks.OutputFile
import org.gradle.api.tasks.SourceSet import org.gradle.api.tasks.SourceSet
@ -44,6 +45,16 @@ public class LicenseHeadersTask extends AntTask {
*/ */
protected List<FileCollection> javaFiles protected List<FileCollection> javaFiles
/** Allowed license families for this project. */
@Input
List<String> approvedLicenses = ['Apache', 'Generated']
/**
* Additional license families that may be found. The key is the license category name (5 characters),
* followed by the family name and the value list of patterns to search for.
*/
protected Map<String, String> additionalLicenses = [:]
LicenseHeadersTask() { LicenseHeadersTask() {
description = "Checks sources for missing, incorrect, or unacceptable license headers" description = "Checks sources for missing, incorrect, or unacceptable license headers"
// Delay resolving the dependencies until after evaluation so we pick up generated sources // Delay resolving the dependencies until after evaluation so we pick up generated sources
@ -53,6 +64,13 @@ public class LicenseHeadersTask extends AntTask {
} }
} }
public void additionalLicense(String categoryName, String familyName, String pattern) {
if (categoryName.length() != 5) {
throw new IllegalArgumentException("License category name must be exactly 5 characters, got ${categoryName}");
}
additionalLicenses.put("${categoryName}${familyName}", pattern);
}
@Override @Override
protected void runAnt(AntBuilder ant) { protected void runAnt(AntBuilder ant) {
ant.project.addTaskDefinition('ratReport', Report) ant.project.addTaskDefinition('ratReport', Report)
@ -64,43 +82,54 @@ public class LicenseHeadersTask extends AntTask {
// run rat, going to the file // run rat, going to the file
List<FileCollection> input = javaFiles List<FileCollection> input = javaFiles
ant.ratReport(reportFile: reportFile.absolutePath, addDefaultLicenseMatchers: true) { ant.ratReport(reportFile: reportFile.absolutePath, addDefaultLicenseMatchers: true) {
for (FileCollection dirSet : input) { for (FileCollection dirSet : input) {
for (File dir: dirSet.srcDirs) { for (File dir: dirSet.srcDirs) {
// sometimes these dirs don't exist, e.g. site-plugin has no actual java src/main... // sometimes these dirs don't exist, e.g. site-plugin has no actual java src/main...
if (dir.exists()) { if (dir.exists()) {
ant.fileset(dir: dir) ant.fileset(dir: dir)
}
} }
} }
}
// BSD 4-clause stuff (is disallowed below) // BSD 4-clause stuff (is disallowed below)
// we keep this here, in case someone adds BSD code for some reason, it should never be allowed. // we keep this here, in case someone adds BSD code for some reason, it should never be allowed.
substringMatcher(licenseFamilyCategory: "BSD4 ", substringMatcher(licenseFamilyCategory: "BSD4 ",
licenseFamilyName: "Original BSD License (with advertising clause)") { licenseFamilyName: "Original BSD License (with advertising clause)") {
pattern(substring: "All advertising materials") pattern(substring: "All advertising materials")
} }
// Apache // Apache
substringMatcher(licenseFamilyCategory: "AL ", substringMatcher(licenseFamilyCategory: "AL ",
licenseFamilyName: "Apache") { licenseFamilyName: "Apache") {
// Apache license (ES) // Apache license (ES)
pattern(substring: "Licensed to Elasticsearch under one or more contributor") pattern(substring: "Licensed to Elasticsearch under one or more contributor")
// Apache license (ASF) // Apache license (ASF)
pattern(substring: "Licensed to the Apache Software Foundation (ASF) under") pattern(substring: "Licensed to the Apache Software Foundation (ASF) under")
// this is the old-school one under some files // this is the old-school one under some files
pattern(substring: "Licensed under the Apache License, Version 2.0 (the \"License\")") pattern(substring: "Licensed under the Apache License, Version 2.0 (the \"License\")")
} }
// Generated resources // Generated resources
substringMatcher(licenseFamilyCategory: "GEN ", substringMatcher(licenseFamilyCategory: "GEN ",
licenseFamilyName: "Generated") { licenseFamilyName: "Generated") {
// parsers generated by antlr // parsers generated by antlr
pattern(substring: "ANTLR GENERATED CODE") pattern(substring: "ANTLR GENERATED CODE")
} }
// approved categories // license types added by the project
approvedLicense(familyName: "Apache") for (Map.Entry<String, String[]> additional : additionalLicenses.entrySet()) {
approvedLicense(familyName: "Generated") String category = additional.getKey().substring(0, 5)
String family = additional.getKey().substring(5)
substringMatcher(licenseFamilyCategory: category,
licenseFamilyName: family) {
pattern(substring: additional.getValue())
}
}
// approved categories
for (String licenseFamily : approvedLicenses) {
approvedLicense(familyName: licenseFamily)
}
} }
// check the license file for any errors, this should be fast. // check the license file for any errors, this should be fast.