From 111abc9c06e5588d9a91a28ecc30dcb3419c7326 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christoph=20L=C3=A4ubrich?= Date: Thu, 12 Sep 2024 08:05:31 +0200 Subject: [PATCH] Convert MavenURLStreamHandlerService to JSR330 / Resolver API --- p2-maven-plugin/pom.xml | 4 + .../p2maven/MavenURLStreamHandlerService.java | 88 ++++++++++--------- 2 files changed, 51 insertions(+), 41 deletions(-) diff --git a/p2-maven-plugin/pom.xml b/p2-maven-plugin/pom.xml index 477497f3d6..87ccc8e0eb 100644 --- a/p2-maven-plugin/pom.xml +++ b/p2-maven-plugin/pom.xml @@ -219,6 +219,10 @@ org.apache.maven.plugins maven-plugin-plugin + + org.eclipse.sisu + sisu-maven-plugin + org.apache.servicemix.tooling depends-maven-plugin diff --git a/p2-maven-plugin/src/main/java/org/eclipse/tycho/p2maven/MavenURLStreamHandlerService.java b/p2-maven-plugin/src/main/java/org/eclipse/tycho/p2maven/MavenURLStreamHandlerService.java index ac843fb70c..fc75f3106d 100644 --- a/p2-maven-plugin/src/main/java/org/eclipse/tycho/p2maven/MavenURLStreamHandlerService.java +++ b/p2-maven-plugin/src/main/java/org/eclipse/tycho/p2maven/MavenURLStreamHandlerService.java @@ -21,17 +21,22 @@ import java.util.Arrays; import java.util.List; import java.util.Map; -import java.util.Set; -import org.apache.maven.artifact.Artifact; -import org.apache.maven.artifact.resolver.ArtifactResolutionRequest; -import org.apache.maven.artifact.resolver.ArtifactResolutionResult; +import javax.inject.Inject; +import javax.inject.Named; +import javax.inject.Singleton; + +import org.apache.maven.RepositoryUtils; +import org.apache.maven.artifact.repository.ArtifactRepository; import org.apache.maven.execution.MavenSession; import org.apache.maven.plugin.LegacySupport; -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.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.ArtifactResolutionException; +import org.eclipse.aether.resolution.ArtifactResult; import org.eclipse.sisu.equinox.embedder.EmbeddedEquinox; import org.eclipse.sisu.equinox.embedder.EquinoxLifecycleListener; import org.osgi.service.url.AbstractURLStreamHandlerService; @@ -43,18 +48,19 @@ * This makes the mvn protocol available to P2 e.g. to load * updates-sites. */ -@Component(role = EquinoxLifecycleListener.class, hint = "MavenURLStreamHandlerService") +@Singleton +@Named("MavenURLStreamHandlerService") public class MavenURLStreamHandlerService extends AbstractURLStreamHandlerService implements EquinoxLifecycleListener { private static final String PROTOCOL = "mvn"; - @Requirement + @Inject private Logger logger; - @Requirement + @Inject private LegacySupport context; - @Requirement + @Inject private RepositorySystem repositorySystem; private MavenSession mavenSession; @@ -124,45 +130,45 @@ public void connect() throws IOException { String artifactId = coordinates[1]; String version = coordinates[2]; if (classifier != null && !classifier.isEmpty()) { - artifact = repositorySystem.createArtifactWithClassifier(groupId, artifactId, version, type, - classifier); + artifact = new DefaultArtifact(groupId, artifactId, classifier, type, version); } else { - artifact = repositorySystem.createArtifact(groupId, artifactId, version, null, type); + artifact = new DefaultArtifact(groupId, artifactId, "", type, version); } logger.debug("Resolving " + artifact); - ArtifactResolutionRequest request = new ArtifactResolutionRequest(); - request.setArtifact(artifact); - request.setResolveRoot(true); - request.setOffline(mavenSession.isOffline()); - request.setLocalRepository(mavenSession.getLocalRepository()); - request.setResolveTransitively(false); - request.setRemoteRepositories(mavenSession.getCurrentProject().getRemoteArtifactRepositories()); - ArtifactResolutionResult result = repositorySystem.resolve(request); - if (result.hasExceptions()) { - String message = "Resolving " + artifact + " failed"; - List exceptions = result.getExceptions(); - if (exceptions.size() == 1) { - throw new IOException(message, exceptions.get(0)); - } else { - IOException exception = new IOException(message); - for (Exception suppressed : exceptions) { - exception.addSuppressed(suppressed); + ArtifactRequest artifactRequest = new ArtifactRequest(); + artifactRequest.setArtifact(artifact); + artifactRequest.addRepository(RepositoryUtils.toRepo(mavenSession.getLocalRepository())); + for (ArtifactRepository repo : mavenSession.getCurrentProject().getRemoteArtifactRepositories()) { + artifactRequest.addRepository(RepositoryUtils.toRepo(repo)); + } + try { + ArtifactResult artifactResult = repositorySystem + .resolveArtifact(mavenSession.getRepositorySession(), artifactRequest); + artifact = artifactResult.getArtifact(); + if (!artifactResult.getExceptions().isEmpty()) { + String message = "Resolving " + artifact + " failed"; + List exceptions = artifactResult.getExceptions(); + if (exceptions.size() == 1) { + throw new IOException(message, exceptions.get(0)); + } else { + IOException exception = new IOException(message); + for (Exception suppressed : exceptions) { + exception.addSuppressed(suppressed); + } + throw exception; } - throw exception; } - } - Set artifacts = result.getArtifacts(); - if (artifacts.isEmpty()) { + if (artifactResult.isMissing()) { + throw new IOException("artifact " + Arrays.toString(coordinates) + + " could not be retrieved from any of the available repositories"); + } + } catch (ArtifactResolutionException e) { throw new IOException("artifact " + Arrays.toString(coordinates) - + " could not be retrieved from any of the available repositories"); - } - if (artifacts.size() > 1) { - throw new IOException( - "artifact " + Arrays.toString(coordinates) + " resolves to multiple artifacts"); + + " could not be resolved"); } - artifact = artifacts.iterator().next(); } catch (RuntimeException e) { throw new IOException("internal error connecting to maven url " + url, e); + } }