| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, |
| * software distributed under the License is distributed on an |
| * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| * KIND, either express or implied. See the License for the |
| * specific language governing permissions and limitations |
| * under the License. |
| */ |
| |
| package org.apache.geronimo.gshell.artifact.maven; |
| |
| import org.apache.geronimo.gshell.chronos.StopWatch; |
| import org.apache.maven.artifact.Artifact; |
| import org.apache.maven.artifact.factory.ArtifactFactory; |
| import org.apache.maven.artifact.manager.WagonManager; |
| import org.apache.maven.artifact.metadata.ArtifactMetadataSource; |
| import org.apache.maven.artifact.resolver.ArtifactResolutionException; |
| import org.apache.maven.artifact.resolver.ArtifactResolutionRequest; |
| import org.apache.maven.artifact.resolver.ArtifactResolutionResult; |
| import org.apache.maven.artifact.resolver.ArtifactResolver; |
| import org.apache.maven.artifact.resolver.CyclicDependencyException; |
| import org.apache.maven.wagon.events.TransferListener; |
| import org.codehaus.plexus.component.annotations.Component; |
| import org.codehaus.plexus.component.annotations.Requirement; |
| import org.slf4j.Logger; |
| import org.slf4j.LoggerFactory; |
| |
| import java.util.List; |
| |
| /** |
| * Default implementation of the {@link ArtifactManager} component. |
| * |
| * @version $Rev$ $Date$ |
| */ |
| @Component(role=ArtifactManager.class) |
| public class ArtifactManagerImpl |
| implements ArtifactManager |
| { |
| private final Logger log = LoggerFactory.getLogger(getClass()); |
| |
| @Requirement |
| private ArtifactFactory artifactFactory; |
| |
| @Requirement |
| private ArtifactRepositoryManager repositoryManager; |
| |
| @Requirement |
| private ArtifactResolver artifactResolver; |
| |
| @Requirement(hint="gshell") |
| private ArtifactMetadataSource artifactMetadataSource; |
| |
| @Requirement |
| private WagonManager wagonManager; |
| |
| public ArtifactRepositoryManager getRepositoryManager() { |
| return repositoryManager; |
| } |
| |
| public ArtifactFactory getArtifactFactory() { |
| return artifactFactory; |
| } |
| |
| public void setDownloadMonitor(final TransferListener listener) { |
| assert listener != null; |
| |
| wagonManager.setDownloadMonitor(listener); |
| |
| log.debug("Using download monitor: {}", listener); |
| } |
| |
| public ArtifactResolutionResult resolve(final ArtifactResolutionRequest request) throws ResolutionException { |
| assert request != null; |
| |
| // Automatically fill in some missing bits |
| |
| if (request.getLocalRepository() == null) { |
| request.setLocalRepository(repositoryManager.getLocalRepository()); |
| } |
| |
| if (request.getRemoteRepostories() == null) { |
| request.setRemoteRepostories(repositoryManager.getRemoteRepositories()); |
| } |
| |
| if (request.getMetadataSource() == null) { |
| request.setMetadataSource(artifactMetadataSource); |
| } |
| |
| // If there is no artifact, then assume we want to do some full transitive resolve and install a dummy artifact |
| Artifact artifact = request.getArtifact(); |
| if (artifact == null) { |
| artifact = artifactFactory.createArtifact("dummy", "dummy", "dummy", null, "dummy"); |
| request.setArtifact(artifact); |
| } |
| |
| log.debug("Resolving request: {}", request); |
| |
| StopWatch watch = new StopWatch(true); |
| |
| ArtifactResolutionResult result = artifactResolver.resolve(request); |
| |
| log.debug("Resolution completed after: {}", watch); |
| |
| return validateResolutionResult(request, result); |
| } |
| |
| private ArtifactResolutionResult validateResolutionResult(final ArtifactResolutionRequest request, final ArtifactResolutionResult result) throws ResolutionException { |
| assert request != null; |
| assert result != null; |
| |
| log.debug("Validating result: {}", result); |
| |
| boolean failed = false; |
| |
| if (result.hasErrorArtifactExceptions()) { |
| failed = true; |
| |
| log.error("Artifact resolution errors:"); |
| List<ArtifactResolutionException> exceptions = result.getErrorArtifactExceptions(); |
| for (ArtifactResolutionException exception : exceptions) { |
| log.error(" {}", exception); |
| log.trace("Artifact resolution error", exception); |
| } |
| } |
| |
| if (result.hasCircularDependencyExceptions()) { |
| failed = true; |
| |
| log.error("Artifact circular dependency errors:"); |
| List<CyclicDependencyException> exceptions = result.getCircularDependencyExceptions(); |
| for (CyclicDependencyException exception : exceptions) { |
| log.error(" {}", exception); |
| log.trace("Artifact circular dependency error", exception); |
| } |
| } |
| |
| if (result.hasMetadataResolutionExceptions()) { |
| failed = true; |
| |
| log.error("Artifact metadata resolution errors:"); |
| // noinspection unchecked |
| List<ArtifactResolutionException> exceptions = result.getMetadataResolutionExceptions(); |
| for (ArtifactResolutionException exception : exceptions) { |
| log.error(" {}", exception); |
| log.trace("Artifact metadata resolution error", exception); |
| } |
| } |
| |
| if (result.hasVersionRangeViolations()) { |
| failed = true; |
| |
| log.error("Artifact version range violations:"); |
| // noinspection unchecked |
| List<Exception> exceptions = result.getVersionRangeViolations(); |
| for (Exception exception : exceptions) { |
| log.error(" {}", exception); |
| log.trace("Artifact version range violation", exception); |
| } |
| } |
| |
| // noinspection unchecked |
| List<Artifact> artifacts = result.getMissingArtifacts(); |
| if (!artifacts.isEmpty()) { |
| failed = true; |
| |
| log.error("Missing artifacts:"); |
| for (Artifact artifact : artifacts) { |
| log.error(" {}", artifact); |
| } |
| } |
| |
| if (failed) { |
| throw new ResolutionException(request, result); |
| } |
| |
| return result; |
| } |
| |
| public boolean isOnline() { |
| return wagonManager.isOnline(); |
| } |
| |
| public void setOnline(final boolean flag) { |
| log.debug("Online: {}", flag); |
| |
| wagonManager.setOnline(flag); |
| } |
| } |