mirror of https://github.com/apache/archiva.git
[MRM-46] introduce modello configuration, change indexer API to use a File for the index path, introduce a core module for moving the main application logic to
git-svn-id: https://svn.apache.org/repos/asf/maven/repository-manager/trunk@412683 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
8532c8ed0a
commit
86db5311d4
|
@ -69,7 +69,7 @@ public class IndexCli
|
||||||
List artifacts = discoverer.discoverArtifacts( repository, null, false );
|
List artifacts = discoverer.discoverArtifacts( repository, null, false );
|
||||||
|
|
||||||
ArtifactRepositoryIndex index =
|
ArtifactRepositoryIndex index =
|
||||||
indexFactory.createArtifactRepositoryIndex( new File( args[0], ".index" ).getAbsolutePath(), repository );
|
indexFactory.createArtifactRepositoryIndex( new File( args[0], ".index" ), repository );
|
||||||
|
|
||||||
long time = System.currentTimeMillis();
|
long time = System.currentTimeMillis();
|
||||||
try
|
try
|
||||||
|
|
|
@ -65,7 +65,7 @@ public class IndexSearcherCli
|
||||||
layout, null, null );
|
layout, null, null );
|
||||||
|
|
||||||
ArtifactRepositoryIndex index =
|
ArtifactRepositoryIndex index =
|
||||||
indexFactory.createArtifactRepositoryIndex( new File( args[0], ".index" ).getAbsolutePath(), repository );
|
indexFactory.createArtifactRepositoryIndex( new File( args[0], ".index" ), repository );
|
||||||
|
|
||||||
RepositoryIndexSearcher searcher = (RepositoryIndexSearcher) embedder.lookup( RepositoryIndexSearcher.ROLE );
|
RepositoryIndexSearcher searcher = (RepositoryIndexSearcher) embedder.lookup( RepositoryIndexSearcher.ROLE );
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,40 @@
|
||||||
|
<?xml version="1.0"?>
|
||||||
|
<project>
|
||||||
|
<parent>
|
||||||
|
<artifactId>maven-repository-manager</artifactId>
|
||||||
|
<groupId>org.apache.maven.repository</groupId>
|
||||||
|
<version>1.0-SNAPSHOT</version>
|
||||||
|
</parent>
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
<groupId>org.apache.maven.repository</groupId>
|
||||||
|
<artifactId>maven-repository-configuration</artifactId>
|
||||||
|
<name>Maven Repository Manager Configuration</name>
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.codehaus.plexus</groupId>
|
||||||
|
<artifactId>plexus-utils</artifactId>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
<build>
|
||||||
|
<plugins>
|
||||||
|
<plugin>
|
||||||
|
<groupId>org.codehaus.modello</groupId>
|
||||||
|
<artifactId>modello-maven-plugin</artifactId>
|
||||||
|
<version>1.0-alpha-8</version>
|
||||||
|
<executions>
|
||||||
|
<execution>
|
||||||
|
<goals>
|
||||||
|
<goal>xpp3-writer</goal>
|
||||||
|
<goal>java</goal>
|
||||||
|
<goal>xpp3-reader</goal>
|
||||||
|
</goals>
|
||||||
|
</execution>
|
||||||
|
</executions>
|
||||||
|
<configuration>
|
||||||
|
<version>1.0.0</version>
|
||||||
|
<model>src/main/mdo/configuration.mdo</model>
|
||||||
|
</configuration>
|
||||||
|
</plugin>
|
||||||
|
</plugins>
|
||||||
|
</build>
|
||||||
|
</project>
|
|
@ -0,0 +1,82 @@
|
||||||
|
<model>
|
||||||
|
<id>configuration</id>
|
||||||
|
<name>Configuration</name>
|
||||||
|
<description>
|
||||||
|
Configuration for the Maven Repository Manager.
|
||||||
|
</description>
|
||||||
|
<defaults>
|
||||||
|
<default>
|
||||||
|
<key>package</key>
|
||||||
|
<value>org.apache.maven.repository.configuration</value>
|
||||||
|
</default>
|
||||||
|
</defaults>
|
||||||
|
<!-- TODO! break out subtypes such as <discovery> and create a list of blacklist -->
|
||||||
|
<classes>
|
||||||
|
<class rootElement="true" xml.tagName="configuration">
|
||||||
|
<name>Configuration</name>
|
||||||
|
<version>1.0.0</version>
|
||||||
|
<fields>
|
||||||
|
<field>
|
||||||
|
<name>repositoryDirectory</name>
|
||||||
|
<version>1.0.0</version>
|
||||||
|
<type>String</type>
|
||||||
|
<required>true</required>
|
||||||
|
<description>
|
||||||
|
The location of the repository to monitor.
|
||||||
|
</description>
|
||||||
|
</field>
|
||||||
|
<field>
|
||||||
|
<name>repositoryLayout</name>
|
||||||
|
<version>1.0.0</version>
|
||||||
|
<type>String</type>
|
||||||
|
<required>true</required>
|
||||||
|
<description>
|
||||||
|
The layout of the repository. Valid values are "default" and "legacy".
|
||||||
|
</description>
|
||||||
|
<!-- TODO: should be able to detect this from the repository (perhaps by metadata at the root) -->
|
||||||
|
<defaultValue>default</defaultValue>
|
||||||
|
</field>
|
||||||
|
<field>
|
||||||
|
<name>indexPath</name>
|
||||||
|
<version>1.0.0</version>
|
||||||
|
<type>String</type>
|
||||||
|
<description>
|
||||||
|
The location of the Lucene index to use for the repository. The default is the .index subdirectory of
|
||||||
|
the repository.
|
||||||
|
</description>
|
||||||
|
</field>
|
||||||
|
<field>
|
||||||
|
<name>minimalIndexPath</name>
|
||||||
|
<version>1.0.0</version>
|
||||||
|
<type>String</type>
|
||||||
|
<description>
|
||||||
|
The location of the reduced Lucene index to use for the repository. The default is the .small-index
|
||||||
|
subdirectory of the repository.
|
||||||
|
</description>
|
||||||
|
</field>
|
||||||
|
<field>
|
||||||
|
<name>discoveryCronExpression</name>
|
||||||
|
<version>1.0.0</version>
|
||||||
|
<type>String</type>
|
||||||
|
<description>When to run the discovery mechanism.</description>
|
||||||
|
<defaultValue>0 0 8 * * ?</defaultValue>
|
||||||
|
</field>
|
||||||
|
<field>
|
||||||
|
<name>discoverSnapshots</name>
|
||||||
|
<version>1.0.0</version>
|
||||||
|
<type>boolean</type>
|
||||||
|
<description>Whether to include snapshot versions in the discovery process</description>
|
||||||
|
<defaultValue>false</defaultValue>
|
||||||
|
</field>
|
||||||
|
<field>
|
||||||
|
<name>discoveryBlackListPatterns</name>
|
||||||
|
<version>1.0.0</version>
|
||||||
|
<type>String</type>
|
||||||
|
<description>Blacklisted patterns in the discovery process</description>
|
||||||
|
</field>
|
||||||
|
</fields>
|
||||||
|
</class>
|
||||||
|
</classes>
|
||||||
|
</model>
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,20 @@
|
||||||
|
<?xml version="1.0"?>
|
||||||
|
<project>
|
||||||
|
<parent>
|
||||||
|
<artifactId>maven-repository-manager</artifactId>
|
||||||
|
<groupId>org.apache.maven.repository</groupId>
|
||||||
|
<version>1.0-SNAPSHOT</version>
|
||||||
|
</parent>
|
||||||
|
<modelVersion>4.0.0</modelVersion>
|
||||||
|
<groupId>org.apache.maven.repository</groupId>
|
||||||
|
<artifactId>maven-repository-core</artifactId>
|
||||||
|
<name>Maven Repository Manager Core</name>
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>junit</groupId>
|
||||||
|
<artifactId>junit</artifactId>
|
||||||
|
<version>3.8.1</version>
|
||||||
|
<scope>test</scope>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
</project>
|
|
@ -41,7 +41,7 @@ public abstract class AbstractRepositoryIndex
|
||||||
implements RepositoryIndex
|
implements RepositoryIndex
|
||||||
{
|
{
|
||||||
// TODO: can this be derived from the repository? -- probably a sensible default, but still should be configurable, but this could just be on the call to open()
|
// TODO: can this be derived from the repository? -- probably a sensible default, but still should be configurable, but this could just be on the call to open()
|
||||||
private String indexPath;
|
private File indexPath;
|
||||||
|
|
||||||
private boolean indexOpen;
|
private boolean indexOpen;
|
||||||
|
|
||||||
|
@ -58,7 +58,7 @@ public abstract class AbstractRepositoryIndex
|
||||||
* @param indexPath
|
* @param indexPath
|
||||||
* @param repository
|
* @param repository
|
||||||
*/
|
*/
|
||||||
protected AbstractRepositoryIndex( String indexPath, ArtifactRepository repository )
|
protected AbstractRepositoryIndex( File indexPath, ArtifactRepository repository )
|
||||||
{
|
{
|
||||||
this.repository = repository;
|
this.repository = repository;
|
||||||
this.indexPath = indexPath;
|
this.indexPath = indexPath;
|
||||||
|
@ -144,7 +144,7 @@ public abstract class AbstractRepositoryIndex
|
||||||
/**
|
/**
|
||||||
* @see org.apache.maven.repository.indexing.RepositoryIndex#getIndexPath()
|
* @see org.apache.maven.repository.indexing.RepositoryIndex#getIndexPath()
|
||||||
*/
|
*/
|
||||||
public String getIndexPath()
|
public File getIndexPath()
|
||||||
{
|
{
|
||||||
return indexPath;
|
return indexPath;
|
||||||
}
|
}
|
||||||
|
@ -244,19 +244,17 @@ public abstract class AbstractRepositoryIndex
|
||||||
protected boolean indexExists()
|
protected boolean indexExists()
|
||||||
throws RepositoryIndexException
|
throws RepositoryIndexException
|
||||||
{
|
{
|
||||||
File indexDir = new File( indexPath );
|
if ( IndexReader.indexExists( indexPath ) )
|
||||||
|
|
||||||
if ( IndexReader.indexExists( indexDir ) )
|
|
||||||
{
|
{
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else if ( !indexDir.exists() )
|
else if ( !indexPath.exists() )
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
else if ( indexDir.isDirectory() )
|
else if ( indexPath.isDirectory() )
|
||||||
{
|
{
|
||||||
if ( indexDir.listFiles().length > 1 )
|
if ( indexPath.listFiles().length > 1 )
|
||||||
{
|
{
|
||||||
throw new RepositoryIndexException( indexPath + " is not a valid index directory." );
|
throw new RepositoryIndexException( indexPath + " is not a valid index directory." );
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,6 +22,7 @@ import org.apache.maven.artifact.Artifact;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepository;
|
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||||
import org.apache.maven.repository.digest.Digester;
|
import org.apache.maven.repository.digest.Digester;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
import java.io.FileNotFoundException;
|
import java.io.FileNotFoundException;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.security.NoSuchAlgorithmException;
|
import java.security.NoSuchAlgorithmException;
|
||||||
|
@ -48,7 +49,7 @@ public class ArtifactRepositoryIndex
|
||||||
* @param repository the repository where the indexed artifacts are located
|
* @param repository the repository where the indexed artifacts are located
|
||||||
* @param digester the digester object to generate the checksum strings
|
* @param digester the digester object to generate the checksum strings
|
||||||
*/
|
*/
|
||||||
public ArtifactRepositoryIndex( String indexPath, ArtifactRepository repository, Digester digester )
|
public ArtifactRepositoryIndex( File indexPath, ArtifactRepository repository, Digester digester )
|
||||||
{
|
{
|
||||||
super( indexPath, repository );
|
super( indexPath, repository );
|
||||||
this.digester = digester;
|
this.digester = digester;
|
||||||
|
|
|
@ -78,7 +78,7 @@ public class DefaultRepositoryIndexSearcher
|
||||||
IndexSearcher searcher;
|
IndexSearcher searcher;
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
searcher = new IndexSearcher( index.getIndexPath() );
|
searcher = new IndexSearcher( index.getIndexPath().getAbsolutePath() );
|
||||||
}
|
}
|
||||||
catch ( IOException e )
|
catch ( IOException e )
|
||||||
{
|
{
|
||||||
|
|
|
@ -20,6 +20,8 @@ import org.apache.maven.artifact.factory.ArtifactFactory;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepository;
|
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||||
import org.apache.maven.repository.digest.Digester;
|
import org.apache.maven.repository.digest.Digester;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Edwin Punzalan
|
* @author Edwin Punzalan
|
||||||
* @plexus.component role="org.apache.maven.repository.indexing.RepositoryIndexingFactory"
|
* @plexus.component role="org.apache.maven.repository.indexing.RepositoryIndexingFactory"
|
||||||
|
@ -37,28 +39,19 @@ public class DefaultRepositoryIndexingFactory
|
||||||
*/
|
*/
|
||||||
private ArtifactFactory artifactFactory;
|
private ArtifactFactory artifactFactory;
|
||||||
|
|
||||||
/**
|
public ArtifactRepositoryIndex createArtifactRepositoryIndex( File indexPath, ArtifactRepository repository )
|
||||||
* @see RepositoryIndexingFactory#createArtifactRepositoryIndex(String, org.apache.maven.artifact.repository.ArtifactRepository)
|
|
||||||
*/
|
|
||||||
public ArtifactRepositoryIndex createArtifactRepositoryIndex( String indexPath, ArtifactRepository repository )
|
|
||||||
throws RepositoryIndexException
|
throws RepositoryIndexException
|
||||||
{
|
{
|
||||||
return new ArtifactRepositoryIndex( indexPath, repository, digester );
|
return new ArtifactRepositoryIndex( indexPath, repository, digester );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public PomRepositoryIndex createPomRepositoryIndex( File indexPath, ArtifactRepository repository )
|
||||||
* @see RepositoryIndexingFactory#createPomRepositoryIndex(String, org.apache.maven.artifact.repository.ArtifactRepository)
|
|
||||||
*/
|
|
||||||
public PomRepositoryIndex createPomRepositoryIndex( String indexPath, ArtifactRepository repository )
|
|
||||||
throws RepositoryIndexException
|
throws RepositoryIndexException
|
||||||
{
|
{
|
||||||
return new PomRepositoryIndex( indexPath, repository, digester, artifactFactory );
|
return new PomRepositoryIndex( indexPath, repository, digester, artifactFactory );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public MetadataRepositoryIndex createMetadataRepositoryIndex( File indexPath, ArtifactRepository repository )
|
||||||
* @see RepositoryIndexingFactory#createMetadataRepositoryIndex(String, org.apache.maven.artifact.repository.ArtifactRepository)
|
|
||||||
*/
|
|
||||||
public MetadataRepositoryIndex createMetadataRepositoryIndex( String indexPath, ArtifactRepository repository )
|
|
||||||
throws RepositoryIndexException
|
throws RepositoryIndexException
|
||||||
{
|
{
|
||||||
return new MetadataRepositoryIndex( indexPath, repository );
|
return new MetadataRepositoryIndex( indexPath, repository );
|
||||||
|
|
|
@ -68,7 +68,7 @@ public class EclipseRepositoryIndex
|
||||||
* @param repository the repository where the indexed artifacts are located
|
* @param repository the repository where the indexed artifacts are located
|
||||||
* @param digester the digester object to generate the checksum strings
|
* @param digester the digester object to generate the checksum strings
|
||||||
*/
|
*/
|
||||||
public EclipseRepositoryIndex( String indexPath, ArtifactRepository repository, Digester digester )
|
public EclipseRepositoryIndex( File indexPath, ArtifactRepository repository, Digester digester )
|
||||||
{
|
{
|
||||||
super( indexPath, repository );
|
super( indexPath, repository );
|
||||||
|
|
||||||
|
@ -169,7 +169,7 @@ public class EclipseRepositoryIndex
|
||||||
public File getCompressedCopy()
|
public File getCompressedCopy()
|
||||||
throws IOException
|
throws IOException
|
||||||
{
|
{
|
||||||
File indexPath = new File( getIndexPath() );
|
File indexPath = getIndexPath();
|
||||||
String name = indexPath.getName();
|
String name = indexPath.getName();
|
||||||
|
|
||||||
File outputFile = new File( indexPath.getParent(), name + ".zip" );
|
File outputFile = new File( indexPath.getParent(), name + ".zip" );
|
||||||
|
|
|
@ -24,6 +24,7 @@ import org.apache.maven.artifact.repository.metadata.Plugin;
|
||||||
import org.apache.maven.artifact.repository.metadata.RepositoryMetadata;
|
import org.apache.maven.artifact.repository.metadata.RepositoryMetadata;
|
||||||
import org.apache.maven.artifact.repository.metadata.Versioning;
|
import org.apache.maven.artifact.repository.metadata.Versioning;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -40,7 +41,7 @@ public class MetadataRepositoryIndex
|
||||||
* @param indexPath the path to the index
|
* @param indexPath the path to the index
|
||||||
* @param repository the repository where the metadata to be indexed is located
|
* @param repository the repository where the metadata to be indexed is located
|
||||||
*/
|
*/
|
||||||
public MetadataRepositoryIndex( String indexPath, ArtifactRepository repository )
|
public MetadataRepositoryIndex( File indexPath, ArtifactRepository repository )
|
||||||
{
|
{
|
||||||
super( indexPath, repository );
|
super( indexPath, repository );
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,7 +56,7 @@ public class PomRepositoryIndex
|
||||||
* @param digester the digester to be used for generating checksums
|
* @param digester the digester to be used for generating checksums
|
||||||
* @param artifactFactory the factory for building artifact objects
|
* @param artifactFactory the factory for building artifact objects
|
||||||
*/
|
*/
|
||||||
public PomRepositoryIndex( String indexPath, ArtifactRepository repository, Digester digester,
|
public PomRepositoryIndex( File indexPath, ArtifactRepository repository, Digester digester,
|
||||||
ArtifactFactory artifactFactory )
|
ArtifactFactory artifactFactory )
|
||||||
{
|
{
|
||||||
super( indexPath, repository );
|
super( indexPath, repository );
|
||||||
|
|
|
@ -19,6 +19,7 @@ package org.apache.maven.repository.indexing;
|
||||||
import org.apache.lucene.analysis.Analyzer;
|
import org.apache.lucene.analysis.Analyzer;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepository;
|
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
@ -113,7 +114,7 @@ public interface RepositoryIndex
|
||||||
*
|
*
|
||||||
* @return the path where the index resides
|
* @return the path where the index resides
|
||||||
*/
|
*/
|
||||||
String getIndexPath();
|
File getIndexPath();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests an index field if it is a keyword field
|
* Tests an index field if it is a keyword field
|
||||||
|
|
|
@ -18,6 +18,8 @@ package org.apache.maven.repository.indexing;
|
||||||
|
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepository;
|
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Edwin Punzalan
|
* @author Edwin Punzalan
|
||||||
|
@ -34,7 +36,7 @@ public interface RepositoryIndexingFactory
|
||||||
* @return the ArtifactRepositoryIndex instance
|
* @return the ArtifactRepositoryIndex instance
|
||||||
* @throws RepositoryIndexException
|
* @throws RepositoryIndexException
|
||||||
*/
|
*/
|
||||||
ArtifactRepositoryIndex createArtifactRepositoryIndex( String indexPath, ArtifactRepository repository )
|
ArtifactRepositoryIndex createArtifactRepositoryIndex( File indexPath, ArtifactRepository repository )
|
||||||
throws RepositoryIndexException;
|
throws RepositoryIndexException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -45,7 +47,7 @@ public interface RepositoryIndexingFactory
|
||||||
* @return the PomRepositoryIndex instance
|
* @return the PomRepositoryIndex instance
|
||||||
* @throws RepositoryIndexException
|
* @throws RepositoryIndexException
|
||||||
*/
|
*/
|
||||||
PomRepositoryIndex createPomRepositoryIndex( String indexPath, ArtifactRepository repository )
|
PomRepositoryIndex createPomRepositoryIndex( File indexPath, ArtifactRepository repository )
|
||||||
throws RepositoryIndexException;
|
throws RepositoryIndexException;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -56,7 +58,7 @@ public interface RepositoryIndexingFactory
|
||||||
* @return the MetadataRepositoryIndex instance
|
* @return the MetadataRepositoryIndex instance
|
||||||
* @throws RepositoryIndexException
|
* @throws RepositoryIndexException
|
||||||
*/
|
*/
|
||||||
MetadataRepositoryIndex createMetadataRepositoryIndex( String indexPath, ArtifactRepository repository )
|
MetadataRepositoryIndex createMetadataRepositoryIndex( File indexPath, ArtifactRepository repository )
|
||||||
throws RepositoryIndexException;
|
throws RepositoryIndexException;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,7 +43,7 @@ public class ArtifactRepositoryIndexingTest
|
||||||
|
|
||||||
private ArtifactRepository repository;
|
private ArtifactRepository repository;
|
||||||
|
|
||||||
private String indexPath;
|
private File indexPath;
|
||||||
|
|
||||||
private Digester digester;
|
private Digester digester;
|
||||||
|
|
||||||
|
@ -59,7 +59,7 @@ public class ArtifactRepositoryIndexingTest
|
||||||
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
|
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
|
||||||
digester = new DefaultDigester();
|
digester = new DefaultDigester();
|
||||||
|
|
||||||
indexPath = "target/index";
|
indexPath = getTestFile( "target/index" );
|
||||||
FileUtils.deleteDirectory( indexPath );
|
FileUtils.deleteDirectory( indexPath );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -77,7 +77,7 @@ public class ArtifactRepositoryIndexingTest
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
String notIndexDir = new File( "pom.xml" ).getAbsolutePath();
|
File notIndexDir = new File( "pom.xml" );
|
||||||
ArtifactRepositoryIndex indexer = factory.createArtifactRepositoryIndex( notIndexDir, repository );
|
ArtifactRepositoryIndex indexer = factory.createArtifactRepositoryIndex( notIndexDir, repository );
|
||||||
indexer.indexArtifact( artifact );
|
indexer.indexArtifact( artifact );
|
||||||
fail( "Must throw exception on non-directory index directory" );
|
fail( "Must throw exception on non-directory index directory" );
|
||||||
|
@ -89,7 +89,7 @@ public class ArtifactRepositoryIndexingTest
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
String notIndexDir = new File( "" ).getAbsolutePath();
|
File notIndexDir = new File( "" );
|
||||||
ArtifactRepositoryIndex indexer = factory.createArtifactRepositoryIndex( notIndexDir, repository );
|
ArtifactRepositoryIndex indexer = factory.createArtifactRepositoryIndex( notIndexDir, repository );
|
||||||
indexer.indexArtifact( artifact );
|
indexer.indexArtifact( artifact );
|
||||||
fail( "Must throw an exception on a non-index directory" );
|
fail( "Must throw an exception on a non-index directory" );
|
||||||
|
@ -433,7 +433,7 @@ public class ArtifactRepositoryIndexingTest
|
||||||
assertTrue( true );
|
assertTrue( true );
|
||||||
}
|
}
|
||||||
|
|
||||||
indexer = factory.createArtifactRepositoryIndex( "target/index/sample", repository );
|
indexer = factory.createArtifactRepositoryIndex( getTestFile( "target/index/sample" ), repository );
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
|
|
@ -43,7 +43,7 @@ public class EclipseRepositoryIndexTest
|
||||||
|
|
||||||
private ArtifactRepository repository;
|
private ArtifactRepository repository;
|
||||||
|
|
||||||
private String indexPath;
|
private File indexPath;
|
||||||
|
|
||||||
private Digester digester;
|
private Digester digester;
|
||||||
|
|
||||||
|
@ -63,7 +63,7 @@ public class EclipseRepositoryIndexTest
|
||||||
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
|
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
|
||||||
digester = new DefaultDigester();
|
digester = new DefaultDigester();
|
||||||
|
|
||||||
indexPath = "target/index";
|
indexPath = getTestFile( "target/index" );
|
||||||
FileUtils.deleteDirectory( indexPath );
|
FileUtils.deleteDirectory( indexPath );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -125,7 +125,7 @@ public class EclipseRepositoryIndexTest
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
String notIndexDir = new File( "pom.xml" ).getAbsolutePath();
|
File notIndexDir = new File( "pom.xml" );
|
||||||
EclipseRepositoryIndex indexer = new EclipseRepositoryIndex( notIndexDir, repository, digester );
|
EclipseRepositoryIndex indexer = new EclipseRepositoryIndex( notIndexDir, repository, digester );
|
||||||
indexer.indexArtifact( artifact );
|
indexer.indexArtifact( artifact );
|
||||||
fail( "Must throw exception on non-directory index directory" );
|
fail( "Must throw exception on non-directory index directory" );
|
||||||
|
@ -137,7 +137,7 @@ public class EclipseRepositoryIndexTest
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
String notIndexDir = new File( "" ).getAbsolutePath();
|
File notIndexDir = new File( "" );
|
||||||
EclipseRepositoryIndex indexer = new EclipseRepositoryIndex( notIndexDir, repository, digester );
|
EclipseRepositoryIndex indexer = new EclipseRepositoryIndex( notIndexDir, repository, digester );
|
||||||
indexer.indexArtifact( artifact );
|
indexer.indexArtifact( artifact );
|
||||||
fail( "Must throw an exception on a non-index directory" );
|
fail( "Must throw an exception on a non-index directory" );
|
||||||
|
@ -169,7 +169,7 @@ public class EclipseRepositoryIndexTest
|
||||||
{
|
{
|
||||||
EclipseRepositoryIndex index = createTestIndex();
|
EclipseRepositoryIndex index = createTestIndex();
|
||||||
|
|
||||||
IndexSearcher searcher = new IndexSearcher( index.getIndexPath() );
|
IndexSearcher searcher = new IndexSearcher( index.getIndexPath().getAbsolutePath() );
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
QueryParser parser = new QueryParser( "j", index.getAnalyzer() );
|
QueryParser parser = new QueryParser( "j", index.getAnalyzer() );
|
||||||
|
|
|
@ -52,7 +52,7 @@ public class MetadataRepositoryIndexingTest
|
||||||
{
|
{
|
||||||
private ArtifactRepository repository;
|
private ArtifactRepository repository;
|
||||||
|
|
||||||
private String indexPath;
|
private File indexPath;
|
||||||
|
|
||||||
private ArtifactFactory artifactFactory;
|
private ArtifactFactory artifactFactory;
|
||||||
|
|
||||||
|
@ -71,7 +71,7 @@ public class MetadataRepositoryIndexingTest
|
||||||
ArtifactRepositoryFactory repoFactory = (ArtifactRepositoryFactory) lookup( ArtifactRepositoryFactory.ROLE );
|
ArtifactRepositoryFactory repoFactory = (ArtifactRepositoryFactory) lookup( ArtifactRepositoryFactory.ROLE );
|
||||||
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
|
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
|
||||||
|
|
||||||
indexPath = "target/index";
|
indexPath = getTestFile( "target/index" );
|
||||||
FileUtils.deleteDirectory( indexPath );
|
FileUtils.deleteDirectory( indexPath );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -48,7 +48,7 @@ public class PomRepositoryIndexingTest
|
||||||
|
|
||||||
private ArtifactFactory artifactFactory;
|
private ArtifactFactory artifactFactory;
|
||||||
|
|
||||||
private String indexPath;
|
private File indexPath;
|
||||||
|
|
||||||
private Digester digester;
|
private Digester digester;
|
||||||
|
|
||||||
|
@ -64,7 +64,7 @@ public class PomRepositoryIndexingTest
|
||||||
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
|
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
|
||||||
digester = new DefaultDigester();
|
digester = new DefaultDigester();
|
||||||
|
|
||||||
indexPath = "target/index";
|
indexPath = getTestFile( "target/index" );
|
||||||
FileUtils.deleteDirectory( indexPath );
|
FileUtils.deleteDirectory( indexPath );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -77,7 +77,7 @@ public class PomRepositoryIndexingTest
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
String notIndexDir = new File( "pom.xml" ).getAbsolutePath();
|
File notIndexDir = new File( "pom.xml" );
|
||||||
PomRepositoryIndex indexer = factory.createPomRepositoryIndex( notIndexDir, repository );
|
PomRepositoryIndex indexer = factory.createPomRepositoryIndex( notIndexDir, repository );
|
||||||
indexer.indexPom( pom );
|
indexer.indexPom( pom );
|
||||||
fail( "Must throw exception on non-directory index directory" );
|
fail( "Must throw exception on non-directory index directory" );
|
||||||
|
@ -89,7 +89,7 @@ public class PomRepositoryIndexingTest
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
String notIndexDir = new File( "" ).getAbsolutePath();
|
File notIndexDir = new File( "" );
|
||||||
PomRepositoryIndex indexer = factory.createPomRepositoryIndex( notIndexDir, repository );
|
PomRepositoryIndex indexer = factory.createPomRepositoryIndex( notIndexDir, repository );
|
||||||
indexer.indexPom( pom );
|
indexer.indexPom( pom );
|
||||||
fail( "Must throw an exception on a non-index directory" );
|
fail( "Must throw an exception on a non-index directory" );
|
||||||
|
|
|
@ -54,7 +54,7 @@ public class RepositoryIndexSearchLayerTest
|
||||||
|
|
||||||
private ArtifactFactory artifactFactory;
|
private ArtifactFactory artifactFactory;
|
||||||
|
|
||||||
private String indexPath;
|
private File indexPath;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Setup method
|
* Setup method
|
||||||
|
@ -71,7 +71,7 @@ public class RepositoryIndexSearchLayerTest
|
||||||
ArtifactRepositoryFactory repoFactory = (ArtifactRepositoryFactory) lookup( ArtifactRepositoryFactory.ROLE );
|
ArtifactRepositoryFactory repoFactory = (ArtifactRepositoryFactory) lookup( ArtifactRepositoryFactory.ROLE );
|
||||||
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
|
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
|
||||||
|
|
||||||
indexPath = "target/index";
|
indexPath = getTestFile( "target/index" );
|
||||||
FileUtils.deleteDirectory( indexPath );
|
FileUtils.deleteDirectory( indexPath );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -68,8 +68,8 @@ public class DuplicateArtifactFileReportProcessor
|
||||||
{
|
{
|
||||||
if ( artifact.getFile() != null )
|
if ( artifact.getFile() != null )
|
||||||
{
|
{
|
||||||
//@todo remove hard-coded value; current value enables tests to pass
|
//@todo remove hard-coded value; current value enables tests to pass!
|
||||||
String indexPath = new File( "target/.index" ).getAbsolutePath();
|
File indexPath = new File( "target/.index" );
|
||||||
|
|
||||||
RepositoryIndex index;
|
RepositoryIndex index;
|
||||||
try
|
try
|
||||||
|
|
|
@ -41,7 +41,7 @@ public class DuplicateArtifactFileReportProcessorTest
|
||||||
|
|
||||||
private ArtifactFactory artifactFactory;
|
private ArtifactFactory artifactFactory;
|
||||||
|
|
||||||
private String indexPath = new File( "target/.index" ).getAbsolutePath();
|
private File indexPath = getTestFile( "target/.index" );
|
||||||
|
|
||||||
protected void setUp()
|
protected void setUp()
|
||||||
throws Exception
|
throws Exception
|
||||||
|
|
|
@ -50,6 +50,10 @@
|
||||||
<groupId>org.apache.maven.repository</groupId>
|
<groupId>org.apache.maven.repository</groupId>
|
||||||
<artifactId>maven-repository-discovery</artifactId>
|
<artifactId>maven-repository-discovery</artifactId>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.apache.maven.repository</groupId>
|
||||||
|
<artifactId>maven-repository-configuration</artifactId>
|
||||||
|
</dependency>
|
||||||
<dependency>
|
<dependency>
|
||||||
<groupId>org.apache.maven.repository</groupId>
|
<groupId>org.apache.maven.repository</groupId>
|
||||||
<artifactId>maven-repository-artifact-applet</artifactId>
|
<artifactId>maven-repository-artifact-applet</artifactId>
|
||||||
|
|
|
@ -17,9 +17,12 @@ package org.apache.maven.repository.manager.web.action;
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import com.opensymphony.xwork.Action;
|
import com.opensymphony.xwork.Action;
|
||||||
|
import org.apache.maven.repository.configuration.Configuration;
|
||||||
import org.apache.maven.repository.manager.web.execution.DiscovererExecution;
|
import org.apache.maven.repository.manager.web.execution.DiscovererExecution;
|
||||||
import org.apache.maven.repository.manager.web.job.DiscovererScheduler;
|
import org.apache.maven.repository.manager.web.job.DiscovererScheduler;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is the Action class of index.jsp, which is the initial page of the web application.
|
* This is the Action class of index.jsp, which is the initial page of the web application.
|
||||||
* It invokes the DiscovererScheduler to set the DiscoverJob in the scheduler.
|
* It invokes the DiscovererScheduler to set the DiscoverJob in the scheduler.
|
||||||
|
@ -48,8 +51,9 @@ public class BaseAction
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
execution.executeDiscovererIfIndexDoesNotExist();
|
Configuration configuration = new Configuration(); // TODO!
|
||||||
discovererScheduler.setSchedule();
|
execution.executeDiscovererIfIndexDoesNotExist( new File( configuration.getIndexPath() ) );
|
||||||
|
discovererScheduler.setSchedule( configuration.getDiscoveryCronExpression() );
|
||||||
}
|
}
|
||||||
catch ( Exception e )
|
catch ( Exception e )
|
||||||
{
|
{
|
||||||
|
|
|
@ -19,16 +19,18 @@ package org.apache.maven.repository.manager.web.action;
|
||||||
import com.opensymphony.xwork.Action;
|
import com.opensymphony.xwork.Action;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepository;
|
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepositoryFactory;
|
import org.apache.maven.artifact.repository.ArtifactRepositoryFactory;
|
||||||
|
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
|
||||||
|
import org.apache.maven.repository.configuration.Configuration;
|
||||||
import org.apache.maven.repository.indexing.ArtifactRepositoryIndex;
|
import org.apache.maven.repository.indexing.ArtifactRepositoryIndex;
|
||||||
import org.apache.maven.repository.indexing.RepositoryIndexException;
|
import org.apache.maven.repository.indexing.RepositoryIndexException;
|
||||||
import org.apache.maven.repository.indexing.RepositoryIndexSearchException;
|
import org.apache.maven.repository.indexing.RepositoryIndexSearchException;
|
||||||
import org.apache.maven.repository.indexing.RepositoryIndexSearchLayer;
|
import org.apache.maven.repository.indexing.RepositoryIndexSearchLayer;
|
||||||
import org.apache.maven.repository.indexing.RepositoryIndexingFactory;
|
import org.apache.maven.repository.indexing.RepositoryIndexingFactory;
|
||||||
import org.apache.maven.repository.manager.web.job.Configuration;
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.net.MalformedURLException;
|
import java.net.MalformedURLException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Searches for searchString in all indexed fields.
|
* Searches for searchString in all indexed fields.
|
||||||
|
@ -58,24 +60,26 @@ public class GeneralSearchAction
|
||||||
private ArtifactRepositoryFactory repositoryFactory;
|
private ArtifactRepositoryFactory repositoryFactory;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @plexus.requirement
|
* @plexus.requirement role="org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout"
|
||||||
*/
|
*/
|
||||||
private Configuration configuration;
|
private Map repositoryLayouts;
|
||||||
|
|
||||||
public String execute()
|
public String execute()
|
||||||
throws MalformedURLException, RepositoryIndexException, RepositoryIndexSearchException
|
throws MalformedURLException, RepositoryIndexException, RepositoryIndexSearchException
|
||||||
{
|
{
|
||||||
if ( searchString != null && searchString.length() != 0 )
|
if ( searchString != null && searchString.length() != 0 )
|
||||||
{
|
{
|
||||||
String indexPath = configuration.getIndexDirectory();
|
Configuration configuration = new Configuration(); // TODO!
|
||||||
|
File indexPath = new File( configuration.getIndexPath() );
|
||||||
// TODO: reduce the amount of lookup?
|
|
||||||
|
|
||||||
|
// TODO: [!] repository should only have been instantiated once
|
||||||
File repositoryDirectory = new File( configuration.getRepositoryDirectory() );
|
File repositoryDirectory = new File( configuration.getRepositoryDirectory() );
|
||||||
String repoDir = repositoryDirectory.toURL().toString();
|
String repoDir = repositoryDirectory.toURL().toString();
|
||||||
|
|
||||||
|
ArtifactRepositoryLayout layout =
|
||||||
|
(ArtifactRepositoryLayout) repositoryLayouts.get( configuration.getRepositoryLayout() );
|
||||||
ArtifactRepository repository =
|
ArtifactRepository repository =
|
||||||
repositoryFactory.createArtifactRepository( "test", repoDir, configuration.getLayout(), null, null );
|
repositoryFactory.createArtifactRepository( "test", repoDir, layout, null, null );
|
||||||
|
|
||||||
ArtifactRepositoryIndex index = factory.createArtifactRepositoryIndex( indexPath, repository );
|
ArtifactRepositoryIndex index = factory.createArtifactRepositoryIndex( indexPath, repository );
|
||||||
|
|
||||||
|
|
|
@ -19,6 +19,8 @@ package org.apache.maven.repository.manager.web.action;
|
||||||
import com.opensymphony.xwork.Action;
|
import com.opensymphony.xwork.Action;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepository;
|
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||||
import org.apache.maven.artifact.repository.ArtifactRepositoryFactory;
|
import org.apache.maven.artifact.repository.ArtifactRepositoryFactory;
|
||||||
|
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
|
||||||
|
import org.apache.maven.repository.configuration.Configuration;
|
||||||
import org.apache.maven.repository.indexing.ArtifactRepositoryIndex;
|
import org.apache.maven.repository.indexing.ArtifactRepositoryIndex;
|
||||||
import org.apache.maven.repository.indexing.RepositoryIndex;
|
import org.apache.maven.repository.indexing.RepositoryIndex;
|
||||||
import org.apache.maven.repository.indexing.RepositoryIndexException;
|
import org.apache.maven.repository.indexing.RepositoryIndexException;
|
||||||
|
@ -26,11 +28,11 @@ import org.apache.maven.repository.indexing.RepositoryIndexSearchException;
|
||||||
import org.apache.maven.repository.indexing.RepositoryIndexSearchLayer;
|
import org.apache.maven.repository.indexing.RepositoryIndexSearchLayer;
|
||||||
import org.apache.maven.repository.indexing.RepositoryIndexingFactory;
|
import org.apache.maven.repository.indexing.RepositoryIndexingFactory;
|
||||||
import org.apache.maven.repository.indexing.query.SinglePhraseQuery;
|
import org.apache.maven.repository.indexing.query.SinglePhraseQuery;
|
||||||
import org.apache.maven.repository.manager.web.job.Configuration;
|
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.net.MalformedURLException;
|
import java.net.MalformedURLException;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Search by package name.
|
* Search by package name.
|
||||||
|
@ -52,6 +54,11 @@ public class PackageSearchAction
|
||||||
*/
|
*/
|
||||||
private RepositoryIndexingFactory factory;
|
private RepositoryIndexingFactory factory;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @plexus.requirement role="org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout"
|
||||||
|
*/
|
||||||
|
private Map repositoryLayouts;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @plexus.requirement
|
* @plexus.requirement
|
||||||
*/
|
*/
|
||||||
|
@ -62,11 +69,6 @@ public class PackageSearchAction
|
||||||
*/
|
*/
|
||||||
private RepositoryIndexSearchLayer searchLayer;
|
private RepositoryIndexSearchLayer searchLayer;
|
||||||
|
|
||||||
/**
|
|
||||||
* @plexus.requirement
|
|
||||||
*/
|
|
||||||
private Configuration configuration;
|
|
||||||
|
|
||||||
public String execute()
|
public String execute()
|
||||||
throws MalformedURLException, RepositoryIndexException, RepositoryIndexSearchException
|
throws MalformedURLException, RepositoryIndexException, RepositoryIndexSearchException
|
||||||
{
|
{
|
||||||
|
@ -87,15 +89,17 @@ public class PackageSearchAction
|
||||||
return ERROR;
|
return ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: better config [!]
|
// TODO: better config - share with general [!]
|
||||||
String indexPath = configuration.getIndexDirectory();
|
Configuration configuration = new Configuration();
|
||||||
|
File indexPath = new File( configuration.getIndexPath() );
|
||||||
|
|
||||||
// TODO: reduce the amount of lookup?
|
|
||||||
File repositoryDirectory = new File( configuration.getRepositoryDirectory() );
|
File repositoryDirectory = new File( configuration.getRepositoryDirectory() );
|
||||||
String repoDir = repositoryDirectory.toURL().toString();
|
String repoDir = repositoryDirectory.toURL().toString();
|
||||||
|
|
||||||
|
ArtifactRepositoryLayout layout =
|
||||||
|
(ArtifactRepositoryLayout) repositoryLayouts.get( configuration.getRepositoryLayout() );
|
||||||
ArtifactRepository repository =
|
ArtifactRepository repository =
|
||||||
repositoryFactory.createArtifactRepository( "repository", repoDir, configuration.getLayout(), null, null );
|
repositoryFactory.createArtifactRepository( "repository", repoDir, layout, null, null );
|
||||||
|
|
||||||
ArtifactRepositoryIndex index = factory.createArtifactRepositoryIndex( indexPath, repository );
|
ArtifactRepositoryIndex index = factory.createArtifactRepositoryIndex( indexPath, repository );
|
||||||
|
|
||||||
|
|
|
@ -24,6 +24,7 @@ import org.apache.maven.artifact.repository.DefaultArtifactRepositoryFactory;
|
||||||
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
|
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
|
||||||
import org.apache.maven.artifact.repository.metadata.RepositoryMetadata;
|
import org.apache.maven.artifact.repository.metadata.RepositoryMetadata;
|
||||||
import org.apache.maven.model.Model;
|
import org.apache.maven.model.Model;
|
||||||
|
import org.apache.maven.repository.configuration.Configuration;
|
||||||
import org.apache.maven.repository.discovery.ArtifactDiscoverer;
|
import org.apache.maven.repository.discovery.ArtifactDiscoverer;
|
||||||
import org.apache.maven.repository.discovery.MetadataDiscoverer;
|
import org.apache.maven.repository.discovery.MetadataDiscoverer;
|
||||||
import org.apache.maven.repository.indexing.ArtifactRepositoryIndex;
|
import org.apache.maven.repository.indexing.ArtifactRepositoryIndex;
|
||||||
|
@ -31,7 +32,6 @@ import org.apache.maven.repository.indexing.MetadataRepositoryIndex;
|
||||||
import org.apache.maven.repository.indexing.PomRepositoryIndex;
|
import org.apache.maven.repository.indexing.PomRepositoryIndex;
|
||||||
import org.apache.maven.repository.indexing.RepositoryIndexException;
|
import org.apache.maven.repository.indexing.RepositoryIndexException;
|
||||||
import org.apache.maven.repository.indexing.RepositoryIndexingFactory;
|
import org.apache.maven.repository.indexing.RepositoryIndexingFactory;
|
||||||
import org.apache.maven.repository.manager.web.job.Configuration;
|
|
||||||
import org.codehaus.plexus.logging.AbstractLogEnabled;
|
import org.codehaus.plexus.logging.AbstractLogEnabled;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
@ -39,7 +39,6 @@ import java.net.MalformedURLException;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Properties;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is the class that executes the discoverer and indexer.
|
* This is the class that executes the discoverer and indexer.
|
||||||
|
@ -50,10 +49,6 @@ import java.util.Properties;
|
||||||
public class DiscovererExecution
|
public class DiscovererExecution
|
||||||
extends AbstractLogEnabled
|
extends AbstractLogEnabled
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* @plexus.requirement
|
|
||||||
*/
|
|
||||||
private Configuration config;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @plexus.requirement role="org.apache.maven.repository.discovery.ArtifactDiscoverer"
|
* @plexus.requirement role="org.apache.maven.repository.discovery.ArtifactDiscoverer"
|
||||||
|
@ -75,19 +70,21 @@ public class DiscovererExecution
|
||||||
*/
|
*/
|
||||||
private ArtifactRepositoryFactory repoFactory;
|
private ArtifactRepositoryFactory repoFactory;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @plexus.requirement role="org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout"
|
||||||
|
*/
|
||||||
|
private Map repositoryLayouts;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Executes discoverer and indexer if an index does not exist yet
|
* Executes discoverer and indexer if an index does not exist yet
|
||||||
*
|
*
|
||||||
|
* @param indexDir
|
||||||
* @throws MalformedURLException
|
* @throws MalformedURLException
|
||||||
* @throws RepositoryIndexException
|
* @throws RepositoryIndexException
|
||||||
*/
|
*/
|
||||||
public void executeDiscovererIfIndexDoesNotExist()
|
public void executeDiscovererIfIndexDoesNotExist( File indexDir )
|
||||||
throws MalformedURLException, RepositoryIndexException
|
throws MalformedURLException, RepositoryIndexException
|
||||||
{
|
{
|
||||||
Properties props = config.getProperties();
|
|
||||||
String indexPath = props.getProperty( "index.path" );
|
|
||||||
|
|
||||||
File indexDir = new File( indexPath );
|
|
||||||
boolean isExisting = false;
|
boolean isExisting = false;
|
||||||
|
|
||||||
if ( IndexReader.indexExists( indexDir ) )
|
if ( IndexReader.indexExists( indexDir ) )
|
||||||
|
@ -107,27 +104,26 @@ public class DiscovererExecution
|
||||||
public void executeDiscoverer()
|
public void executeDiscoverer()
|
||||||
throws MalformedURLException, RepositoryIndexException
|
throws MalformedURLException, RepositoryIndexException
|
||||||
{
|
{
|
||||||
Properties props = config.getProperties();
|
Configuration configuration = new Configuration(); // TODO!
|
||||||
String indexPath = props.getProperty( "index.path" );
|
File indexPath = new File( configuration.getIndexPath() );
|
||||||
String blacklistedPatterns = props.getProperty( "blacklist.patterns" );
|
String blacklistedPatterns = configuration.getDiscoveryBlackListPatterns();
|
||||||
boolean includeSnapshots = Boolean.valueOf( props.getProperty( "include.snapshots" ) ).booleanValue();
|
boolean includeSnapshots = configuration.isDiscoverSnapshots();
|
||||||
boolean convertSnapshots = Boolean.valueOf( props.getProperty( "convert.snapshots" ) ).booleanValue();
|
|
||||||
|
|
||||||
ArtifactRepository defaultRepository = getDefaultRepository();
|
ArtifactRepository defaultRepository = getDefaultRepository( configuration );
|
||||||
|
|
||||||
getLogger().info( "[DiscovererExecution] Started discovery and indexing.." );
|
getLogger().info( "[DiscovererExecution] Started discovery and indexing.." );
|
||||||
String layoutProperty = props.getProperty( "layout" );
|
String layoutProperty = configuration.getRepositoryLayout();
|
||||||
ArtifactDiscoverer discoverer = (ArtifactDiscoverer) artifactDiscoverers.get( layoutProperty );
|
ArtifactDiscoverer discoverer = (ArtifactDiscoverer) artifactDiscoverers.get( layoutProperty );
|
||||||
List artifacts = discoverer.discoverArtifacts( defaultRepository, blacklistedPatterns, includeSnapshots );
|
List artifacts = discoverer.discoverArtifacts( defaultRepository, blacklistedPatterns, includeSnapshots );
|
||||||
indexArtifact( artifacts, indexPath, defaultRepository );
|
indexArtifact( artifacts, indexPath, defaultRepository );
|
||||||
|
|
||||||
List models = discoverer.discoverStandalonePoms( defaultRepository, blacklistedPatterns, convertSnapshots );
|
List models = discoverer.discoverStandalonePoms( defaultRepository, blacklistedPatterns, includeSnapshots );
|
||||||
indexPom( models, indexPath, defaultRepository );
|
indexPom( models, indexPath, defaultRepository );
|
||||||
|
|
||||||
MetadataDiscoverer metadataDiscoverer = (MetadataDiscoverer) metadataDiscoverers.get( layoutProperty );
|
MetadataDiscoverer metadataDiscoverer = (MetadataDiscoverer) metadataDiscoverers.get( layoutProperty );
|
||||||
List metadataList =
|
List metadataList =
|
||||||
metadataDiscoverer.discoverMetadata( new File( defaultRepository.getBasedir() ), blacklistedPatterns );
|
metadataDiscoverer.discoverMetadata( new File( defaultRepository.getBasedir() ), blacklistedPatterns );
|
||||||
indexMetadata( metadataList, indexPath, new File( defaultRepository.getBasedir() ), config.getLayout() );
|
indexMetadata( metadataList, indexPath, defaultRepository );
|
||||||
getLogger().info( "[DiscovererExecution] Finished discovery and indexing." );
|
getLogger().info( "[DiscovererExecution] Finished discovery and indexing." );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -138,7 +134,7 @@ public class DiscovererExecution
|
||||||
* @param indexPath the path to the index file
|
* @param indexPath the path to the index file
|
||||||
* @param repository the repository where the artifacts are located
|
* @param repository the repository where the artifacts are located
|
||||||
*/
|
*/
|
||||||
protected void indexArtifact( List artifacts, String indexPath, ArtifactRepository repository )
|
protected void indexArtifact( List artifacts, File indexPath, ArtifactRepository repository )
|
||||||
throws RepositoryIndexException
|
throws RepositoryIndexException
|
||||||
{
|
{
|
||||||
ArtifactRepositoryIndex artifactIndex = indexFactory.createArtifactRepositoryIndex( indexPath, repository );
|
ArtifactRepositoryIndex artifactIndex = indexFactory.createArtifactRepositoryIndex( indexPath, repository );
|
||||||
|
@ -158,18 +154,12 @@ public class DiscovererExecution
|
||||||
/**
|
/**
|
||||||
* Index the metadata in the list
|
* Index the metadata in the list
|
||||||
*
|
*
|
||||||
* @param metadataList the metadata to be indexed
|
* @param metadataList the metadata to be indexed
|
||||||
* @param indexPath the path to the index file
|
* @param indexPath the path to the index file
|
||||||
* @param repositoryBase the repository where the metadata are located
|
|
||||||
*/
|
*/
|
||||||
protected void indexMetadata( List metadataList, String indexPath, File repositoryBase,
|
protected void indexMetadata( List metadataList, File indexPath, ArtifactRepository repository )
|
||||||
ArtifactRepositoryLayout layout )
|
|
||||||
throws RepositoryIndexException, MalformedURLException
|
throws RepositoryIndexException, MalformedURLException
|
||||||
{
|
{
|
||||||
String repoDir = repositoryBase.toURL().toString();
|
|
||||||
ArtifactRepository repository =
|
|
||||||
repoFactory.createArtifactRepository( "repository", repoDir, layout, null, null );
|
|
||||||
|
|
||||||
MetadataRepositoryIndex metadataIndex = indexFactory.createMetadataRepositoryIndex( indexPath, repository );
|
MetadataRepositoryIndex metadataIndex = indexFactory.createMetadataRepositoryIndex( indexPath, repository );
|
||||||
for ( Iterator iter = metadataList.iterator(); iter.hasNext(); )
|
for ( Iterator iter = metadataList.iterator(); iter.hasNext(); )
|
||||||
{
|
{
|
||||||
|
@ -191,7 +181,7 @@ public class DiscovererExecution
|
||||||
* @param indexPath the path to the index
|
* @param indexPath the path to the index
|
||||||
* @param repository the artifact repository where the poms were discovered
|
* @param repository the artifact repository where the poms were discovered
|
||||||
*/
|
*/
|
||||||
protected void indexPom( List models, String indexPath, ArtifactRepository repository )
|
protected void indexPom( List models, File indexPath, ArtifactRepository repository )
|
||||||
throws RepositoryIndexException
|
throws RepositoryIndexException
|
||||||
{
|
{
|
||||||
PomRepositoryIndex pomIndex = indexFactory.createPomRepositoryIndex( indexPath, repository );
|
PomRepositoryIndex pomIndex = indexFactory.createPomRepositoryIndex( indexPath, repository );
|
||||||
|
@ -214,33 +204,16 @@ public class DiscovererExecution
|
||||||
* @return an ArtifactRepository instance
|
* @return an ArtifactRepository instance
|
||||||
* @throws java.net.MalformedURLException
|
* @throws java.net.MalformedURLException
|
||||||
*/
|
*/
|
||||||
protected ArtifactRepository getDefaultRepository()
|
protected ArtifactRepository getDefaultRepository( Configuration configuration )
|
||||||
throws MalformedURLException
|
throws MalformedURLException
|
||||||
{
|
{
|
||||||
File repositoryDirectory = new File( config.getRepositoryDirectory() );
|
// TODO! share with general search action, should only instantiate once
|
||||||
|
File repositoryDirectory = new File( configuration.getRepositoryDirectory() );
|
||||||
String repoDir = repositoryDirectory.toURL().toString();
|
String repoDir = repositoryDirectory.toURL().toString();
|
||||||
ArtifactRepositoryFactory repoFactory = new DefaultArtifactRepositoryFactory();
|
ArtifactRepositoryFactory repoFactory = new DefaultArtifactRepositoryFactory();
|
||||||
|
|
||||||
return repoFactory.createArtifactRepository( "test", repoDir, config.getLayout(), null, null );
|
ArtifactRepositoryLayout layout =
|
||||||
}
|
(ArtifactRepositoryLayout) repositoryLayouts.get( configuration.getRepositoryLayout() );
|
||||||
|
return repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
|
||||||
/**
|
|
||||||
* Method that sets the configuration object
|
|
||||||
*
|
|
||||||
* @param config
|
|
||||||
*/
|
|
||||||
public void setConfiguration( Configuration config )
|
|
||||||
{
|
|
||||||
this.config = config;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the cofiguration
|
|
||||||
*
|
|
||||||
* @return a Configuration object that contains the configuration values
|
|
||||||
*/
|
|
||||||
public Configuration getConfiguration()
|
|
||||||
{
|
|
||||||
return config;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,99 +0,0 @@
|
||||||
package org.apache.maven.repository.manager.web.job;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Copyright 2005-2006 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
import org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout;
|
|
||||||
import org.apache.maven.artifact.repository.layout.DefaultRepositoryLayout;
|
|
||||||
import org.apache.maven.artifact.repository.layout.LegacyRepositoryLayout;
|
|
||||||
import org.codehaus.plexus.personality.plexus.lifecycle.phase.Initializable;
|
|
||||||
import org.codehaus.plexus.personality.plexus.lifecycle.phase.InitializationException;
|
|
||||||
|
|
||||||
import java.util.Properties;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This class contains the configuration values to be used by the scheduler
|
|
||||||
*
|
|
||||||
* @todo should not need to be initializable [!] Should have individual configuration items, and they could well be configured on the job itself, not in this class
|
|
||||||
*/
|
|
||||||
public class Configuration
|
|
||||||
implements Initializable
|
|
||||||
{
|
|
||||||
|
|
||||||
private Properties props;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @throws InitializationException
|
|
||||||
*/
|
|
||||||
public void initialize()
|
|
||||||
throws InitializationException
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set the properties object
|
|
||||||
*
|
|
||||||
* @param properties
|
|
||||||
*/
|
|
||||||
public void setProperties( Properties properties )
|
|
||||||
{
|
|
||||||
this.props = properties;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the properties object
|
|
||||||
*
|
|
||||||
* @return a Properties object that contains the configuration values
|
|
||||||
*/
|
|
||||||
public Properties getProperties()
|
|
||||||
{
|
|
||||||
return props;
|
|
||||||
}
|
|
||||||
|
|
||||||
public ArtifactRepositoryLayout getLayout()
|
|
||||||
{
|
|
||||||
// TODO: lookup from map [!]
|
|
||||||
ArtifactRepositoryLayout layout;
|
|
||||||
if ( "legacy".equals( props.getProperty( "layout" ) ) )
|
|
||||||
{
|
|
||||||
layout = new LegacyRepositoryLayout();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
layout = new DefaultRepositoryLayout();
|
|
||||||
}
|
|
||||||
return layout;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getIndexDirectory()
|
|
||||||
{
|
|
||||||
return props.getProperty( "index.path" );
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getRepositoryDirectory()
|
|
||||||
{
|
|
||||||
String repositoryDir = "";
|
|
||||||
if ( "default".equals( props.getProperty( "layout" ) ) )
|
|
||||||
{
|
|
||||||
repositoryDir = props.getProperty( "default.repository.dir" );
|
|
||||||
}
|
|
||||||
else if ( "legacy".equals( props.getProperty( "layout" ) ) )
|
|
||||||
{
|
|
||||||
repositoryDir = props.getProperty( "legacy.repository.dir" );
|
|
||||||
}
|
|
||||||
return repositoryDir;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -26,7 +26,6 @@ import org.quartz.JobDetail;
|
||||||
import org.quartz.SchedulerException;
|
import org.quartz.SchedulerException;
|
||||||
|
|
||||||
import java.text.ParseException;
|
import java.text.ParseException;
|
||||||
import java.util.Properties;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class sets the job to be executed in the plexus-quartz scheduler
|
* This class sets the job to be executed in the plexus-quartz scheduler
|
||||||
|
@ -36,11 +35,6 @@ import java.util.Properties;
|
||||||
public class DiscovererScheduler
|
public class DiscovererScheduler
|
||||||
extends AbstractLogEnabled
|
extends AbstractLogEnabled
|
||||||
{
|
{
|
||||||
/**
|
|
||||||
* @plexus.requirement
|
|
||||||
*/
|
|
||||||
private Configuration config;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @plexus.requirement
|
* @plexus.requirement
|
||||||
*/
|
*/
|
||||||
|
@ -54,43 +48,20 @@ public class DiscovererScheduler
|
||||||
/**
|
/**
|
||||||
* Method that sets the schedule in the plexus-quartz scheduler
|
* Method that sets the schedule in the plexus-quartz scheduler
|
||||||
*
|
*
|
||||||
|
* @param cronExpression
|
||||||
* @throws ParseException
|
* @throws ParseException
|
||||||
* @throws SchedulerException
|
* @throws SchedulerException
|
||||||
*/
|
*/
|
||||||
public void setSchedule()
|
public void setSchedule( String cronExpression )
|
||||||
throws ParseException, SchedulerException
|
throws ParseException, SchedulerException
|
||||||
{
|
{
|
||||||
Properties props = config.getProperties();
|
|
||||||
JobDetail jobDetail = new JobDetail( "discovererJob", "DISCOVERER", DiscovererJob.class );
|
JobDetail jobDetail = new JobDetail( "discovererJob", "DISCOVERER", DiscovererJob.class );
|
||||||
JobDataMap dataMap = new JobDataMap();
|
JobDataMap dataMap = new JobDataMap();
|
||||||
dataMap.put( AbstractJob.LOGGER, getLogger() );
|
dataMap.put( AbstractJob.LOGGER, getLogger() );
|
||||||
dataMap.put( DiscovererJob.MAP_DISCOVERER_EXECUTION, execution );
|
dataMap.put( DiscovererJob.MAP_DISCOVERER_EXECUTION, execution );
|
||||||
jobDetail.setJobDataMap( dataMap );
|
jobDetail.setJobDataMap( dataMap );
|
||||||
|
|
||||||
CronTrigger trigger =
|
CronTrigger trigger = new CronTrigger( "DiscovererTrigger", "DISCOVERER", cronExpression );
|
||||||
new CronTrigger( "DiscovererTrigger", "DISCOVERER", props.getProperty( "cron.expression" ) );
|
|
||||||
scheduler.scheduleJob( jobDetail, trigger );
|
scheduler.scheduleJob( jobDetail, trigger );
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Method that sets the configuration object
|
|
||||||
*
|
|
||||||
* @param config
|
|
||||||
*/
|
|
||||||
public void setConfiguration( Configuration config )
|
|
||||||
{
|
|
||||||
this.config = config;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Returns the cofiguration
|
|
||||||
*
|
|
||||||
* @return a Configuration object that contains the configuration values
|
|
||||||
*/
|
|
||||||
public Configuration getConfiguration()
|
|
||||||
{
|
|
||||||
return config;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -41,47 +41,6 @@
|
||||||
<implementation>org.codehaus.plexus.xwork.PlexusObjectFactory</implementation>
|
<implementation>org.codehaus.plexus.xwork.PlexusObjectFactory</implementation>
|
||||||
</component>
|
</component>
|
||||||
|
|
||||||
<component>
|
|
||||||
<role>org.apache.maven.repository.manager.web.job.Configuration</role>
|
|
||||||
<implementation>org.apache.maven.repository.manager.web.job.Configuration</implementation>
|
|
||||||
<configuration>
|
|
||||||
<properties>
|
|
||||||
<property>
|
|
||||||
<name>layout</name>
|
|
||||||
<value>default</value>
|
|
||||||
</property>
|
|
||||||
<property>
|
|
||||||
<name>default.repository.dir</name>
|
|
||||||
<value>C:/TEST_REPOS/.m2/repository/</value>
|
|
||||||
</property>
|
|
||||||
<property>
|
|
||||||
<name>legacy.repository.dir</name>
|
|
||||||
<value>C:/TEST_REPOS/.maven/repository/</value>
|
|
||||||
</property>
|
|
||||||
<property>
|
|
||||||
<name>index.path</name>
|
|
||||||
<value>C:/INDEX</value>
|
|
||||||
</property>
|
|
||||||
<property>
|
|
||||||
<name>cron.expression</name>
|
|
||||||
<value>0 0 8 * * ?</value>
|
|
||||||
</property>
|
|
||||||
<property>
|
|
||||||
<name>blacklist.patterns</name>
|
|
||||||
<value>null</value>
|
|
||||||
</property>
|
|
||||||
<property>
|
|
||||||
<name>include.snapshots</name>
|
|
||||||
<value>true</value>
|
|
||||||
</property>
|
|
||||||
<property>
|
|
||||||
<name>convert.snapshots</name>
|
|
||||||
<value>true</value>
|
|
||||||
</property>
|
|
||||||
</properties>
|
|
||||||
</configuration>
|
|
||||||
</component>
|
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
| Logger manager
|
| Logger manager
|
||||||
-->
|
-->
|
||||||
|
|
13
pom.xml
13
pom.xml
|
@ -14,9 +14,7 @@
|
||||||
~ See the License for the specific language governing permissions and
|
~ See the License for the specific language governing permissions and
|
||||||
~ limitations under the License.
|
~ limitations under the License.
|
||||||
-->
|
-->
|
||||||
|
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
||||||
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
|
||||||
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
|
|
||||||
<modelVersion>4.0.0</modelVersion>
|
<modelVersion>4.0.0</modelVersion>
|
||||||
<parent>
|
<parent>
|
||||||
<groupId>org.apache.maven</groupId>
|
<groupId>org.apache.maven</groupId>
|
||||||
|
@ -120,6 +118,8 @@
|
||||||
<module>maven-repository-webapp</module>
|
<module>maven-repository-webapp</module>
|
||||||
<module>maven-repository-proxy</module>
|
<module>maven-repository-proxy</module>
|
||||||
<module>maven-repository-manager-site</module>
|
<module>maven-repository-manager-site</module>
|
||||||
|
<module>maven-repository-core</module>
|
||||||
|
<module>maven-repository-configuration</module>
|
||||||
</modules>
|
</modules>
|
||||||
<dependencies>
|
<dependencies>
|
||||||
<dependency>
|
<dependency>
|
||||||
|
@ -211,6 +211,11 @@
|
||||||
<artifactId>maven-repository-artifact-applet</artifactId>
|
<artifactId>maven-repository-artifact-applet</artifactId>
|
||||||
<version>${pom.version}</version>
|
<version>${pom.version}</version>
|
||||||
</dependency>
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.apache.maven.repository</groupId>
|
||||||
|
<artifactId>maven-repository-configuration</artifactId>
|
||||||
|
<version>${pom.version}</version>
|
||||||
|
</dependency>
|
||||||
</dependencies>
|
</dependencies>
|
||||||
</dependencyManagement>
|
</dependencyManagement>
|
||||||
<reporting>
|
<reporting>
|
||||||
|
@ -329,4 +334,4 @@
|
||||||
</build>
|
</build>
|
||||||
</profile>
|
</profile>
|
||||||
</profiles>
|
</profiles>
|
||||||
</project>
|
</project>
|
Loading…
Reference in New Issue