All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jboss.modules.maven.MavenResolver Maven / Gradle / Ivy

There is a newer version: 2.1.5.Final
Show newest version
/*
 * JBoss, Home of Professional Open Source.
 * Copyright 2015 Red Hat, Inc., and individual contributors
 * as indicated by the @author tags.
 *
 * Licensed 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.jboss.modules.maven;

import java.io.File;
import java.io.IOException;

/**
 * A resolution strategy for Maven artifacts.
 *
 * @author David M. Lloyd
 */
public interface MavenResolver {

    /**
     * Try to resolve a Maven JAR artifact.  Calling this method is identical to calling
     * {@code resolveJarArtifact(qualifier, "jar")}.
     *
     * @param coordinates the non-{@code null} Maven coordinates object
     * @return the absolute path to the artifact, or {@code null} if none exists
     * @throws IOException if acquiring the artifact path failed for some reason
     */
    default File resolveJarArtifact(final ArtifactCoordinates coordinates) throws IOException {
        return resolveArtifact(coordinates, "jar");
    }

    /**
     * Tries to find a maven jar artifact from the system property {@code "maven.repo.local"} This property is a list of
     * platform separated directory names.  If not specified, then it looks in {@code ${user.home}/.m2/repository} by default.
     * 

* If it can't find it in local paths, then will try to download from a remote repository from the system property * {@code "remote.maven.repo"}. There is no default remote repository. It will download both the pom and jar and put it * into the first directory listed in {@code "maven.repo.local"} (or the default directory). This directory will be * created if it doesn't exist. *

* Finally, if you do not want a message to console, then set the system property {@code "maven.download.message"} to * {@code "false"}. * * @param coordinates the non-{@code null} Maven coordinates object * @param packaging a non-{@code null} string with the exact packaging type desired (e.g. {@code pom}, {@code jar}, etc.) * @return the absolute path to the artifact, or {@code null} if none exists * @throws IOException if acquiring the artifact path failed for some reason */ File resolveArtifact(final ArtifactCoordinates coordinates, final String packaging) throws IOException; /** * Create a Maven artifact resolver using the default strategy. The permissions of the class calling this method * are captured and used for filesystem and network accesses. The default strategy uses the following system * properties: *

    *
  • {@code maven.repo.local} - a list of directory names using the platform separator which reflect local * Maven repository roots
  • *
  • {@code remote.maven.repo} - a comma-separated list of URIs which refer to remote Maven repositories, * from which artifacts can be downloaded
  • *
  • {@code maven.download.message} - a boolean system property which controls the logging of messages to * the console
  • *
* * @return the maven resolver strategy (not {@code null}) */ static MavenResolver createDefaultResolver() { return new DefaultMavenResolver(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy