[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:
Brett Porter 2006-06-08 07:15:34 +00:00
parent 8532c8ed0a
commit 86db5311d4
30 changed files with 266 additions and 303 deletions

View File

@ -69,7 +69,7 @@ public class IndexCli
List artifacts = discoverer.discoverArtifacts( repository, null, false );
ArtifactRepositoryIndex index =
indexFactory.createArtifactRepositoryIndex( new File( args[0], ".index" ).getAbsolutePath(), repository );
indexFactory.createArtifactRepositoryIndex( new File( args[0], ".index" ), repository );
long time = System.currentTimeMillis();
try

View File

@ -65,7 +65,7 @@ public class IndexSearcherCli
layout, null, null );
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 );

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -41,7 +41,7 @@ public abstract class AbstractRepositoryIndex
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()
private String indexPath;
private File indexPath;
private boolean indexOpen;
@ -58,7 +58,7 @@ public abstract class AbstractRepositoryIndex
* @param indexPath
* @param repository
*/
protected AbstractRepositoryIndex( String indexPath, ArtifactRepository repository )
protected AbstractRepositoryIndex( File indexPath, ArtifactRepository repository )
{
this.repository = repository;
this.indexPath = indexPath;
@ -144,7 +144,7 @@ public abstract class AbstractRepositoryIndex
/**
* @see org.apache.maven.repository.indexing.RepositoryIndex#getIndexPath()
*/
public String getIndexPath()
public File getIndexPath()
{
return indexPath;
}
@ -244,19 +244,17 @@ public abstract class AbstractRepositoryIndex
protected boolean indexExists()
throws RepositoryIndexException
{
File indexDir = new File( indexPath );
if ( IndexReader.indexExists( indexDir ) )
if ( IndexReader.indexExists( indexPath ) )
{
return true;
}
else if ( !indexDir.exists() )
else if ( !indexPath.exists() )
{
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." );
}

View File

@ -22,6 +22,7 @@ import org.apache.maven.artifact.Artifact;
import org.apache.maven.artifact.repository.ArtifactRepository;
import org.apache.maven.repository.digest.Digester;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.security.NoSuchAlgorithmException;
@ -48,7 +49,7 @@ public class ArtifactRepositoryIndex
* @param repository the repository where the indexed artifacts are located
* @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 );
this.digester = digester;

View File

@ -78,7 +78,7 @@ public class DefaultRepositoryIndexSearcher
IndexSearcher searcher;
try
{
searcher = new IndexSearcher( index.getIndexPath() );
searcher = new IndexSearcher( index.getIndexPath().getAbsolutePath() );
}
catch ( IOException e )
{

View File

@ -20,6 +20,8 @@ import org.apache.maven.artifact.factory.ArtifactFactory;
import org.apache.maven.artifact.repository.ArtifactRepository;
import org.apache.maven.repository.digest.Digester;
import java.io.File;
/**
* @author Edwin Punzalan
* @plexus.component role="org.apache.maven.repository.indexing.RepositoryIndexingFactory"
@ -37,28 +39,19 @@ public class DefaultRepositoryIndexingFactory
*/
private ArtifactFactory artifactFactory;
/**
* @see RepositoryIndexingFactory#createArtifactRepositoryIndex(String, org.apache.maven.artifact.repository.ArtifactRepository)
*/
public ArtifactRepositoryIndex createArtifactRepositoryIndex( String indexPath, ArtifactRepository repository )
public ArtifactRepositoryIndex createArtifactRepositoryIndex( File indexPath, ArtifactRepository repository )
throws RepositoryIndexException
{
return new ArtifactRepositoryIndex( indexPath, repository, digester );
}
/**
* @see RepositoryIndexingFactory#createPomRepositoryIndex(String, org.apache.maven.artifact.repository.ArtifactRepository)
*/
public PomRepositoryIndex createPomRepositoryIndex( String indexPath, ArtifactRepository repository )
public PomRepositoryIndex createPomRepositoryIndex( File indexPath, ArtifactRepository repository )
throws RepositoryIndexException
{
return new PomRepositoryIndex( indexPath, repository, digester, artifactFactory );
}
/**
* @see RepositoryIndexingFactory#createMetadataRepositoryIndex(String, org.apache.maven.artifact.repository.ArtifactRepository)
*/
public MetadataRepositoryIndex createMetadataRepositoryIndex( String indexPath, ArtifactRepository repository )
public MetadataRepositoryIndex createMetadataRepositoryIndex( File indexPath, ArtifactRepository repository )
throws RepositoryIndexException
{
return new MetadataRepositoryIndex( indexPath, repository );

View File

@ -68,7 +68,7 @@ public class EclipseRepositoryIndex
* @param repository the repository where the indexed artifacts are located
* @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 );
@ -169,7 +169,7 @@ public class EclipseRepositoryIndex
public File getCompressedCopy()
throws IOException
{
File indexPath = new File( getIndexPath() );
File indexPath = getIndexPath();
String name = indexPath.getName();
File outputFile = new File( indexPath.getParent(), name + ".zip" );

View File

@ -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.Versioning;
import java.io.File;
import java.io.IOException;
import java.util.Iterator;
import java.util.List;
@ -40,7 +41,7 @@ public class MetadataRepositoryIndex
* @param indexPath the path to the index
* @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 );
}

View File

@ -56,7 +56,7 @@ public class PomRepositoryIndex
* @param digester the digester to be used for generating checksums
* @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 )
{
super( indexPath, repository );

View File

@ -19,6 +19,7 @@ package org.apache.maven.repository.indexing;
import org.apache.lucene.analysis.Analyzer;
import org.apache.maven.artifact.repository.ArtifactRepository;
import java.io.File;
import java.util.Arrays;
import java.util.List;
@ -113,7 +114,7 @@ public interface RepositoryIndex
*
* @return the path where the index resides
*/
String getIndexPath();
File getIndexPath();
/**
* Tests an index field if it is a keyword field

View File

@ -18,6 +18,8 @@ package org.apache.maven.repository.indexing;
import org.apache.maven.artifact.repository.ArtifactRepository;
import java.io.File;
/**
* @author Edwin Punzalan
@ -34,7 +36,7 @@ public interface RepositoryIndexingFactory
* @return the ArtifactRepositoryIndex instance
* @throws RepositoryIndexException
*/
ArtifactRepositoryIndex createArtifactRepositoryIndex( String indexPath, ArtifactRepository repository )
ArtifactRepositoryIndex createArtifactRepositoryIndex( File indexPath, ArtifactRepository repository )
throws RepositoryIndexException;
/**
@ -45,7 +47,7 @@ public interface RepositoryIndexingFactory
* @return the PomRepositoryIndex instance
* @throws RepositoryIndexException
*/
PomRepositoryIndex createPomRepositoryIndex( String indexPath, ArtifactRepository repository )
PomRepositoryIndex createPomRepositoryIndex( File indexPath, ArtifactRepository repository )
throws RepositoryIndexException;
/**
@ -56,7 +58,7 @@ public interface RepositoryIndexingFactory
* @return the MetadataRepositoryIndex instance
* @throws RepositoryIndexException
*/
MetadataRepositoryIndex createMetadataRepositoryIndex( String indexPath, ArtifactRepository repository )
MetadataRepositoryIndex createMetadataRepositoryIndex( File indexPath, ArtifactRepository repository )
throws RepositoryIndexException;
}

View File

@ -43,7 +43,7 @@ public class ArtifactRepositoryIndexingTest
private ArtifactRepository repository;
private String indexPath;
private File indexPath;
private Digester digester;
@ -59,7 +59,7 @@ public class ArtifactRepositoryIndexingTest
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
digester = new DefaultDigester();
indexPath = "target/index";
indexPath = getTestFile( "target/index" );
FileUtils.deleteDirectory( indexPath );
}
@ -77,7 +77,7 @@ public class ArtifactRepositoryIndexingTest
try
{
String notIndexDir = new File( "pom.xml" ).getAbsolutePath();
File notIndexDir = new File( "pom.xml" );
ArtifactRepositoryIndex indexer = factory.createArtifactRepositoryIndex( notIndexDir, repository );
indexer.indexArtifact( artifact );
fail( "Must throw exception on non-directory index directory" );
@ -89,7 +89,7 @@ public class ArtifactRepositoryIndexingTest
try
{
String notIndexDir = new File( "" ).getAbsolutePath();
File notIndexDir = new File( "" );
ArtifactRepositoryIndex indexer = factory.createArtifactRepositoryIndex( notIndexDir, repository );
indexer.indexArtifact( artifact );
fail( "Must throw an exception on a non-index directory" );
@ -433,7 +433,7 @@ public class ArtifactRepositoryIndexingTest
assertTrue( true );
}
indexer = factory.createArtifactRepositoryIndex( "target/index/sample", repository );
indexer = factory.createArtifactRepositoryIndex( getTestFile( "target/index/sample" ), repository );
try
{

View File

@ -43,7 +43,7 @@ public class EclipseRepositoryIndexTest
private ArtifactRepository repository;
private String indexPath;
private File indexPath;
private Digester digester;
@ -63,7 +63,7 @@ public class EclipseRepositoryIndexTest
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
digester = new DefaultDigester();
indexPath = "target/index";
indexPath = getTestFile( "target/index" );
FileUtils.deleteDirectory( indexPath );
}
@ -125,7 +125,7 @@ public class EclipseRepositoryIndexTest
try
{
String notIndexDir = new File( "pom.xml" ).getAbsolutePath();
File notIndexDir = new File( "pom.xml" );
EclipseRepositoryIndex indexer = new EclipseRepositoryIndex( notIndexDir, repository, digester );
indexer.indexArtifact( artifact );
fail( "Must throw exception on non-directory index directory" );
@ -137,7 +137,7 @@ public class EclipseRepositoryIndexTest
try
{
String notIndexDir = new File( "" ).getAbsolutePath();
File notIndexDir = new File( "" );
EclipseRepositoryIndex indexer = new EclipseRepositoryIndex( notIndexDir, repository, digester );
indexer.indexArtifact( artifact );
fail( "Must throw an exception on a non-index directory" );
@ -169,7 +169,7 @@ public class EclipseRepositoryIndexTest
{
EclipseRepositoryIndex index = createTestIndex();
IndexSearcher searcher = new IndexSearcher( index.getIndexPath() );
IndexSearcher searcher = new IndexSearcher( index.getIndexPath().getAbsolutePath() );
try
{
QueryParser parser = new QueryParser( "j", index.getAnalyzer() );

View File

@ -52,7 +52,7 @@ public class MetadataRepositoryIndexingTest
{
private ArtifactRepository repository;
private String indexPath;
private File indexPath;
private ArtifactFactory artifactFactory;
@ -71,7 +71,7 @@ public class MetadataRepositoryIndexingTest
ArtifactRepositoryFactory repoFactory = (ArtifactRepositoryFactory) lookup( ArtifactRepositoryFactory.ROLE );
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
indexPath = "target/index";
indexPath = getTestFile( "target/index" );
FileUtils.deleteDirectory( indexPath );
}

View File

@ -48,7 +48,7 @@ public class PomRepositoryIndexingTest
private ArtifactFactory artifactFactory;
private String indexPath;
private File indexPath;
private Digester digester;
@ -64,7 +64,7 @@ public class PomRepositoryIndexingTest
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
digester = new DefaultDigester();
indexPath = "target/index";
indexPath = getTestFile( "target/index" );
FileUtils.deleteDirectory( indexPath );
}
@ -77,7 +77,7 @@ public class PomRepositoryIndexingTest
try
{
String notIndexDir = new File( "pom.xml" ).getAbsolutePath();
File notIndexDir = new File( "pom.xml" );
PomRepositoryIndex indexer = factory.createPomRepositoryIndex( notIndexDir, repository );
indexer.indexPom( pom );
fail( "Must throw exception on non-directory index directory" );
@ -89,7 +89,7 @@ public class PomRepositoryIndexingTest
try
{
String notIndexDir = new File( "" ).getAbsolutePath();
File notIndexDir = new File( "" );
PomRepositoryIndex indexer = factory.createPomRepositoryIndex( notIndexDir, repository );
indexer.indexPom( pom );
fail( "Must throw an exception on a non-index directory" );

View File

@ -54,7 +54,7 @@ public class RepositoryIndexSearchLayerTest
private ArtifactFactory artifactFactory;
private String indexPath;
private File indexPath;
/**
* Setup method
@ -71,7 +71,7 @@ public class RepositoryIndexSearchLayerTest
ArtifactRepositoryFactory repoFactory = (ArtifactRepositoryFactory) lookup( ArtifactRepositoryFactory.ROLE );
repository = repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
indexPath = "target/index";
indexPath = getTestFile( "target/index" );
FileUtils.deleteDirectory( indexPath );
}

View File

@ -68,8 +68,8 @@ public class DuplicateArtifactFileReportProcessor
{
if ( artifact.getFile() != null )
{
//@todo remove hard-coded value; current value enables tests to pass
String indexPath = new File( "target/.index" ).getAbsolutePath();
//@todo remove hard-coded value; current value enables tests to pass!
File indexPath = new File( "target/.index" );
RepositoryIndex index;
try

View File

@ -41,7 +41,7 @@ public class DuplicateArtifactFileReportProcessorTest
private ArtifactFactory artifactFactory;
private String indexPath = new File( "target/.index" ).getAbsolutePath();
private File indexPath = getTestFile( "target/.index" );
protected void setUp()
throws Exception

View File

@ -50,6 +50,10 @@
<groupId>org.apache.maven.repository</groupId>
<artifactId>maven-repository-discovery</artifactId>
</dependency>
<dependency>
<groupId>org.apache.maven.repository</groupId>
<artifactId>maven-repository-configuration</artifactId>
</dependency>
<dependency>
<groupId>org.apache.maven.repository</groupId>
<artifactId>maven-repository-artifact-applet</artifactId>

View File

@ -17,9 +17,12 @@ package org.apache.maven.repository.manager.web.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.job.DiscovererScheduler;
import java.io.File;
/**
* 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.
@ -48,8 +51,9 @@ public class BaseAction
{
try
{
execution.executeDiscovererIfIndexDoesNotExist();
discovererScheduler.setSchedule();
Configuration configuration = new Configuration(); // TODO!
execution.executeDiscovererIfIndexDoesNotExist( new File( configuration.getIndexPath() ) );
discovererScheduler.setSchedule( configuration.getDiscoveryCronExpression() );
}
catch ( Exception e )
{

View File

@ -19,16 +19,18 @@ package org.apache.maven.repository.manager.web.action;
import com.opensymphony.xwork.Action;
import org.apache.maven.artifact.repository.ArtifactRepository;
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.RepositoryIndexException;
import org.apache.maven.repository.indexing.RepositoryIndexSearchException;
import org.apache.maven.repository.indexing.RepositoryIndexSearchLayer;
import org.apache.maven.repository.indexing.RepositoryIndexingFactory;
import org.apache.maven.repository.manager.web.job.Configuration;
import java.io.File;
import java.net.MalformedURLException;
import java.util.List;
import java.util.Map;
/**
* Searches for searchString in all indexed fields.
@ -58,24 +60,26 @@ public class GeneralSearchAction
private ArtifactRepositoryFactory repositoryFactory;
/**
* @plexus.requirement
* @plexus.requirement role="org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout"
*/
private Configuration configuration;
private Map repositoryLayouts;
public String execute()
throws MalformedURLException, RepositoryIndexException, RepositoryIndexSearchException
{
if ( searchString != null && searchString.length() != 0 )
{
String indexPath = configuration.getIndexDirectory();
// TODO: reduce the amount of lookup?
Configuration configuration = new Configuration(); // TODO!
File indexPath = new File( configuration.getIndexPath() );
// TODO: [!] repository should only have been instantiated once
File repositoryDirectory = new File( configuration.getRepositoryDirectory() );
String repoDir = repositoryDirectory.toURL().toString();
ArtifactRepositoryLayout layout =
(ArtifactRepositoryLayout) repositoryLayouts.get( configuration.getRepositoryLayout() );
ArtifactRepository repository =
repositoryFactory.createArtifactRepository( "test", repoDir, configuration.getLayout(), null, null );
repositoryFactory.createArtifactRepository( "test", repoDir, layout, null, null );
ArtifactRepositoryIndex index = factory.createArtifactRepositoryIndex( indexPath, repository );

View File

@ -19,6 +19,8 @@ package org.apache.maven.repository.manager.web.action;
import com.opensymphony.xwork.Action;
import org.apache.maven.artifact.repository.ArtifactRepository;
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.RepositoryIndex;
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.RepositoryIndexingFactory;
import org.apache.maven.repository.indexing.query.SinglePhraseQuery;
import org.apache.maven.repository.manager.web.job.Configuration;
import java.io.File;
import java.net.MalformedURLException;
import java.util.List;
import java.util.Map;
/**
* Search by package name.
@ -52,6 +54,11 @@ public class PackageSearchAction
*/
private RepositoryIndexingFactory factory;
/**
* @plexus.requirement role="org.apache.maven.artifact.repository.layout.ArtifactRepositoryLayout"
*/
private Map repositoryLayouts;
/**
* @plexus.requirement
*/
@ -62,11 +69,6 @@ public class PackageSearchAction
*/
private RepositoryIndexSearchLayer searchLayer;
/**
* @plexus.requirement
*/
private Configuration configuration;
public String execute()
throws MalformedURLException, RepositoryIndexException, RepositoryIndexSearchException
{
@ -87,15 +89,17 @@ public class PackageSearchAction
return ERROR;
}
// TODO: better config [!]
String indexPath = configuration.getIndexDirectory();
// TODO: better config - share with general [!]
Configuration configuration = new Configuration();
File indexPath = new File( configuration.getIndexPath() );
// TODO: reduce the amount of lookup?
File repositoryDirectory = new File( configuration.getRepositoryDirectory() );
String repoDir = repositoryDirectory.toURL().toString();
ArtifactRepositoryLayout layout =
(ArtifactRepositoryLayout) repositoryLayouts.get( configuration.getRepositoryLayout() );
ArtifactRepository repository =
repositoryFactory.createArtifactRepository( "repository", repoDir, configuration.getLayout(), null, null );
repositoryFactory.createArtifactRepository( "repository", repoDir, layout, null, null );
ArtifactRepositoryIndex index = factory.createArtifactRepositoryIndex( indexPath, repository );

View File

@ -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.metadata.RepositoryMetadata;
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.MetadataDiscoverer;
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.RepositoryIndexException;
import org.apache.maven.repository.indexing.RepositoryIndexingFactory;
import org.apache.maven.repository.manager.web.job.Configuration;
import org.codehaus.plexus.logging.AbstractLogEnabled;
import java.io.File;
@ -39,7 +39,6 @@ import java.net.MalformedURLException;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Properties;
/**
* This is the class that executes the discoverer and indexer.
@ -50,10 +49,6 @@ import java.util.Properties;
public class DiscovererExecution
extends AbstractLogEnabled
{
/**
* @plexus.requirement
*/
private Configuration config;
/**
* @plexus.requirement role="org.apache.maven.repository.discovery.ArtifactDiscoverer"
@ -75,19 +70,21 @@ public class DiscovererExecution
*/
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
*
* @param indexDir
* @throws MalformedURLException
* @throws RepositoryIndexException
*/
public void executeDiscovererIfIndexDoesNotExist()
public void executeDiscovererIfIndexDoesNotExist( File indexDir )
throws MalformedURLException, RepositoryIndexException
{
Properties props = config.getProperties();
String indexPath = props.getProperty( "index.path" );
File indexDir = new File( indexPath );
boolean isExisting = false;
if ( IndexReader.indexExists( indexDir ) )
@ -107,27 +104,26 @@ public class DiscovererExecution
public void executeDiscoverer()
throws MalformedURLException, RepositoryIndexException
{
Properties props = config.getProperties();
String indexPath = props.getProperty( "index.path" );
String blacklistedPatterns = props.getProperty( "blacklist.patterns" );
boolean includeSnapshots = Boolean.valueOf( props.getProperty( "include.snapshots" ) ).booleanValue();
boolean convertSnapshots = Boolean.valueOf( props.getProperty( "convert.snapshots" ) ).booleanValue();
Configuration configuration = new Configuration(); // TODO!
File indexPath = new File( configuration.getIndexPath() );
String blacklistedPatterns = configuration.getDiscoveryBlackListPatterns();
boolean includeSnapshots = configuration.isDiscoverSnapshots();
ArtifactRepository defaultRepository = getDefaultRepository();
ArtifactRepository defaultRepository = getDefaultRepository( configuration );
getLogger().info( "[DiscovererExecution] Started discovery and indexing.." );
String layoutProperty = props.getProperty( "layout" );
String layoutProperty = configuration.getRepositoryLayout();
ArtifactDiscoverer discoverer = (ArtifactDiscoverer) artifactDiscoverers.get( layoutProperty );
List artifacts = discoverer.discoverArtifacts( defaultRepository, blacklistedPatterns, includeSnapshots );
indexArtifact( artifacts, indexPath, defaultRepository );
List models = discoverer.discoverStandalonePoms( defaultRepository, blacklistedPatterns, convertSnapshots );
List models = discoverer.discoverStandalonePoms( defaultRepository, blacklistedPatterns, includeSnapshots );
indexPom( models, indexPath, defaultRepository );
MetadataDiscoverer metadataDiscoverer = (MetadataDiscoverer) metadataDiscoverers.get( layoutProperty );
List metadataList =
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." );
}
@ -138,7 +134,7 @@ public class DiscovererExecution
* @param indexPath the path to the index file
* @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
{
ArtifactRepositoryIndex artifactIndex = indexFactory.createArtifactRepositoryIndex( indexPath, repository );
@ -160,16 +156,10 @@ public class DiscovererExecution
*
* @param metadataList the metadata to be indexed
* @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,
ArtifactRepositoryLayout layout )
protected void indexMetadata( List metadataList, File indexPath, ArtifactRepository repository )
throws RepositoryIndexException, MalformedURLException
{
String repoDir = repositoryBase.toURL().toString();
ArtifactRepository repository =
repoFactory.createArtifactRepository( "repository", repoDir, layout, null, null );
MetadataRepositoryIndex metadataIndex = indexFactory.createMetadataRepositoryIndex( indexPath, repository );
for ( Iterator iter = metadataList.iterator(); iter.hasNext(); )
{
@ -191,7 +181,7 @@ public class DiscovererExecution
* @param indexPath the path to the index
* @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
{
PomRepositoryIndex pomIndex = indexFactory.createPomRepositoryIndex( indexPath, repository );
@ -214,33 +204,16 @@ public class DiscovererExecution
* @return an ArtifactRepository instance
* @throws java.net.MalformedURLException
*/
protected ArtifactRepository getDefaultRepository()
protected ArtifactRepository getDefaultRepository( Configuration configuration )
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();
ArtifactRepositoryFactory repoFactory = new DefaultArtifactRepositoryFactory();
return repoFactory.createArtifactRepository( "test", repoDir, config.getLayout(), 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;
ArtifactRepositoryLayout layout =
(ArtifactRepositoryLayout) repositoryLayouts.get( configuration.getRepositoryLayout() );
return repoFactory.createArtifactRepository( "test", repoDir, layout, null, null );
}
}

View File

@ -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;
}
}

View File

@ -26,7 +26,6 @@ import org.quartz.JobDetail;
import org.quartz.SchedulerException;
import java.text.ParseException;
import java.util.Properties;
/**
* This class sets the job to be executed in the plexus-quartz scheduler
@ -36,11 +35,6 @@ import java.util.Properties;
public class DiscovererScheduler
extends AbstractLogEnabled
{
/**
* @plexus.requirement
*/
private Configuration config;
/**
* @plexus.requirement
*/
@ -54,43 +48,20 @@ public class DiscovererScheduler
/**
* Method that sets the schedule in the plexus-quartz scheduler
*
* @param cronExpression
* @throws ParseException
* @throws SchedulerException
*/
public void setSchedule()
public void setSchedule( String cronExpression )
throws ParseException, SchedulerException
{
Properties props = config.getProperties();
JobDetail jobDetail = new JobDetail( "discovererJob", "DISCOVERER", DiscovererJob.class );
JobDataMap dataMap = new JobDataMap();
dataMap.put( AbstractJob.LOGGER, getLogger() );
dataMap.put( DiscovererJob.MAP_DISCOVERER_EXECUTION, execution );
jobDetail.setJobDataMap( dataMap );
CronTrigger trigger =
new CronTrigger( "DiscovererTrigger", "DISCOVERER", props.getProperty( "cron.expression" ) );
CronTrigger trigger = new CronTrigger( "DiscovererTrigger", "DISCOVERER", cronExpression );
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;
}
}

View File

@ -41,47 +41,6 @@
<implementation>org.codehaus.plexus.xwork.PlexusObjectFactory</implementation>
</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
-->

11
pom.xml
View File

@ -14,9 +14,7 @@
~ See the License for the specific language governing permissions and
~ 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>
<parent>
<groupId>org.apache.maven</groupId>
@ -120,6 +118,8 @@
<module>maven-repository-webapp</module>
<module>maven-repository-proxy</module>
<module>maven-repository-manager-site</module>
<module>maven-repository-core</module>
<module>maven-repository-configuration</module>
</modules>
<dependencies>
<dependency>
@ -211,6 +211,11 @@
<artifactId>maven-repository-artifact-applet</artifactId>
<version>${pom.version}</version>
</dependency>
<dependency>
<groupId>org.apache.maven.repository</groupId>
<artifactId>maven-repository-configuration</artifactId>
<version>${pom.version}</version>
</dependency>
</dependencies>
</dependencyManagement>
<reporting>