package org.jboss.shrinkwrap.resolver.impl.maven.task;
import java.text.MessageFormat;
import java.util.Iterator;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.jboss.shrinkwrap.resolver.api.ResolutionException;
import org.jboss.shrinkwrap.resolver.api.maven.MavenWorkingSession;
import org.jboss.shrinkwrap.resolver.api.maven.PackagingType;
import org.jboss.shrinkwrap.resolver.api.maven.coordinate.MavenCoordinate;
import org.jboss.shrinkwrap.resolver.api.maven.coordinate.MavenCoordinates;
import org.jboss.shrinkwrap.resolver.api.maven.coordinate.MavenDependency;
import org.jboss.shrinkwrap.resolver.api.maven.coordinate.MavenDependencyExclusion;
import org.jboss.shrinkwrap.resolver.impl.maven.coordinate.MavenDependencyImpl;
import org.jboss.shrinkwrap.resolver.impl.maven.util.Validate;
public class ResolveVersionFromMetadataTask implements MavenWorkingSessionTask<String> {
private static final Logger log = Logger.getLogger(ResolveVersionFromMetadataTask.class.getName());
private final MavenDependency dependency;
public ResolveVersionFromMetadataTask(MavenDependency dependency) {
this.dependency = dependency;
}
@Override
public String execute(MavenWorkingSession session) {
final String declaredVersion = dependency.getVersion();
String resolvedVersion = declaredVersion;
if (Validate.isNullOrEmptyOrQuestionMark(resolvedVersion)) {
if (session.getDependencyManagement().contains(dependency)) {
MavenDependency resolved = null;
Iterator<MavenDependency> it = session.getDependencyManagement().iterator();
while (it.hasNext()) {
resolved = it.next();
if (resolved.equals(dependency)) {
break;
}
}
resolvedVersion = resolved.getVersion();
log.log(Level.FINE, "Resolved version {0} from the POM file for the artifact {1}", new Object[] {
resolved.getVersion(), dependency.toCanonicalForm() });
}
}
if (Validate.isNullOrEmptyOrQuestionMark(resolvedVersion) && dependency.getPackaging().equals(PackagingType.JAR) && dependency.getClassifier().equals(PackagingType.TEST_JAR.getClassifier())) {
MavenCoordinate coordinate = MavenCoordinates.createCoordinate(dependency.getGroupId(), dependency.getArtifactId(), dependency.getVersion(), PackagingType.TEST_JAR, PackagingType.TEST_JAR.getClassifier());
MavenDependency newDependency = new MavenDependencyImpl(coordinate, dependency.getScope(), dependency.isOptional(), dependency.getExclusions().toArray(new MavenDependencyExclusion[0]));
if (session.getDependencyManagement().contains(newDependency)) {
MavenDependency resolved = null;
Iterator<MavenDependency> it = session.getDependencyManagement().iterator();
while (it.hasNext()) {
resolved = it.next();
if (resolved.equals(newDependency)) {
break;
}
}
resolvedVersion = resolved.getVersion();
log.log(Level.FINE, "Resolved version {0} from the POM file for the artifact {1} via {2}", new Object[] {
resolved.getVersion(), dependency.toCanonicalForm() , newDependency.toCanonicalForm()});
}
}
if (Validate.isNullOrEmptyOrQuestionMark(resolvedVersion)) {
if (log.isLoggable(Level.FINER)) {
StringBuilder sb = new StringBuilder("Available version management: \n");
for (final MavenDependency depmgmt : session.getDependencyManagement()) {
sb.append(depmgmt).append("\n");
}
log.log(Level.FINER, sb.toString());
}
throw new ResolutionException(
MessageFormat
.format(
"Unable to get version for dependency specified by {0}, it was not provided in neither <dependencyManagement> nor <dependencies> sections.",
dependency.toCanonicalForm()));
}
return resolvedVersion;
}
}