From 6c80860d853832a08fe2339dc042a0d38565b051 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christoph=20L=C3=A4ubrich?= Date: Mon, 23 Sep 2024 08:56:17 +0200 Subject: [PATCH] Migrate RepositoryArtifactCoordinateResolver to JSR330/Resolver API --- tycho-packaging-plugin/pom.xml | 4 + .../RepositoryArtifactCoordinateResolver.java | 83 +++++++++---------- 2 files changed, 43 insertions(+), 44 deletions(-) diff --git a/tycho-packaging-plugin/pom.xml b/tycho-packaging-plugin/pom.xml index 05b5cf6fc0..e721a41455 100644 --- a/tycho-packaging-plugin/pom.xml +++ b/tycho-packaging-plugin/pom.xml @@ -97,6 +97,10 @@ org.codehaus.plexus plexus-component-metadata + + org.eclipse.sisu + sisu-maven-plugin + org.apache.maven.plugins maven-plugin-plugin diff --git a/tycho-packaging-plugin/src/main/java/org/eclipse/tycho/packaging/reverseresolve/RepositoryArtifactCoordinateResolver.java b/tycho-packaging-plugin/src/main/java/org/eclipse/tycho/packaging/reverseresolve/RepositoryArtifactCoordinateResolver.java index f419bb374d..809b6b1d99 100644 --- a/tycho-packaging-plugin/src/main/java/org/eclipse/tycho/packaging/reverseresolve/RepositoryArtifactCoordinateResolver.java +++ b/tycho-packaging-plugin/src/main/java/org/eclipse/tycho/packaging/reverseresolve/RepositoryArtifactCoordinateResolver.java @@ -22,31 +22,35 @@ import java.util.jar.JarEntry; import java.util.jar.JarFile; +import javax.inject.Inject; +import javax.inject.Named; +import javax.inject.Singleton; + import org.apache.commons.io.FileUtils; import org.apache.commons.io.FilenameUtils; -import org.apache.maven.artifact.Artifact; -import org.apache.maven.artifact.resolver.ArtifactResolutionRequest; -import org.apache.maven.artifact.resolver.ArtifactResolutionResult; +import org.apache.maven.RepositoryUtils; import org.apache.maven.execution.MavenSession; import org.apache.maven.model.Dependency; import org.apache.maven.project.MavenProject; -import org.apache.maven.repository.RepositorySystem; -import org.codehaus.plexus.component.annotations.Component; -import org.codehaus.plexus.component.annotations.Requirement; import org.codehaus.plexus.logging.Logger; -import org.eclipse.tycho.core.DependencyResolutionException; +import org.eclipse.aether.RepositorySystem; +import org.eclipse.aether.artifact.Artifact; +import org.eclipse.aether.artifact.DefaultArtifact; +import org.eclipse.aether.resolution.ArtifactRequest; +import org.eclipse.aether.resolution.ArtifactResult; /** * This resolves against the maven (local) repository if the jar carry a * suitable pom.properties file... */ -@Component(role = ArtifactCoordinateResolver.class, hint = "local") +@Singleton +@Named("local") public class RepositoryArtifactCoordinateResolver implements ArtifactCoordinateResolver { - @Requirement + @Inject private RepositorySystem repositorySystem; - @Requirement + @Inject private Logger log; @Override @@ -63,42 +67,33 @@ public Optional resolve(Dependency dep, MavenProject project, MavenS String version = properties.getProperty("version"); if (artifactId != null && groupId != null && version != null) { String type = FilenameUtils.getExtension(path.getFileName().toString()); - Dependency dependency = new Dependency(); - dependency.setGroupId(groupId); - dependency.setArtifactId(artifactId); - dependency.setType(type); - dependency.setVersion(version); - Artifact artifact = repositorySystem.createDependencyArtifact(dependency); - ArtifactResolutionRequest request = new ArtifactResolutionRequest(); - request.setArtifact(artifact); - request.setOffline(session.isOffline()); - request.setLocalRepository(session.getLocalRepository()); - repositorySystem.injectMirror(request.getRemoteRepositories(), session.getSettings().getMirrors()); - repositorySystem.injectProxy(request.getRemoteRepositories(), session.getSettings().getProxies()); - repositorySystem.injectAuthentication(request.getRemoteRepositories(), - session.getSettings().getServers()); - ArtifactResolutionResult resolveResult = repositorySystem.resolve(request); - if (resolveResult.hasExceptions()) { - DependencyResolutionException exception = new DependencyResolutionException( - "Resolving " + artifact + " failed", resolveResult.getExceptions()); - log.debug("Resolving " + artifact + " failed because of: " + exception, exception); - return Optional.empty(); + Artifact artifact = new DefaultArtifact(groupId, artifactId, type, version); + ArtifactRequest artifactRequest = new ArtifactRequest(); + artifactRequest.setArtifact(artifact); + artifactRequest.setRepositories(RepositoryUtils.toRepos(project.getRemoteArtifactRepositories())); + ArtifactResult artifactResult = repositorySystem.resolveArtifact(session.getRepositorySession(), + artifactRequest); + if (artifactResult.isResolved()) { + } else { + log.debug("Resolving " + artifact + " failed because of: " + artifactResult.getExceptions()); + return Optional.empty(); } - return resolveResult.getArtifacts().stream().filter(a -> a.getFile() != null).filter(a -> { - try { - return FileUtils.contentEquals(a.getFile(), path.toFile()); - } catch (IOException e) { - return false; - } - }).map(a -> { - Dependency result = new Dependency(); - result.setGroupId(a.getGroupId()); - result.setArtifactId(a.getArtifactId()); - result.setVersion(a.getVersion()); - result.setType(a.getType()); - return result; - }).findFirst(); + return Optional.ofNullable(artifactResult.getArtifact()).filter(a -> a.getFile() != null) + .filter(a -> { + try { + return FileUtils.contentEquals(a.getFile(), path.toFile()); + } catch (IOException e) { + return false; + } + }).map(a -> { + Dependency result = new Dependency(); + result.setGroupId(a.getGroupId()); + result.setArtifactId(a.getArtifactId()); + result.setVersion(a.getVersion()); + result.setType(a.getExtension()); + return result; + }); } } catch (Exception e) {