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