Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
com.lewisd.maven.lint.util.ModelUtil Maven / Gradle / Ivy
package com.lewisd.maven.lint.util;
import java.lang.reflect.Field;
import java.util.Collection;
import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import org.apache.maven.model.Dependency;
import org.apache.maven.model.Exclusion;
import org.apache.maven.model.InputLocation;
import org.apache.maven.model.Model;
import org.apache.maven.model.Plugin;
import org.apache.maven.model.PluginExecution;
import org.apache.maven.plugin.logging.Log;
import org.apache.maven.project.MavenProject;
import org.springframework.beans.factory.annotation.Autowired;
import com.lewisd.maven.lint.model.Coordinates;
import com.lewisd.maven.lint.model.ExtDependency;
import com.lewisd.maven.lint.model.ExtPlugin;
import com.lewisd.maven.lint.model.ObjectWithPath;
public class ModelUtil {
private static final Object[] EMPTY_OBJECT_ARRAY = new Object[] {};
@SuppressWarnings("rawtypes")
private static final Class[] EMPTY_CLASS_ARRAY = new Class[] {};
private final ReflectionUtil reflectionUtil;
private final ExpressionEvaluator expressionEvaluator;
private final Log log;
@Autowired
public ModelUtil(final ReflectionUtil reflectionUtil, final ExpressionEvaluator expressionEvaluator,
final Log log) {
this.reflectionUtil = reflectionUtil;
this.expressionEvaluator = expressionEvaluator;
this.log = log;
}
/*
* TODO: This reflection nonsense is all a bit rubish. Let's add useful interfaces to the ExtPlugin, ExtDependency, etc
* classes, and create instances of those instead.
*/
public InputLocation getLocation(final Object modelObject) {
return getLocation(modelObject, "");
}
public InputLocation getLocation(final Object modelObject, final Object key) {
final String methodName = "getLocation";
return (InputLocation) reflectionUtil.callMethod(modelObject, methodName, new Class[] { Object.class }, new Object[] { key });
}
public String getVersion(final Object modelObject) {
final String methodName = "getVersion";
return (String) reflectionUtil.callMethod(modelObject, methodName, EMPTY_CLASS_ARRAY, EMPTY_OBJECT_ARRAY);
}
public String getArtifactId(final Object modelObject) {
final String methodName = "getArtifactId";
return (String) reflectionUtil.callMethod(modelObject, methodName, EMPTY_CLASS_ARRAY, EMPTY_OBJECT_ARRAY);
}
public String getGroupId(final Object modelObject) {
final String methodName = "getGroupId";
return (String) reflectionUtil.callMethod(modelObject, methodName, EMPTY_CLASS_ARRAY, EMPTY_OBJECT_ARRAY);
}
public String getType(final Object modelObject) {
final String methodName = "getType";
return (String) reflectionUtil.callMethod(modelObject, methodName, EMPTY_CLASS_ARRAY, EMPTY_OBJECT_ARRAY);
}
public String tryGetType(final Object modelObject) {
try {
return getType(modelObject);
} catch (final IllegalArgumentException e) {
return null;
}
}
public String getClassifier(final Object modelObject) {
final String methodName = "getClassifier";
return (String) reflectionUtil.callMethod(modelObject, methodName, EMPTY_CLASS_ARRAY, EMPTY_OBJECT_ARRAY);
}
public String tryGetClassifier(final Object modelObject) {
try {
return getClassifier(modelObject);
} catch (final IllegalArgumentException e) {
return null;
}
}
public String getKey(final Object modelObject) {
if (modelObject instanceof Dependency) {
return ((Dependency) modelObject).getManagementKey();
} else if (modelObject instanceof Plugin) {
return ((Plugin) modelObject).getKey();
} else {
throw new IllegalArgumentException("Unknown object type: " + modelObject.getClass());
}
}
@SuppressWarnings("rawtypes")
public Map getLocations(final Object modelObject) {
final Class klass = modelObject.getClass();
final Map locations = getLocations(modelObject, klass);
if (modelObject instanceof Plugin) {
final Plugin plugin = (Plugin) modelObject;
final List executions = plugin.getExecutions();
if (executions != null && !executions.isEmpty()) {
final PluginExecution pluginExecution = executions.get(0);
final InputLocation location = pluginExecution.getLocation("");
if (location != null) {
locations.put("execution", location);
} else {
log.warn("Unable to determine location for " + pluginExecution);
}
}
} else if (modelObject instanceof Dependency) {
final Dependency dependency = (Dependency) modelObject;
final List exclusions = dependency.getExclusions();
if (exclusions != null && !exclusions.isEmpty()) {
final Exclusion exclusion = exclusions.get(0);
final InputLocation location = exclusion.getLocation("");
if (location != null) {
locations.put("exclusion", location);
} else {
log.warn("Unable to determine location for " + exclusion);
}
}
}
return locations;
}
public Collection findGAVObjects(final MavenProject mavenProject) {
final Collection objects = new LinkedList();
final Model originalModel = mavenProject.getOriginalModel();
objects.add(originalModel);
objects.addAll(expressionEvaluator.getPath(originalModel, "dependencies"));
objects.addAll(expressionEvaluator.getPath(originalModel, "dependencyManagement/dependencies"));
objects.addAll(expressionEvaluator.getPath(originalModel, "build/plugins"));
objects.addAll(expressionEvaluator.getPath(originalModel, "build/plugins/dependencies"));
objects.addAll(expressionEvaluator.getPath(originalModel, "build/pluginManagement/plugins"));
objects.addAll(expressionEvaluator.getPath(originalModel, "build/pluginManagement/plugins/dependencies"));
return objects;
}
@SuppressWarnings({ "unchecked", "rawtypes" })
private Map getLocations(final Object modelObject, final Class klass) {
try {
final Field field = klass.getDeclaredField("locations");
field.setAccessible(true);
final Map locations = new HashMap();
final Map locationsFieldValue = (Map) field.get(modelObject);
for (Map.Entry entry : locationsFieldValue.entrySet()) {
if (entry.getValue() != null) {
locations.put(entry.getKey(), entry.getValue());
} else {
log.warn("Unable to determine location for " + entry.getKey());
}
}
return locations;
} catch (final NoSuchFieldException e) {
if (klass.getSuperclass() == null) {
throw new IllegalArgumentException("No 'locations' field found on object of type " + klass, e);
} else {
return getLocations(modelObject, klass.getSuperclass());
}
} catch (final SecurityException e) {
throw new IllegalArgumentException("Failed to get 'locations' field on object of type " + klass, e);
} catch (final IllegalArgumentException e) {
throw new IllegalArgumentException("Failed to get 'locations' field on object of type " + klass, e);
} catch (final IllegalAccessException e) {
throw new IllegalArgumentException("Failed to get 'locations' field on object of type " + klass, e);
}
}
public Map mapByManagementKey(final Collection dependencies) {
final Map map = new HashMap();
for (final Dependency dependency : dependencies) {
map.put(dependency.getManagementKey(), dependency);
}
return map;
}
public Map mapById(final Collection dependencies) {
final Map map = new HashMap();
for (final Plugin plugin : dependencies) {
map.put(plugin.getId(), plugin);
}
return map;
}
public ObjectWithPath findInheritedDependency(final MavenProject mavenProject, final Dependency dependency) {
final MavenProject parent = mavenProject.getParent();
if (parent != null) {
final Map dependencies = mapByManagementKey(expressionEvaluator.getPath(parent.getOriginalModel(), "dependencies"));
final Map managedDependencies = mapByManagementKey(expressionEvaluator.getPath(parent.getOriginalModel(),
"dependencyManagement/dependencies"));
final Dependency parentDependency = dependencies.get(dependency.getManagementKey());
if (parentDependency != null) {
return new ObjectWithPath(new ExtDependency(parent, parentDependency), parent, "dependencies");
}
final Dependency parentManagedDependency = managedDependencies.get(dependency.getManagementKey());
if (parentManagedDependency != null) {
return new ObjectWithPath(new ExtDependency(parent, parentManagedDependency), parent, "dependencyManagement/dependencies");
}
return findInheritedDependency(parent, dependency);
}
return null;
}
public List> findInheritedPlugins(final MavenProject mavenProject,
final Plugin plugin) {
final List> inheritedPlugins = new LinkedList>();
findInheritedPlugins(inheritedPlugins, mavenProject, plugin);
return inheritedPlugins;
}
private void findInheritedPlugins(final List> inheritedPlugins, final MavenProject mavenProject,
final Plugin plugin) {
final MavenProject parent = mavenProject.getParent();
if (parent != null) {
final Map plugins = mapById(expressionEvaluator.getPath(parent.getOriginalModel(), "build/plugins"));
final Map managedPlugins = mapById(expressionEvaluator.getPath(parent.getOriginalModel(),
"build/pluginManagement/plugins"));
final Plugin parentPlugin = plugins.get(plugin.getId());
if (parentPlugin != null) {
// FIXME replace ExtPlugin with Plugin
inheritedPlugins.add(new ObjectWithPath(new ExtPlugin(parent, parentPlugin), parent, "build/plugins"));
}
final Plugin parentManagedPlugin = managedPlugins.get(plugin.getId());
if (parentManagedPlugin != null) {
// FIXME replace ExtPlugin with Plugin
inheritedPlugins.add(new ObjectWithPath(new ExtPlugin(parent, parentManagedPlugin), parent, "build/pluginManagement/plugins"));
}
findInheritedPlugins(inheritedPlugins, parent, plugin);
}
}
public Coordinates getCoordinates(final Object modelObject) {
final String groupId = getGroupId(modelObject);
final String artifactId = getArtifactId(modelObject);
final String type = tryGetType(modelObject);
final String version = getVersion(modelObject);
return new Coordinates(groupId, artifactId, type, version);
}
}