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

org.ops4j.pax.url.mvn.internal.Connection Maven / Gradle / Ivy

/*
 * Copyright 2007 Alin Dreghiciu.
 * Copyright 2010, 2011 Toni Menzel.
 * Copyright (C) 2014 Guillaume Nodet
 *
 * 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.ops4j.pax.url.mvn.internal;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;

import org.ops4j.lang.NullArgumentException;
import org.ops4j.pax.url.mvn.MavenResolver;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * An URLConnection that supports mvn: protocol.
* Syntax:
* mvn:[repository_url!]groupId/artifactId[/version[/type]]
* where:
* - repository_url = an url that points to a maven 2 repository; optional, if not specified the repositories are * resolved based on the repository/localRepository.
* - groupId = group id of maven artifact; mandatory
* - artifactId = artifact id of maven artifact; mandatory
* - version = version of maven artifact; optional, if not specified uses LATEST and will try to resolve the version * from available maven metadata. If version is a SNAPSHOT version, SNAPSHOT will be resolved from available maven * metadata
* - type = type of maven artifact; optional, if not specified uses JAR
* Examples:
* mvn:http://repository.ops4j.org/mvn-releases!org.ops4j.pax.runner/runner/0.4.0 - an artifact from an http repository
* mvn:http://user:[email protected]/mvn-releases!org.ops4j.pax.runner/runner/0.4.0 - an artifact from an http * repository with authentication
* mvn:file://c:/localRepo!org.ops4j.pax.runner/runner/0.4.0 - an artifact from a directory
* mvn:jar:file://c:/repo.zip!/repository!org.ops4j.pax.runner/runner/0.4.0 - an artifact from a zip file
* mvn:org.ops4j.pax.runner/runner/0.4.0 - an artifact that will be resolved based on the configured repositories
*
* The service can be configured in two ways: via configuration admin if available and via framework/system properties * where the configuration via config admin has priority.
* Service configuration:
* - org.ops4j.pax.url.mvn.settings = the path to settings.xml;
* - org.ops4j.pax.url.mvn.localRepository = the path to local repository directory;
* - org.ops4j.pax.url.mvn.repository = a comma separated list for repositories urls;
* - org.ops4j.pax.url.mvn.certificateCheck = true/false if the SSL certificate check should be done. * Default false. * * @author Toni Menzel * @author Alin Dreghiciu * @author Guillaume Nodet * @since September 10, 2010 */ public class Connection extends URLConnection { /** * Logger. */ private static final Logger LOG = LoggerFactory.getLogger( Connection.class ); /** * Maven resolver */ private final MavenResolver m_resolver; /** * Creates a new connection. * * @param url the url; cannot be null. * @param resolver resolver service; cannot be null * * @throws java.net.MalformedURLException in case of a malformed url */ public Connection( final URL url, final MavenResolver resolver ) throws MalformedURLException { super( url ); NullArgumentException.validateNotNull( url, "URL cannot be null" ); NullArgumentException.validateNotNull( resolver, "Service configuration" ); m_resolver = resolver; // Verify the url syntax, will throw an exception when invalid new Parser( url.getPath() ); } /** * Does nothing. * * @see java.net.URLConnection#connect() */ @Override public void connect() { // do nothing } /** * TODO doc */ @Override public InputStream getInputStream() throws IOException { connect(); LOG.debug( "Resolving [" + url.toExternalForm() + "]" ); File file = m_resolver.resolve( url.toExternalForm() ); return new FileInputStream( file ); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy