All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.codehaus.mojo.license.api.ThirdPartyTool Maven / Gradle / Ivy

package org.codehaus.mojo.license.api;

/*
 * #%L
 * License Maven Plugin
 * %%
 * Copyright (C) 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 org.apache.maven.artifact.Artifact;
import org.apache.maven.artifact.repository.ArtifactRepository;
import org.apache.maven.artifact.resolver.ArtifactNotFoundException;
import org.apache.maven.artifact.resolver.ArtifactResolutionException;
import org.apache.maven.model.License;
import org.apache.maven.plugin.MojoExecutionException;
import org.apache.maven.project.MavenProject;
import org.codehaus.mojo.license.model.LicenseMap;
import org.codehaus.mojo.license.utils.SortedProperties;

import java.io.File;
import java.io.IOException;
import java.util.Collection;
import java.util.List;
import java.util.Set;
import java.util.SortedMap;
import java.util.SortedSet;

/**
 * A tool to load third party files missing files.
 * 

* We should put here all the logic code written in some mojo and licenseMap... * * @author tchemit [email protected] * @since 1.0 */ public interface ThirdPartyTool { /** * Plexus Role. */ String ROLE = ThirdPartyTool.class.getName(); /** * Is log should be verbose? * * @return {@code true} if verbose log should be produced, {@code false} otherwise. * @since 1.4 */ boolean isVerbose(); /** * Sets the verbose mode. * * @param verbose new verbose mode to set * @since 1.4 */ void setVerbose( boolean verbose ); /** * Collect license information from property file, 'third-party' classified artifacts, and .license.properties dependencies. * * @param dependencies top-level dependencies to scan for .license.properties files. * @param encoding encoding used to read or write properties files * @param projects all projects where to read third parties descriptors * @param unsafeProjects all unsafe projects * @param licenseMap license map where to store new licenses * @param localRepository local repository * @param remoteRepositories remote repositories * @return the map of loaded missing from the remote missing third party files * @throws ThirdPartyToolException if any * @throws IOException if any */ SortedProperties loadThirdPartyDescriptorsForUnsafeMapping( Set dependencies, String encoding, Collection projects, SortedSet unsafeProjects, LicenseMap licenseMap, ArtifactRepository localRepository, List remoteRepositories ) throws ThirdPartyToolException, IOException; /** * For the given {@code project}, attach the given {@code file} as a third-party file. *

* The file will be attached as with a classifier {@code third-parties} and a type {@code properties}. * * @param project the project on which to attch the third-party file * @param file the third-party file to attach. */ void attachThirdPartyDescriptor( MavenProject project, File file ); /** * Obtain the third party file from the repository. *

* Will first search in the local repository, then into the remote repositories and will resolv it. * * @param project the project * @param localRepository the local repository * @param repositories the remote repositories * @return the locale file resolved into the local repository * @throws ThirdPartyToolException if any */ File resolvThirdPartyDescriptor( MavenProject project, ArtifactRepository localRepository, List repositories ) throws ThirdPartyToolException; File resolveMissingLicensesDescriptor( String groupId, String artifactId, String version, ArtifactRepository localRepository, List repositories ) throws IOException, ArtifactResolutionException, ArtifactNotFoundException; /** * From the given {@code licenseMap}, obtain all the projects with no license. * * @param licenseMap the license map to query * @param doLog a flag to add debug logs * @return the set of projects with no license */ SortedSet getProjectsWithNoLicense( LicenseMap licenseMap, boolean doLog ); /** * Loads unsafe mapping and returns it. * * @param licenseMap license map * @param artifactCache cache of dependencies (used for id migration from missing file) * @param encoding encoding used to load missing file * @param missingFile location of the optional missing file * @param missingFileUrl location of an optional missing file extension that can be downloaded from some * resource hoster and that will be merged with the content of the missing file. * @return the unsafe mapping * @throws IOException if pb while reading missing file */ SortedProperties loadUnsafeMapping( LicenseMap licenseMap, SortedMap artifactCache, String encoding, File missingFile, String missingFileUrl ) throws IOException, MojoExecutionException; /** * Override licenses from override file. * * @param licenseMap license map * @param artifactCache cache of dependencies (used for id migration from missing file) * @param encoding encoding used to load override file * @param overrideFile location of the optional override file * @throws IOException if pb while reading override file */ void overrideLicenses( LicenseMap licenseMap, SortedMap artifactCache, String encoding, File overrideFile ) throws IOException; /** * Add one or more licenses (name and url are {@code licenseNames}) to the given {@code licenseMap} for the given * {@code project}. * * @param licenseMap the license map where to add the license * @param project the project * @param licenseNames the names of the licenses */ void addLicense( LicenseMap licenseMap, MavenProject project, String... licenseNames ); /** * Add a given {@code license} to the given {@code licenseMap} for the given {@code project}. * * @param licenseMap the license map where to add the license * @param project the project * @param license the license to add */ void addLicense( LicenseMap licenseMap, MavenProject project, License license ); /** * Add a given {@code licenses} to the given {@code licenseMap} for the given {@code project}. * * @param licenseMap the license map where to add the licenses * @param project the project * @param licenses the licenses to add */ void addLicense( LicenseMap licenseMap, MavenProject project, List licenses ); /** * For a given {@code licenseMap}, merge all {@code licenses}. *

* The first value of the {@code licenses} is the license to keep and all other values will be merged into the * first one. * * @param licenseMap the license map to merge * @param mainLicense the main license to keep * @param licensesToMerge all the licenses to merge */ void mergeLicenses( LicenseMap licenseMap, String mainLicense, Set licensesToMerge ); /** * Write the content of the third-party file. * * @param licenseMap map of all license to use * @param thirdPartyFile location of file to generate * @param verbose verbose flag * @param encoding encoding used to generate file * @param template the location of the freemarker template used to generate the file content * @throws IOException if any probem while writing file */ void writeThirdPartyFile( LicenseMap licenseMap, File thirdPartyFile, boolean verbose, String encoding, String template ) throws IOException; /** * Writes the bundled version of the third-party file. * * @param thirdPartyFile location of normal third-party file * @param outputDirectory where to generate bundled version of the third-party file * @param bundleThirdPartyPath relative end path of the file to generate * @throws IOException if any problem while writing file */ void writeBundleThirdPartyFile( File thirdPartyFile, File outputDirectory, String bundleThirdPartyPath ) throws IOException; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy