org.codehaus.mojo.license.AddThirdPartyMojo Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of license-maven-plugin Show documentation
Show all versions of license-maven-plugin Show documentation
Maven plugin to download and collect license files from project dependencies.
The newest version!
package org.codehaus.mojo.license;
/*
* #%L
* License Maven Plugin
* %%
* Copyright (C) 2008 - 2011 CodeLutin, Codehaus, Tony Chemit
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Lesser Public License for more details.
*
* You should have received a copy of the GNU General Lesser Public
* License along with this program. If not, see
* .
* #L%
*/
import javax.inject.Inject;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.nio.file.Files;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.SortedMap;
import java.util.SortedSet;
import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.collections.MapUtils;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.plugins.annotations.LifecyclePhase;
import org.apache.maven.plugins.annotations.Mojo;
import org.apache.maven.plugins.annotations.Parameter;
import org.apache.maven.plugins.annotations.ResolutionScope;
import org.apache.maven.project.MavenProject;
import org.apache.maven.project.ProjectBuildingException;
import org.codehaus.mojo.license.api.ArtifactFilters;
import org.codehaus.mojo.license.api.DependenciesTool;
import org.codehaus.mojo.license.api.DependenciesToolException;
import org.codehaus.mojo.license.api.MavenProjectDependenciesConfigurator;
import org.codehaus.mojo.license.api.ResolvedProjectDependencies;
import org.codehaus.mojo.license.api.ThirdPartyTool;
import org.codehaus.mojo.license.api.ThirdPartyToolException;
import org.codehaus.mojo.license.model.LicenseMap;
import org.codehaus.mojo.license.utils.MojoHelper;
import org.codehaus.mojo.license.utils.SortedProperties;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
// CHECKSTYLE_OFF: LineLength
/**
* Goal to generate the third-party license file.
*
* This file contains a list of the dependencies and their licenses. Each dependency and its
* license is displayed on a single line in the format
*
* (<license-name>) <project-name> <groupId>:<artifactId>:<version> - <project-url>
*
* The directory containing the license database file is added to the classpath as an additional resource.
*
* @author tchemit [email protected]
* @since 1.0
*/
// CHECKSTYLE_ON: LineLength
@Mojo(
name = "add-third-party",
requiresDependencyResolution = ResolutionScope.TEST,
defaultPhase = LifecyclePhase.GENERATE_RESOURCES,
threadSafe = true)
public class AddThirdPartyMojo extends AbstractAddThirdPartyMojo implements MavenProjectDependenciesConfigurator {
private static final Logger LOG = LoggerFactory.getLogger(AddThirdPartyMojo.class);
// ----------------------------------------------------------------------
// Mojo Parameters
// ----------------------------------------------------------------------
/**
* To skip execution of this mojo.
*
* @since 1.5
*/
@Parameter(property = "license.skipAddThirdParty", defaultValue = "false")
private boolean skipAddThirdParty;
/**
* Add the output directory as resource directory.
*
* If this is set to false
the generated files are no longer added automatically to the final artifact.
*
*
* @since 2.5.0
*/
@Parameter(property = "license.addOutputDirectoryAsResourceDir", defaultValue = "true")
private boolean addOutputDirectoryAsResourceDir;
// ----------------------------------------------------------------------
// Private Fields
// ----------------------------------------------------------------------
/**
* Internal flag to know if missing file must be generated.
*/
private boolean doGenerateMissing;
/**
* Copies of the project's dependency sets. AddThirdParty needs to load dependencies only for the single project it
* is run for, while AggregateAddThirdParty needs to load dependencies for the parent project, as well as all child
* projects in the reactor.
*
* In cases where one child project A in a reactor depends on another project B in the same reactor,
* B is not necessarily built/published. The plugin needs to resolve B's dependencies manually.
* This field stores the result of that manual resolution.
*/
private ResolvedProjectDependencies dependencyArtifacts;
private ArtifactFilters artifactFilters;
@Inject
public AddThirdPartyMojo(ThirdPartyTool thirdPartyTool, DependenciesTool dependenciesTool) {
super(thirdPartyTool, dependenciesTool);
}
// ----------------------------------------------------------------------
// AbstractLicenseMojo Implementaton
// ----------------------------------------------------------------------
/**
* {@inheritDoc}
*/
@Override
public boolean isSkip() {
return skipAddThirdParty;
}
/**
* {@inheritDoc}
*/
@Override
protected boolean checkPackaging() {
if (acceptPomPackaging) {
// rejects nothing
return true;
}
// can reject pom packaging
return rejectPackaging("pom");
}
/**
* {@inheritDoc}
*/
@Override
protected boolean shouldSkip() {
return !doGenerate && !doGenerateBundle && !doGenerateMissing;
}
/**
* {@inheritDoc}
*/
@Override
protected void doAction() throws Exception {
consolidate();
checkUnsafeDependencies();
boolean safeLicense = checkForbiddenLicenses();
checkBlacklist(safeLicense);
writeThirdPartyFile();
if (doGenerateMissing) {
writeMissingFile();
}
boolean unsafe = CollectionUtils.isNotEmpty(unsafeDependencies);
checkMissing(unsafe);
if (!unsafe && useMissingFile && MapUtils.isEmpty(unsafeMappings) && missingFile.exists()) {
// there is no missing dependencies, but still a missing file, delete it
LOG.info("There is no dependency to put in missing file, delete it at {}", missingFile);
Files.deleteIfExists(missingFile.toPath());
}
if (!unsafe && deployMissingFile && MapUtils.isNotEmpty(unsafeMappings)) {
// can deploy missing file
LOG.info("Will attach third party file from {}", missingFile);
getHelper().attachThirdPartyDescriptor(missingFile);
}
if (addOutputDirectoryAsResourceDir) {
addResourceDir(outputDirectory, "**/*.txt");
}
}
// ----------------------------------------------------------------------
// AbstractAddThirdPartyMojo Implementation
// ----------------------------------------------------------------------
/**
* {@inheritDoc}
*/
@Override
protected SortedMap loadDependencies() throws DependenciesToolException {
return getHelper().loadDependencies(this, resolveDependencyArtifacts());
}
/**
* Resolves the transitive and direct dependency sets for this project.
*
* @return The set of all dependencies, and the set of only direct dependency artifacts.
* @throws org.codehaus.mojo.license.api.DependenciesToolException if the dependencies could not be resolved
*/
protected ResolvedProjectDependencies resolveDependencyArtifacts() throws DependenciesToolException {
if (dependencyArtifacts != null) {
return dependencyArtifacts;
}
dependencyArtifacts =
new ResolvedProjectDependencies(project.getArtifacts(), MojoHelper.getDependencyArtifacts(project));
return dependencyArtifacts;
}
/**
* {@inheritDoc}
*/
@Override
protected SortedProperties createUnsafeMapping()
throws ProjectBuildingException, IOException, ThirdPartyToolException, MojoExecutionException,
DependenciesToolException {
SortedProperties unsafeMappings = getHelper()
.createUnsafeMapping(
licenseMap,
missingFile,
missingFileUrl,
useRepositoryMissingFiles,
unsafeDependencies,
projectDependencies,
resolveDependencyArtifacts().getAllDependencies());
if (isVerbose()) {
LOG.info("found {} unsafe mappings", unsafeMappings.size());
}
// compute if missing file should be (re)-generate
doGenerateMissing = computeDoGenerateMissingFile(unsafeMappings, unsafeDependencies);
if (doGenerateMissing && isVerbose()) {
StringBuilder sb = new StringBuilder();
sb.append("Will use ");
sb.append(unsafeMappings.size());
sb.append(" dependencies from missingFile:");
for (Map.Entry
© 2015 - 2025 Weber Informatics LLC | Privacy Policy