mirror of https://github.com/apache/maven.git
refactoring towards similar pattern of artifact metadata
git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@264967 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
8201bb9d18
commit
c991b41571
|
@ -22,19 +22,14 @@ import org.apache.maven.wagon.ResourceDoesNotExistException;
|
||||||
import org.apache.maven.wagon.TransferFailedException;
|
import org.apache.maven.wagon.TransferFailedException;
|
||||||
import org.codehaus.plexus.logging.AbstractLogEnabled;
|
import org.codehaus.plexus.logging.AbstractLogEnabled;
|
||||||
import org.codehaus.plexus.util.FileUtils;
|
import org.codehaus.plexus.util.FileUtils;
|
||||||
import org.codehaus.plexus.util.IOUtil;
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileInputStream;
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.util.HashSet;
|
||||||
import java.util.HashMap;
|
import java.util.Iterator;
|
||||||
import java.util.Map;
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
/**
|
|
||||||
* @todo try to crop all, particularly plugin stuff
|
|
||||||
* @todo check caching?
|
|
||||||
*/
|
|
||||||
public class DefaultRepositoryMetadataManager
|
public class DefaultRepositoryMetadataManager
|
||||||
extends AbstractLogEnabled
|
extends AbstractLogEnabled
|
||||||
implements RepositoryMetadataManager
|
implements RepositoryMetadataManager
|
||||||
|
@ -42,31 +37,32 @@ public class DefaultRepositoryMetadataManager
|
||||||
// component requirement
|
// component requirement
|
||||||
private WagonManager wagonManager;
|
private WagonManager wagonManager;
|
||||||
|
|
||||||
// only resolve repository metadata once per session...
|
/**
|
||||||
private Map cachedMetadata = new HashMap();
|
* @todo very primitve. Probably we can cache artifacts themselves in a central location, as well as reset the flag over time in a long running process.
|
||||||
|
*/
|
||||||
|
private Set cachedMetadata = new HashSet();
|
||||||
|
|
||||||
public void resolveLocally( RepositoryMetadata metadata, ArtifactRepository local )
|
public void resolve( RepositoryMetadata metadata, List repositories, ArtifactRepository local )
|
||||||
throws RepositoryMetadataManagementException
|
throws RepositoryMetadataManagementException
|
||||||
{
|
{
|
||||||
resolve( metadata, null, local );
|
boolean alreadyResolved = alreadyResolved( metadata );
|
||||||
}
|
if ( !alreadyResolved )
|
||||||
|
|
||||||
public void resolve( RepositoryMetadata metadata, ArtifactRepository remote, ArtifactRepository local )
|
|
||||||
throws RepositoryMetadataManagementException
|
|
||||||
{
|
{
|
||||||
File metadataFile = (File) cachedMetadata.get( metadata.getRepositoryPath() );
|
for ( Iterator i = repositories.iterator(); i.hasNext(); )
|
||||||
|
|
||||||
if ( metadataFile == null )
|
|
||||||
{
|
{
|
||||||
metadataFile = constructLocalRepositoryFile( metadata, local );
|
ArtifactRepository repository = (ArtifactRepository) i.next();
|
||||||
|
|
||||||
if ( !metadataFile.exists() && remote != null )
|
// TODO: replace with a more general repository update mechanism like artifact metadata uses
|
||||||
|
// (Actually, this should now supersede artifact metadata...)
|
||||||
|
File metadataFile = new File( local.getBasedir(), local.pathOfRepositoryMetadata( metadata ) );
|
||||||
|
|
||||||
|
if ( !metadataFile.exists() )
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
wagonManager.getRepositoryMetadata( metadata, remote, metadataFile );
|
wagonManager.getRepositoryMetadata( metadata, repository, metadataFile );
|
||||||
}
|
}
|
||||||
catch ( ResourceDoesNotExistException e )
|
catch ( ResourceDoesNotExistException e )
|
||||||
{
|
{
|
||||||
|
@ -78,7 +74,8 @@ public class DefaultRepositoryMetadataManager
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
String message = "Cannot find " + metadata + " in remote repository - Using local copy.";
|
String message = "Cannot find " + metadata +
|
||||||
|
" in remote repository - Using local copy.";
|
||||||
|
|
||||||
getLogger().info( message );
|
getLogger().info( message );
|
||||||
|
|
||||||
|
@ -97,36 +94,8 @@ public class DefaultRepositoryMetadataManager
|
||||||
getLogger().info( "Using local copy of " + metadata + " from: " + metadataFile );
|
getLogger().info( "Using local copy of " + metadata + " from: " + metadataFile );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( metadataFile.exists() )
|
cachedMetadata.add( metadata.getRepositoryPath() );
|
||||||
{
|
|
||||||
if ( !verifyFileNotEmpty( metadataFile ) )
|
|
||||||
{
|
|
||||||
throw new InvalidRepositoryMetadataException( metadata, "Metadata located in file: " +
|
|
||||||
metadataFile + " appears to be corrupt (file is empty). DOWNLOAD FAILED." );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
cachedMetadata.put( metadata.getRepositoryPath(), metadataFile );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private boolean verifyFileNotEmpty( File metadataFile )
|
|
||||||
{
|
|
||||||
InputStream verifyInputStream = null;
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
verifyInputStream = new FileInputStream( metadataFile );
|
|
||||||
|
|
||||||
return verifyInputStream.available() > 0;
|
|
||||||
}
|
|
||||||
catch ( IOException e )
|
|
||||||
{
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
finally
|
|
||||||
{
|
|
||||||
IOUtil.close( verifyInputStream );
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -147,7 +116,7 @@ public class DefaultRepositoryMetadataManager
|
||||||
public void install( File source, RepositoryMetadata metadata, ArtifactRepository local )
|
public void install( File source, RepositoryMetadata metadata, ArtifactRepository local )
|
||||||
throws RepositoryMetadataManagementException
|
throws RepositoryMetadataManagementException
|
||||||
{
|
{
|
||||||
File metadataFile = constructLocalRepositoryFile( metadata, local );
|
File metadataFile = new File( local.getBasedir(), local.pathOfRepositoryMetadata( metadata ) );
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
@ -167,24 +136,8 @@ public class DefaultRepositoryMetadataManager
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void purgeLocalCopy( RepositoryMetadata metadata, ArtifactRepository local )
|
private boolean alreadyResolved( RepositoryMetadata metadata )
|
||||||
throws RepositoryMetadataManagementException
|
|
||||||
{
|
{
|
||||||
File metadataFile = constructLocalRepositoryFile( metadata, local );
|
return cachedMetadata.contains( metadata.getRepositoryPath() );
|
||||||
|
|
||||||
if ( metadataFile.exists() )
|
|
||||||
{
|
|
||||||
if ( !metadataFile.delete() )
|
|
||||||
{
|
|
||||||
throw new RepositoryMetadataManagementException( metadata,
|
|
||||||
"Failed to purge local copy from: " + metadataFile );
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
private static File constructLocalRepositoryFile( RepositoryMetadata metadata, ArtifactRepository local )
|
|
||||||
{
|
|
||||||
return new File( local.getBasedir(), local.pathOfRepositoryMetadata( metadata ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,33 +0,0 @@
|
||||||
package org.apache.maven.artifact.repository.metadata;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Copyright 2001-2005 The Apache Software Foundation.
|
|
||||||
*
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
public class InvalidRepositoryMetadataException
|
|
||||||
extends RepositoryMetadataManagementException
|
|
||||||
{
|
|
||||||
|
|
||||||
public InvalidRepositoryMetadataException( RepositoryMetadata metadata, String message, Throwable cause )
|
|
||||||
{
|
|
||||||
super( metadata, message, cause );
|
|
||||||
}
|
|
||||||
|
|
||||||
public InvalidRepositoryMetadataException( RepositoryMetadata metadata, String message )
|
|
||||||
{
|
|
||||||
super( metadata, message );
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -16,8 +16,6 @@ package org.apache.maven.artifact.repository.metadata;
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
|
|
||||||
public class PluginMappingMetadata
|
public class PluginMappingMetadata
|
||||||
implements RepositoryMetadata
|
implements RepositoryMetadata
|
||||||
{
|
{
|
||||||
|
@ -25,11 +23,6 @@ public class PluginMappingMetadata
|
||||||
|
|
||||||
private final String groupId;
|
private final String groupId;
|
||||||
|
|
||||||
/**
|
|
||||||
* @todo REMOVE!
|
|
||||||
*/
|
|
||||||
private File metadataFile;
|
|
||||||
|
|
||||||
public PluginMappingMetadata( String groupId )
|
public PluginMappingMetadata( String groupId )
|
||||||
{
|
{
|
||||||
this.groupId = groupId;
|
this.groupId = groupId;
|
||||||
|
|
|
@ -19,13 +19,12 @@ package org.apache.maven.artifact.repository.metadata;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepository;
|
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
public interface RepositoryMetadataManager
|
public interface RepositoryMetadataManager
|
||||||
{
|
{
|
||||||
void resolveLocally( RepositoryMetadata repositoryMetadata, ArtifactRepository local )
|
|
||||||
throws RepositoryMetadataManagementException;
|
|
||||||
|
|
||||||
void resolve( RepositoryMetadata repositoryMetadata, ArtifactRepository remote, ArtifactRepository local )
|
void resolve( RepositoryMetadata repositoryMetadata, List repositories, ArtifactRepository local )
|
||||||
throws RepositoryMetadataManagementException;
|
throws RepositoryMetadataManagementException;
|
||||||
|
|
||||||
void deploy( File source, RepositoryMetadata repositoryMetadata, ArtifactRepository remote )
|
void deploy( File source, RepositoryMetadata repositoryMetadata, ArtifactRepository remote )
|
||||||
|
@ -34,6 +33,4 @@ public interface RepositoryMetadataManager
|
||||||
void install( File source, RepositoryMetadata repositoryMetadata, ArtifactRepository local )
|
void install( File source, RepositoryMetadata repositoryMetadata, ArtifactRepository local )
|
||||||
throws RepositoryMetadataManagementException;
|
throws RepositoryMetadataManagementException;
|
||||||
|
|
||||||
void purgeLocalCopy( RepositoryMetadata repositoryMetadata, ArtifactRepository local )
|
|
||||||
throws RepositoryMetadataManagementException;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,6 @@ package org.apache.maven.plugin;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepository;
|
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||||
import org.apache.maven.artifact.repository.metadata.InvalidRepositoryMetadataException;
|
|
||||||
import org.apache.maven.artifact.repository.metadata.Metadata;
|
import org.apache.maven.artifact.repository.metadata.Metadata;
|
||||||
import org.apache.maven.artifact.repository.metadata.Plugin;
|
import org.apache.maven.artifact.repository.metadata.Plugin;
|
||||||
import org.apache.maven.artifact.repository.metadata.PluginMappingMetadata;
|
import org.apache.maven.artifact.repository.metadata.PluginMappingMetadata;
|
||||||
|
@ -51,98 +50,23 @@ public class DefaultPluginMappingManager
|
||||||
{
|
{
|
||||||
protected RepositoryMetadataManager repositoryMetadataManager;
|
protected RepositoryMetadataManager repositoryMetadataManager;
|
||||||
|
|
||||||
private List mappings = new ArrayList();
|
private Map pluginDefinitionsByPrefix = new HashMap();
|
||||||
|
|
||||||
private boolean refreshed;
|
|
||||||
|
|
||||||
private Map pluginDefinitionsByPrefix;
|
|
||||||
|
|
||||||
public void clear()
|
|
||||||
{
|
|
||||||
this.mappings = null;
|
|
||||||
clearCache();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void clearCache()
|
|
||||||
{
|
|
||||||
this.pluginDefinitionsByPrefix = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public org.apache.maven.model.Plugin getByPrefix( String pluginPrefix, List groupIds, List pluginRepositories,
|
public org.apache.maven.model.Plugin getByPrefix( String pluginPrefix, List groupIds, List pluginRepositories,
|
||||||
ArtifactRepository localRepository )
|
ArtifactRepository localRepository )
|
||||||
throws RepositoryMetadataManagementException
|
throws RepositoryMetadataManagementException
|
||||||
{
|
{
|
||||||
if ( pluginDefinitionsByPrefix == null )
|
|
||||||
{
|
|
||||||
// firstly, search the local repository
|
|
||||||
loadPluginMappings( groupIds, pluginRepositories, localRepository );
|
|
||||||
|
|
||||||
calculatePluginDefinitionsByPrefix();
|
|
||||||
|
|
||||||
// if not found, try from the remote repository
|
// if not found, try from the remote repository
|
||||||
if ( !pluginDefinitionsByPrefix.containsKey( pluginPrefix ) && !refreshed )
|
if ( !pluginDefinitionsByPrefix.containsKey( pluginPrefix ) )
|
||||||
{
|
{
|
||||||
getLogger().info(
|
getLogger().info( "Searching repository for plugin with prefix: \'" + pluginPrefix + "\'." );
|
||||||
"Refreshing plugin mapping metadata; looking for plugin with prefix: \'" + pluginPrefix + "\'." );
|
|
||||||
|
|
||||||
refreshPluginMappingManager( pluginRepositories, localRepository );
|
|
||||||
|
|
||||||
refreshed = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
calculatePluginDefinitionsByPrefix();
|
|
||||||
}
|
|
||||||
return (org.apache.maven.model.Plugin) pluginDefinitionsByPrefix.get( pluginPrefix );
|
|
||||||
}
|
|
||||||
|
|
||||||
private void calculatePluginDefinitionsByPrefix()
|
|
||||||
{
|
|
||||||
pluginDefinitionsByPrefix = new HashMap();
|
|
||||||
|
|
||||||
for ( Iterator it = mappings.iterator(); it.hasNext(); )
|
|
||||||
{
|
|
||||||
Metadata pluginMap = (Metadata) it.next();
|
|
||||||
|
|
||||||
String groupId = pluginMap.getGroupId();
|
|
||||||
|
|
||||||
for ( Iterator pluginIterator = pluginMap.getPlugins().iterator(); pluginIterator.hasNext(); )
|
|
||||||
{
|
|
||||||
Plugin mapping = (Plugin) pluginIterator.next();
|
|
||||||
|
|
||||||
String prefix = mapping.getPrefix();
|
|
||||||
|
|
||||||
String artifactId = mapping.getArtifactId();
|
|
||||||
|
|
||||||
org.apache.maven.model.Plugin plugin = new org.apache.maven.model.Plugin();
|
|
||||||
|
|
||||||
plugin.setGroupId( groupId );
|
|
||||||
|
|
||||||
plugin.setArtifactId( artifactId );
|
|
||||||
|
|
||||||
pluginDefinitionsByPrefix.put( prefix, plugin );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void refreshPluginMappingManager( List pluginRepositories, ArtifactRepository localRepository )
|
|
||||||
throws RepositoryMetadataManagementException
|
|
||||||
{
|
|
||||||
List groupIds = new ArrayList();
|
|
||||||
|
|
||||||
for ( Iterator it = mappings.iterator(); it.hasNext(); )
|
|
||||||
{
|
|
||||||
Metadata map = (Metadata) it.next();
|
|
||||||
|
|
||||||
String groupId = map.getGroupId();
|
|
||||||
|
|
||||||
groupIds.add( groupId );
|
|
||||||
|
|
||||||
repositoryMetadataManager.purgeLocalCopy( new PluginMappingMetadata( groupId ), localRepository );
|
|
||||||
}
|
|
||||||
|
|
||||||
loadPluginMappings( groupIds, pluginRepositories, localRepository );
|
loadPluginMappings( groupIds, pluginRepositories, localRepository );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return (org.apache.maven.model.Plugin) pluginDefinitionsByPrefix.get( pluginPrefix );
|
||||||
|
}
|
||||||
|
|
||||||
private void loadPluginMappings( List groupIds, List pluginRepositories, ArtifactRepository localRepository )
|
private void loadPluginMappings( List groupIds, List pluginRepositories, ArtifactRepository localRepository )
|
||||||
{
|
{
|
||||||
List pluginGroupIds = new ArrayList( groupIds );
|
List pluginGroupIds = new ArrayList( groupIds );
|
||||||
|
@ -159,15 +83,7 @@ public class DefaultPluginMappingManager
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
File mappingFile = resolveMappingMetadata( repositoryMetadataManager, groupId, pluginRepositories,
|
loadPluginMappings( groupId, pluginRepositories, localRepository );
|
||||||
localRepository );
|
|
||||||
|
|
||||||
Metadata pluginMap = readPluginMap( mappingFile );
|
|
||||||
|
|
||||||
if ( pluginMap != null )
|
|
||||||
{
|
|
||||||
mappings.add( pluginMap );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
catch ( RepositoryMetadataManagementException e )
|
catch ( RepositoryMetadataManagementException e )
|
||||||
{
|
{
|
||||||
|
@ -175,18 +91,51 @@ public class DefaultPluginMappingManager
|
||||||
|
|
||||||
getLogger().debug( "Error resolving plugin-mapping metadata for groupId: " + groupId + ".", e );
|
getLogger().debug( "Error resolving plugin-mapping metadata for groupId: " + groupId + ".", e );
|
||||||
}
|
}
|
||||||
|
|
||||||
clearCache();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private static Metadata readPluginMap( File mappingFile )
|
private void loadPluginMappings( String groupId, List pluginRepositories, ArtifactRepository localRepository )
|
||||||
throws RepositoryMetadataManagementException
|
throws RepositoryMetadataManagementException
|
||||||
{
|
{
|
||||||
Metadata result = null;
|
PluginMappingMetadata metadata = new PluginMappingMetadata( groupId );
|
||||||
|
|
||||||
if ( mappingFile.exists() )
|
// TOOD: aggregate the results of this instead
|
||||||
|
repositoryMetadataManager.resolve( metadata, pluginRepositories, localRepository );
|
||||||
|
|
||||||
|
File metadataFile = new File( localRepository.getBasedir(),
|
||||||
|
localRepository.pathOfRepositoryMetadata( metadata ) );
|
||||||
|
|
||||||
|
if ( metadataFile.exists() )
|
||||||
{
|
{
|
||||||
|
Metadata pluginMap = readMetadata( metadataFile );
|
||||||
|
|
||||||
|
if ( pluginMap != null )
|
||||||
|
{
|
||||||
|
for ( Iterator pluginIterator = pluginMap.getPlugins().iterator(); pluginIterator.hasNext(); )
|
||||||
|
{
|
||||||
|
Plugin mapping = (Plugin) pluginIterator.next();
|
||||||
|
|
||||||
|
String prefix = mapping.getPrefix();
|
||||||
|
|
||||||
|
String artifactId = mapping.getArtifactId();
|
||||||
|
|
||||||
|
org.apache.maven.model.Plugin plugin = new org.apache.maven.model.Plugin();
|
||||||
|
|
||||||
|
plugin.setGroupId( groupId );
|
||||||
|
|
||||||
|
plugin.setArtifactId( artifactId );
|
||||||
|
|
||||||
|
pluginDefinitionsByPrefix.put( prefix, plugin );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static Metadata readMetadata( File mappingFile )
|
||||||
|
throws RepositoryMetadataManagementException
|
||||||
|
{
|
||||||
|
Metadata result;
|
||||||
|
|
||||||
Reader fileReader = null;
|
Reader fileReader = null;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
@ -198,70 +147,20 @@ public class DefaultPluginMappingManager
|
||||||
}
|
}
|
||||||
catch ( FileNotFoundException e )
|
catch ( FileNotFoundException e )
|
||||||
{
|
{
|
||||||
throw new RepositoryMetadataManagementException( "Cannot read plugin mappings from: " + mappingFile,
|
throw new RepositoryMetadataManagementException( "Cannot read plugin mappings from: " + mappingFile, e );
|
||||||
e );
|
|
||||||
}
|
}
|
||||||
catch ( IOException e )
|
catch ( IOException e )
|
||||||
{
|
{
|
||||||
throw new RepositoryMetadataManagementException( "Cannot read plugin mappings from: " + mappingFile,
|
throw new RepositoryMetadataManagementException( "Cannot read plugin mappings from: " + mappingFile, e );
|
||||||
e );
|
|
||||||
}
|
}
|
||||||
catch ( XmlPullParserException e )
|
catch ( XmlPullParserException e )
|
||||||
{
|
{
|
||||||
throw new RepositoryMetadataManagementException( "Cannot parse plugin mappings from: " + mappingFile,
|
throw new RepositoryMetadataManagementException( "Cannot parse plugin mappings from: " + mappingFile, e );
|
||||||
e );
|
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
IOUtil.close( fileReader );
|
IOUtil.close( fileReader );
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static File resolveMappingMetadata( RepositoryMetadataManager repositoryMetadataManager, String groupId,
|
|
||||||
List pluginRepositories, ArtifactRepository localRepository )
|
|
||||||
throws RepositoryMetadataManagementException
|
|
||||||
{
|
|
||||||
PluginMappingMetadata metadata = new PluginMappingMetadata( groupId );
|
|
||||||
|
|
||||||
RepositoryMetadataManagementException repositoryException = null;
|
|
||||||
|
|
||||||
for ( Iterator repoIterator = pluginRepositories.iterator(); repoIterator.hasNext(); )
|
|
||||||
{
|
|
||||||
ArtifactRepository repository = (ArtifactRepository) repoIterator.next();
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
repositoryMetadataManager.resolve( metadata, repository, localRepository );
|
|
||||||
|
|
||||||
// reset this to keep it from getting in the way when we succeed but not on first repo...
|
|
||||||
repositoryException = null;
|
|
||||||
|
|
||||||
File metadataFile = new File( localRepository.getBasedir(),
|
|
||||||
localRepository.pathOfRepositoryMetadata( metadata ) );
|
|
||||||
|
|
||||||
if ( metadataFile.exists() )
|
|
||||||
{
|
|
||||||
return metadataFile;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
catch ( InvalidRepositoryMetadataException e )
|
|
||||||
{
|
|
||||||
repositoryMetadataManager.purgeLocalCopy( metadata, localRepository );
|
|
||||||
}
|
|
||||||
catch ( RepositoryMetadataManagementException e )
|
|
||||||
{
|
|
||||||
repositoryException = e;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if ( repositoryException != null )
|
|
||||||
{
|
|
||||||
throw repositoryException;
|
|
||||||
}
|
|
||||||
|
|
||||||
throw new RepositoryMetadataManagementException( "No repository metadata found" );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,6 @@ package org.apache.maven.plugin.plugin.metadata;
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import org.apache.maven.artifact.repository.metadata.InvalidRepositoryMetadataException;
|
|
||||||
import org.apache.maven.artifact.repository.metadata.PluginMappingMetadata;
|
import org.apache.maven.artifact.repository.metadata.PluginMappingMetadata;
|
||||||
import org.apache.maven.artifact.repository.metadata.RepositoryMetadata;
|
import org.apache.maven.artifact.repository.metadata.RepositoryMetadata;
|
||||||
import org.apache.maven.artifact.repository.metadata.RepositoryMetadataManagementException;
|
import org.apache.maven.artifact.repository.metadata.RepositoryMetadataManagementException;
|
||||||
|
@ -39,15 +38,6 @@ public class PluginMappingInstallMojo
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
try
|
|
||||||
{
|
|
||||||
getRepositoryMetadataManager().resolveLocally( metadata, getLocalRepository() );
|
|
||||||
}
|
|
||||||
catch ( InvalidRepositoryMetadataException e )
|
|
||||||
{
|
|
||||||
getRepositoryMetadataManager().purgeLocalCopy( metadata, getLocalRepository() );
|
|
||||||
}
|
|
||||||
|
|
||||||
File metadataFile = updatePluginMap( metadata );
|
File metadataFile = updatePluginMap( metadata );
|
||||||
|
|
||||||
if ( metadataFile != null )
|
if ( metadataFile != null )
|
||||||
|
|
Loading…
Reference in New Issue