org.codehaus.mojo.license.LicenseMojoUtils 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) 2018 Codehaus
* %%
* 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 java.io.File;
import java.nio.file.Files;
import java.nio.file.Path;
import org.codehaus.mojo.license.utils.UrlRequester;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* Utility methods common to various mojos.
*
* @since 1.17
*/
public final class LicenseMojoUtils {
private static final LoggerFacade LOG = new Slf4jLoggerFacade(LoggerFactory.getLogger(LicenseMojoUtils.class));
/** A special singleton to pass the information that the URL was not set. */
static final String NO_URL = "file:///inexistent";
static final String DEFAULT_OVERRIDE_THIRD_PARTY = "src/license/override-THIRD-PARTY.properties";
/**
* Hidden
*/
private LicenseMojoUtils() {}
/**
* @param url the {@link URL} to check
* @return {@code url != null && url != NO_URL}
*/
public static boolean isValid(String url) {
return url != null && !NO_URL.equals(url);
}
/**
* Chooses the override {@link URL} to use out of {@code resolvedUrl}, {@code deprecatedFile}, {@code url}, or the
* default given by {@link #DEFAULT_OVERRIDE_THIRD_PARTY}.
*
* @param resolvedUrl returns this one if it is not {@code null} and not equal to {@link #NO_URL}
* @param deprecatedFile the deprecated mojo parameter
* @param url the newer variant of the mojo parameter
* @param basedir {@code basedir} to resolve {@value #DEFAULT_OVERRIDE_THIRD_PARTY} against
* @return a valid URL or {@link #NO_URL}, never {@code null}
*/
public static String prepareThirdPartyOverrideUrl(
final String resolvedUrl, final File deprecatedFile, final String url, File basedir) {
return prepareThirdPartyOverrideUrl(resolvedUrl, deprecatedFile, url, basedir, LOG);
}
/**
* An overload with explicit {@code log} param for testing purposes.
*
* @param resolvedUrl returns this one if it is not {@code null} and not equal to {@link #NO_URL}
* @param deprecatedFile the deprecated mojo parameter
* @param url the newer variant of the mojo parameter
* @param basedir {@code basedir} to resolve {@value #DEFAULT_OVERRIDE_THIRD_PARTY} against
* @param log the log to write to
* @return a valid URL or {@link #NO_URL}, never {@code null}
*/
static String prepareThirdPartyOverrideUrl(
final String resolvedUrl, final File deprecatedFile, final String url, File basedir, LoggerFacade log) {
if (deprecatedFile != null) {
log.warn("'overrideFile' mojo parameter is deprecated. Use 'overrideUrl' instead.");
}
return prepareUrl(resolvedUrl, deprecatedFile, url, basedir, DEFAULT_OVERRIDE_THIRD_PARTY, log);
}
private static String prepareUrl(
final String resolvedUrl,
final File deprecatedFile,
final String url,
File basedir,
String defaultFilePath,
LoggerFacade log) {
if (resolvedUrl != null && !NO_URL.equals(resolvedUrl)) {
return resolvedUrl;
}
if (deprecatedFile != null && url != null && !url.isEmpty()) {
throw new IllegalArgumentException("You can't use both overrideFile and overrideUrl");
}
if (deprecatedFile != null) {
if (deprecatedFile.exists()) {
String result = deprecatedFile.toURI().toString();
log.debug("Loading overrides from file {}", result);
return result;
} else {
log.warn("overrideFile [{}] was configured but doesn't exist", deprecatedFile.getAbsolutePath());
}
}
if (url != null) {
if (UrlRequester.isStringUrl(url)) {
log.debug("Loading overrides from URL {}", url);
return url;
} else {
log.warn(
"Unsupported or invalid URL [{}] found in overrideUrl; "
+ "supported are 'classpath:' URLs and anything your JVM supports "
+ "(file:, http: and https: should always work)",
url);
}
}
final Path basedirPath = basedir.toPath();
final Path defaultPath = basedirPath.resolve(defaultFilePath);
if (Files.exists(defaultPath)) {
String result = defaultPath.toUri().toString();
log.debug("Loading overrides from file {}", result);
return result;
}
log.debug("No (valid) URL and no file [{}] found; not loading any overrides", defaultPath.toAbsolutePath());
return NO_URL;
}
/**
* A {@link LoggerFacade} implementation backed by a SLF4J {@link Logger}.
*/
static class Slf4jLoggerFacade implements LoggerFacade {
private final Logger delegate;
Slf4jLoggerFacade(Logger delegate) {
super();
this.delegate = delegate;
}
@Override
public void warn(String message) {
delegate.warn(message);
}
@Override
public void warn(String template, Object param) {
delegate.warn(template, param);
}
@Override
public void debug(String template, Object param) {
delegate.debug(template, param);
}
}
/**
* A simplified facade of {@link Logger} to be able to implement a test logger easily.
*/
interface LoggerFacade {
/**
* @see Logger#warn(String)
*/
void warn(String message);
/**
* @see Logger#warn(String, Object)
*/
void warn(String template, Object param);
/**
* @see Logger#debug(String, Object)
*/
void debug(String template, Object param);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy