Work towards compilable webapp

git-svn-id: https://svn.apache.org/repos/asf/maven/archiva/branches/archiva-jpox-database-refactor@527650 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Joakim Erdfelt 2007-04-11 20:27:38 +00:00
parent 9e2d664ab3
commit 454fb5b0be
15 changed files with 377 additions and 517 deletions

View File

@ -27,6 +27,8 @@ package org.apache.maven.archiva.database;
*/ */
public interface ArchivaDAO public interface ArchivaDAO
{ {
public static final String ROLE = ArchivaDAO.class.getName();
ArtifactDAO getArtifactDAO(); ArtifactDAO getArtifactDAO();
ProjectModelDAO getProjectModelDAO(); ProjectModelDAO getProjectModelDAO();

View File

@ -19,7 +19,7 @@ package org.apache.maven.archiva.database;
* under the License. * under the License.
*/ */
import org.apache.maven.archiva.model.ArchivaRepositoryModel; import org.apache.maven.archiva.model.ArchivaRepository;
import java.util.List; import java.util.List;
@ -52,20 +52,20 @@ public interface RepositoryDAO
* This is the only list of options created in this DAO. * This is the only list of options created in this DAO.
*/ */
public ArchivaRepositoryModel createRepository( String id, String url ); public ArchivaRepository createRepository( String id, String name, String url );
public List /*<ArchivaRepositoryModel>*/getRepositories() public List /*<ArchivaRepository>*/getRepositories()
throws ObjectNotFoundException, ArchivaDatabaseException; throws ObjectNotFoundException, ArchivaDatabaseException;
public ArchivaRepositoryModel getRepository( String id ) public ArchivaRepository getRepository( String id )
throws ObjectNotFoundException, ArchivaDatabaseException; throws ObjectNotFoundException, ArchivaDatabaseException;
public List queryRepository( Constraint constraint ) public List /*<ArchivaRepository>*/queryRepositories( Constraint constraint )
throws ObjectNotFoundException, ArchivaDatabaseException; throws ObjectNotFoundException, ArchivaDatabaseException;
public ArchivaRepositoryModel saveRepository( ArchivaRepositoryModel repository ) public ArchivaRepository saveRepository( ArchivaRepository repository )
throws ArchivaDatabaseException; throws ArchivaDatabaseException;
public void deleteRepository( ArchivaRepositoryModel repository ) public void deleteRepository( ArchivaRepository repository )
throws ArchivaDatabaseException; throws ArchivaDatabaseException;
} }

View File

@ -0,0 +1,53 @@
package org.apache.maven.archiva.database.constraints;
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.commons.lang.StringEscapeUtils;
import org.apache.maven.archiva.database.Constraint;
/**
* ArtifactsRelatedConstraint
*
* @author <a href="mailto:joakim@erdfelt.com">Joakim Erdfelt</a>
* @version $Id$
*/
public class ArtifactsRelatedConstraint
extends AbstractConstraint
implements Constraint
{
private String whereClause;
public ArtifactsRelatedConstraint( String groupId, String artifactId, String version )
{
whereClause = "groupId == '" + StringEscapeUtils.escapeSql( groupId ) + "' AND artifactId == '"
+ StringEscapeUtils.escapeSql( artifactId ) + "' AND version == '" + StringEscapeUtils.escapeSql( version )
+ "'";
}
public String getSortColumn()
{
return "classifier";
}
public String getWhereCondition()
{
return whereClause;
}
}

View File

@ -62,12 +62,6 @@ public class JdoArtifactDAO
} }
catch ( ArchivaDatabaseException e ) catch ( ArchivaDatabaseException e )
{ {
if ( !( e instanceof ObjectNotFoundException ) )
{
getLogger().warn(
"Unable to get artifact [" + groupId + ":" + artifactId + ":" + version + ":"
+ classifier + ":" + type + "]: " + e.getMessage(), e );
}
artifact = new ArchivaArtifact( groupId, artifactId, version, classifier, type ); artifact = new ArchivaArtifact( groupId, artifactId, version, classifier, type );
} }

View File

@ -23,8 +23,11 @@ import org.apache.maven.archiva.database.ArchivaDatabaseException;
import org.apache.maven.archiva.database.Constraint; import org.apache.maven.archiva.database.Constraint;
import org.apache.maven.archiva.database.ObjectNotFoundException; import org.apache.maven.archiva.database.ObjectNotFoundException;
import org.apache.maven.archiva.database.RepositoryDAO; import org.apache.maven.archiva.database.RepositoryDAO;
import org.apache.maven.archiva.model.ArchivaRepository;
import org.apache.maven.archiva.model.ArchivaRepositoryModel; import org.apache.maven.archiva.model.ArchivaRepositoryModel;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List; import java.util.List;
/** /**
@ -45,9 +48,9 @@ public class JdoRepositoryDAO
/* .\ Archiva Repository \.____________________________________________________________ */ /* .\ Archiva Repository \.____________________________________________________________ */
public ArchivaRepositoryModel createRepository( String id, String url ) public ArchivaRepository createRepository( String id, String name, String url )
{ {
ArchivaRepositoryModel repo; ArchivaRepository repo;
try try
{ {
@ -55,9 +58,7 @@ public class JdoRepositoryDAO
} }
catch ( ArchivaDatabaseException e ) catch ( ArchivaDatabaseException e )
{ {
repo = new ArchivaRepositoryModel(); repo = new ArchivaRepository( id, name, url );
repo.setId( id );
repo.setUrl( url );
} }
return repo; return repo;
@ -69,26 +70,49 @@ public class JdoRepositoryDAO
return jdo.getAllObjects( ArchivaRepositoryModel.class ); return jdo.getAllObjects( ArchivaRepositoryModel.class );
} }
public ArchivaRepositoryModel getRepository( String id ) public ArchivaRepository getRepository( String id )
throws ObjectNotFoundException, ArchivaDatabaseException throws ObjectNotFoundException, ArchivaDatabaseException
{ {
return (ArchivaRepositoryModel) jdo.getObjectById( ArchivaRepositoryModel.class, id, null ); ArchivaRepositoryModel model = (ArchivaRepositoryModel) jdo.getObjectById( ArchivaRepositoryModel.class, id,
null );
return new ArchivaRepository( model );
} }
public List queryRepository( Constraint constraint ) public List queryRepositories( Constraint constraint )
throws ObjectNotFoundException, ArchivaDatabaseException throws ObjectNotFoundException, ArchivaDatabaseException
{ {
return jdo.getAllObjects( ArchivaRepositoryModel.class, constraint ); List results = jdo.getAllObjects( ArchivaRepositoryModel.class, constraint );
}
public ArchivaRepositoryModel saveRepository( ArchivaRepositoryModel repository ) if ( ( results == null ) || results.isEmpty() )
{ {
return (ArchivaRepositoryModel) jdo.saveObject( repository ); return results;
} }
public void deleteRepository( ArchivaRepositoryModel repository ) List ret = new ArrayList();
Iterator it = results.iterator();
while ( it.hasNext() )
{
ArchivaRepositoryModel model = (ArchivaRepositoryModel) it.next();
ret.add( new ArchivaRepository( model ) );
}
return ret;
}
public ArchivaRepository saveRepository( ArchivaRepository repository )
{
ArchivaRepositoryModel model = (ArchivaRepositoryModel) jdo.saveObject( repository.getModel() );
if ( model == null )
{
return null;
}
return new ArchivaRepository( model );
}
public void deleteRepository( ArchivaRepository repository )
throws ArchivaDatabaseException throws ArchivaDatabaseException
{ {
jdo.removeObject( repository ); jdo.removeObject( repository.getModel() );
} }
} }

View File

@ -22,7 +22,6 @@ package org.apache.maven.archiva.database;
import org.codehaus.plexus.PlexusTestCase; import org.codehaus.plexus.PlexusTestCase;
import org.codehaus.plexus.jdo.DefaultConfigurableJdoFactory; import org.codehaus.plexus.jdo.DefaultConfigurableJdoFactory;
import org.codehaus.plexus.jdo.JdoFactory; import org.codehaus.plexus.jdo.JdoFactory;
import org.codehaus.plexus.util.FileUtils;
import org.jpox.SchemaTool; import org.jpox.SchemaTool;
import java.io.File; import java.io.File;

View File

@ -22,7 +22,7 @@ package org.apache.maven.archiva.database.jdo;
import org.apache.maven.archiva.database.AbstractArchivaDatabaseTestCase; import org.apache.maven.archiva.database.AbstractArchivaDatabaseTestCase;
import org.apache.maven.archiva.database.ArchivaDatabaseException; import org.apache.maven.archiva.database.ArchivaDatabaseException;
import org.apache.maven.archiva.database.RepositoryDAO; import org.apache.maven.archiva.database.RepositoryDAO;
import org.apache.maven.archiva.model.ArchivaRepositoryModel; import org.apache.maven.archiva.model.ArchivaRepository;
import java.util.List; import java.util.List;
@ -43,16 +43,16 @@ public class JdoRepositoryDAOTest
RepositoryDAO repoDao = dao.getRepositoryDAO(); RepositoryDAO repoDao = dao.getRepositoryDAO();
// Create it // Create it
ArchivaRepositoryModel repo = repoDao.createRepository( "testRepo", "http://localhost:8080/repository/foo" ); ArchivaRepository repo = repoDao.createRepository( "testRepo", "Test Repository",
"http://localhost:8080/repository/foo" );
assertNotNull( repo ); assertNotNull( repo );
// Set some mandatory values // Set some mandatory values
repo.setName( "The Test Repository." ); repo.getModel().setCreationSource( "Test Case" );
repo.setCreationSource( "Test Case" ); repo.getModel().setLayoutName( "default" );
repo.setLayoutName( "default" );
// Save it. // Save it.
ArchivaRepositoryModel repoSaved = repoDao.saveRepository( repo ); ArchivaRepository repoSaved = repoDao.saveRepository( repo );
assertNotNull( repoSaved ); assertNotNull( repoSaved );
assertEquals( "testRepo", JDOHelper.getObjectId( repoSaved ).toString() ); assertEquals( "testRepo", JDOHelper.getObjectId( repoSaved ).toString() );
@ -62,28 +62,28 @@ public class JdoRepositoryDAOTest
assertEquals( 1, repos.size() ); assertEquals( 1, repos.size() );
// Test that retreived object is what we expect. // Test that retreived object is what we expect.
ArchivaRepositoryModel firstRepo = (ArchivaRepositoryModel) repos.get( 0 ); ArchivaRepository firstRepo = (ArchivaRepository) repos.get( 0 );
assertNotNull( firstRepo ); assertNotNull( firstRepo );
assertEquals( "testRepo", repo.getId() ); assertEquals( "testRepo", repo.getId() );
assertEquals( "The Test Repository.", repo.getName() ); assertEquals( "The Test Repository.", repo.getModel().getName() );
assertEquals( "Test Case", repo.getCreationSource() ); assertEquals( "Test Case", repo.getModel().getCreationSource() );
assertEquals( "default", repo.getLayoutName() ); assertEquals( "default", repo.getModel().getLayoutName() );
// Change value and save. // Change value and save.
repoSaved.setName( "Saved Again" ); repoSaved.getModel().setCreationSource( "Changed" );
repoDao.saveRepository( repoSaved ); repoDao.saveRepository( repoSaved );
// Test that only 1 object is saved. // Test that only 1 object is saved.
assertEquals( 1, repoDao.getRepositories().size() ); assertEquals( 1, repoDao.getRepositories().size() );
// Get the specific repo. // Get the specific repo.
ArchivaRepositoryModel actualRepo = repoDao.getRepository( "testRepo" ); ArchivaRepository actualRepo = repoDao.getRepository( "testRepo" );
assertNotNull( actualRepo ); assertNotNull( actualRepo );
// Test expected values. // Test expected values.
assertEquals( "testRepo", actualRepo.getId() ); assertEquals( "testRepo", actualRepo.getId() );
assertEquals( "http://localhost:8080/repository/foo", actualRepo.getUrl() ); assertEquals( "http://localhost:8080/repository/foo", actualRepo.getUrl() );
assertEquals( "Saved Again", actualRepo.getName() ); assertEquals( "Changed", actualRepo.getModel().getCreationSource() );
// Test that only 1 object is saved. // Test that only 1 object is saved.
assertEquals( 1, repoDao.getRepositories().size() ); assertEquals( 1, repoDao.getRepositories().size() );

View File

@ -64,6 +64,12 @@
<dependency> <dependency>
<groupId>org.apache.maven.shared</groupId> <groupId>org.apache.maven.shared</groupId>
<artifactId>maven-app-configuration-web</artifactId> <artifactId>maven-app-configuration-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.apache.maven</groupId>
<artifactId>maven-project</artifactId>
</exclusion>
</exclusions>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.codehaus.plexus</groupId> <groupId>org.codehaus.plexus</groupId>
@ -120,17 +126,19 @@
<groupId>org.codehaus.plexus</groupId> <groupId>org.codehaus.plexus</groupId>
<artifactId>plexus-container-default</artifactId> <artifactId>plexus-container-default</artifactId>
</dependency> </dependency>
<!--
<dependency> <dependency>
<groupId>org.apache.maven.archiva</groupId> <groupId>org.apache.maven.archiva</groupId>
<artifactId>archiva-proxy</artifactId> <artifactId>archiva-proxy</artifactId>
</dependency> </dependency>
-->
<dependency> <dependency>
<groupId>org.apache.maven.archiva</groupId> <groupId>org.apache.maven.archiva</groupId>
<artifactId>archiva-core</artifactId> <artifactId>archiva-database</artifactId>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.apache.maven.archiva</groupId> <groupId>org.apache.maven.archiva</groupId>
<artifactId>archiva-common</artifactId> <artifactId>archiva-repository-layer</artifactId>
</dependency> </dependency>
<dependency> <dependency>
<groupId>org.apache.maven.archiva</groupId> <groupId>org.apache.maven.archiva</groupId>
@ -142,15 +150,6 @@
<!-- TODO: actually, just exclude from WAR plugin --> <!-- TODO: actually, just exclude from WAR plugin -->
<scope>provided</scope> <scope>provided</scope>
</dependency> </dependency>
<dependency>
<groupId>org.apache.maven</groupId>
<artifactId>maven-project</artifactId>
</dependency>
<dependency>
<groupId>org.apache.maven.shared</groupId>
<artifactId>maven-dependency-tree</artifactId>
<version>1.0-alpha-2</version>
</dependency>
<!-- Plexus Security Dependencies --> <!-- Plexus Security Dependencies -->
<dependency> <dependency>
<groupId>org.codehaus.plexus.security</groupId> <groupId>org.codehaus.plexus.security</groupId>

View File

@ -22,11 +22,7 @@ package org.apache.maven.archiva.web.action;
import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.StringUtils;
import org.apache.maven.archiva.configuration.ArchivaConfiguration; import org.apache.maven.archiva.configuration.ArchivaConfiguration;
import org.apache.maven.archiva.configuration.Configuration; import org.apache.maven.archiva.configuration.Configuration;
import org.apache.maven.archiva.configuration.ConfiguredRepositoryFactory; import org.apache.maven.archiva.database.ArchivaDAO;
import org.apache.maven.archiva.indexer.RepositoryArtifactIndex;
import org.apache.maven.archiva.indexer.RepositoryArtifactIndexFactory;
import org.apache.maven.archiva.indexer.RepositoryIndexException;
import org.apache.maven.archiva.indexer.RepositoryIndexSearchException;
import org.codehaus.plexus.xwork.action.PlexusActionSupport; import org.codehaus.plexus.xwork.action.PlexusActionSupport;
import java.io.File; import java.io.File;
@ -51,12 +47,7 @@ public class BrowseAction
/** /**
* @plexus.requirement * @plexus.requirement
*/ */
private RepositoryArtifactIndexFactory factory; private ArchivaDAO dao;
/**
* @plexus.requirement
*/
private ConfiguredRepositoryFactory repositoryFactory;
/** /**
* @plexus.requirement * @plexus.requirement
@ -243,15 +234,6 @@ public class BrowseAction
return groups; return groups;
} }
private RepositoryArtifactIndex getIndex()
throws RepositoryIndexException
{
Configuration configuration = archivaConfiguration.getConfiguration();
File indexPath = new File( configuration.getIndexPath() );
return factory.createStandardIndex( indexPath );
}
public List getGroups() public List getGroups()
{ {
return groups; return groups;

View File

@ -20,39 +20,14 @@ package org.apache.maven.archiva.web.action;
*/ */
import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.StringUtils;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.TermQuery;
import org.apache.maven.archiva.configuration.ArchivaConfiguration; import org.apache.maven.archiva.configuration.ArchivaConfiguration;
import org.apache.maven.archiva.configuration.Configuration; import org.apache.maven.archiva.configuration.Configuration;
import org.apache.maven.archiva.configuration.ConfiguredRepositoryFactory; import org.apache.maven.archiva.database.ArchivaDAO;
import org.apache.maven.archiva.indexer.RepositoryArtifactIndex; import org.apache.maven.archiva.database.ArchivaDatabaseException;
import org.apache.maven.archiva.indexer.RepositoryArtifactIndexFactory; import org.apache.maven.archiva.database.ObjectNotFoundException;
import org.apache.maven.archiva.indexer.RepositoryIndexException; import org.apache.maven.archiva.model.ArchivaProjectModel;
import org.apache.maven.archiva.indexer.RepositoryIndexSearchException;
import org.apache.maven.archiva.indexer.lucene.LuceneQuery;
import org.apache.maven.archiva.indexer.record.StandardArtifactIndexRecord;
import org.apache.maven.archiva.proxy.ProxyException;
import org.apache.maven.archiva.reporting.database.ArtifactResultsDatabase;
import org.apache.maven.archiva.web.util.VersionMerger; import org.apache.maven.archiva.web.util.VersionMerger;
import org.apache.maven.artifact.Artifact;
import org.apache.maven.artifact.factory.ArtifactFactory;
import org.apache.maven.artifact.metadata.ArtifactMetadataSource;
import org.apache.maven.artifact.repository.ArtifactRepository;
import org.apache.maven.artifact.resolver.ArtifactCollector;
import org.apache.maven.artifact.resolver.ArtifactResolutionException;
import org.apache.maven.artifact.versioning.DefaultArtifactVersion;
import org.apache.maven.model.Dependency;
import org.apache.maven.model.Model;
import org.apache.maven.project.MavenProject;
import org.apache.maven.project.MavenProjectBuilder;
import org.apache.maven.project.ProjectBuildingException;
import org.apache.maven.project.artifact.InvalidDependencyVersionException;
import org.apache.maven.shared.dependency.tree.DependencyNode;
import org.apache.maven.shared.dependency.tree.DependencyTree;
import org.apache.maven.shared.dependency.tree.DependencyTreeBuilder;
import org.apache.maven.shared.dependency.tree.DependencyTreeBuilderException;
import org.apache.maven.wagon.ResourceDoesNotExistException; import org.apache.maven.wagon.ResourceDoesNotExistException;
import org.codehaus.plexus.util.xml.pull.XmlPullParserException;
import org.codehaus.plexus.xwork.action.PlexusActionSupport; import org.codehaus.plexus.xwork.action.PlexusActionSupport;
import java.io.File; import java.io.File;
@ -68,55 +43,25 @@ import java.util.Set;
/** /**
* Browse the repository. * Browse the repository.
* *
* TODO change name to ShowVersionedAction to conform to terminology.
* @plexus.component role="com.opensymphony.xwork.Action" role-hint="showArtifactAction" * @plexus.component role="com.opensymphony.xwork.Action" role-hint="showArtifactAction"
*/ */
public class ShowArtifactAction public class ShowArtifactAction
extends PlexusActionSupport extends PlexusActionSupport
{ {
/** /* .\ Not Exposed \._____________________________________________ */
* @plexus.requirement
*/
private ArtifactFactory artifactFactory;
/** /**
* @plexus.requirement * @plexus.requirement
*/ */
private ConfiguredRepositoryFactory repositoryFactory; private ArchivaDAO dao;
/**
* @plexus.requirement
*/
private MavenProjectBuilder projectBuilder;
/** /**
* @plexus.requirement * @plexus.requirement
*/ */
private ArchivaConfiguration archivaConfiguration; private ArchivaConfiguration archivaConfiguration;
/** /* .\ Input Parameters \.________________________________________ */
* @plexus.requirement
*/
private RepositoryArtifactIndexFactory factory;
/**
* @plexus.requirement
*/
private ArtifactMetadataSource artifactMetadataSource;
/**
* @plexus.requirement
*/
private ArtifactCollector collector;
/**
* @plexus.requirement
*/
private DependencyTreeBuilder dependencyTreeBuilder;
/**
* @plexus.requirement
*/
ArtifactResultsDatabase artifactsDatabase;
private String groupId; private String groupId;
@ -124,75 +69,81 @@ public class ShowArtifactAction
private String version; private String version;
private Model model; /* .\ Exposed Output Objects \.__________________________________ */
private Collection dependencies; /**
* The model of this versioned project.
*/
private ArchivaProjectModel model;
private List dependencyTree; /**
* The list of artifacts that depend on this versioned project.
private String repositoryId; */
private List dependees;
private String repositoryUrlName;
private String artifactPath;
private List mailingLists;
/**
* The reports associated with this versioned project.
*/
private List reports; private List reports;
/**
* Show the versioned project information tab.
*
* TODO: Change name to 'project'
*/
public String artifact() public String artifact()
throws IOException, XmlPullParserException, ProjectBuildingException, ResourceDoesNotExistException, throws ObjectNotFoundException, ArchivaDatabaseException
ProxyException, ArtifactResolutionException
{ {
if ( !checkParameters() ) if ( !checkParameters() )
{ {
return ERROR; return ERROR;
} }
MavenProject project = readProject(); this.model = readProject();
model = project.getModel();
return SUCCESS; return SUCCESS;
} }
/**
* Show the artifact information tab.
*/
public String dependencies() public String dependencies()
throws IOException, XmlPullParserException, ProjectBuildingException throws ObjectNotFoundException, ArchivaDatabaseException
{ {
if ( !checkParameters() ) if ( !checkParameters() )
{ {
return ERROR; return ERROR;
} }
MavenProject project = readProject(); this.model = readProject();
model = project.getModel();
// TODO: should this be the whole set of artifacts, and be more like the maven dependencies report? // TODO: should this be the whole set of artifacts, and be more like the maven dependencies report?
this.dependencies = VersionMerger.wrap( project.getModel().getDependencies() ); // this.dependencies = VersionMerger.wrap( project.getModel().getDependencies() );
return SUCCESS; return SUCCESS;
} }
/**
* Show the mailing lists information tab.
*/
public String mailingLists() public String mailingLists()
throws IOException, XmlPullParserException, ProjectBuildingException throws ObjectNotFoundException, ArchivaDatabaseException
{ {
if ( !checkParameters() ) if ( !checkParameters() )
{ {
return ERROR; return ERROR;
} }
MavenProject project = readProject(); this.model = readProject();
model = project.getModel();
this.mailingLists = project.getMailingLists();
return SUCCESS; return SUCCESS;
} }
/**
* Show the reports tab.
*/
public String reports() public String reports()
throws IOException, XmlPullParserException, ProjectBuildingException throws ObjectNotFoundException, ArchivaDatabaseException
{ {
if ( !checkParameters() ) if ( !checkParameters() )
{ {
@ -200,115 +151,51 @@ public class ShowArtifactAction
} }
System.out.println("#### In reports."); System.out.println("#### In reports.");
this.reports = artifactsDatabase.findArtifactResults( groupId, artifactId, version ); // TODO: hook up reports on project - this.reports = artifactsDatabase.findArtifactResults( groupId, artifactId, version );
System.out.println("#### Found " + reports.size() + " reports."); System.out.println("#### Found " + reports.size() + " reports.");
return SUCCESS; return SUCCESS;
} }
/**
* Show the dependees (other artifacts that depend on this project) tab.
*/
public String dependees() public String dependees()
throws IOException, XmlPullParserException, ProjectBuildingException, RepositoryIndexException, throws ObjectNotFoundException, ArchivaDatabaseException
RepositoryIndexSearchException
{ {
if ( !checkParameters() ) if ( !checkParameters() )
{ {
return ERROR; return ERROR;
} }
MavenProject project = readProject(); this.model = readProject();
model = project.getModel(); // TODO: create depends on collector.
this.dependees = Collections.EMPTY_LIST;
RepositoryArtifactIndex index = getIndex();
String id = createId( groupId, artifactId, version );
List records = index.search( new LuceneQuery( new TermQuery( new Term( "dependencies", id ) ) ) );
dependencies = VersionMerger.merge( records );
return SUCCESS; return SUCCESS;
} }
/**
* Show the dependencies of this versioned project tab.
*/
public String dependencyTree() public String dependencyTree()
throws ProjectBuildingException, InvalidDependencyVersionException, ArtifactResolutionException throws ObjectNotFoundException, ArchivaDatabaseException
{ {
if ( !checkParameters() ) if ( !checkParameters() )
{ {
return ERROR; return ERROR;
} }
Configuration configuration = archivaConfiguration.getConfiguration(); this.model = readProject();
List repositories = repositoryFactory.createRepositories( configuration );
Artifact artifact = artifactFactory.createProjectArtifact( groupId, artifactId, version );
// TODO: maybe we can decouple the assembly parts of the project builder from the repository handling to get rid of the temp repo
ArtifactRepository localRepository = repositoryFactory.createLocalRepository( configuration );
MavenProject project = projectBuilder.buildFromRepository( artifact, repositories, localRepository );
model = project.getModel();
getLogger().debug( " processing : " + groupId + ":" + artifactId + ":" + version );
DependencyTree dependencies = collectDependencies( project, localRepository );
this.dependencyTree = new ArrayList();
populateFlatTreeList( dependencies.getRootNode(), dependencyTree );
return SUCCESS; return SUCCESS;
} }
private void populateFlatTreeList( DependencyNode currentNode, List dependencyList ) private ArchivaProjectModel readProject()
throws ObjectNotFoundException, ArchivaDatabaseException
{ {
DependencyNode childNode; return dao.getProjectModelDAO().getProjectModel( groupId, artifactId, version );
for ( Iterator iterator = currentNode.getChildren().iterator(); iterator.hasNext(); )
{
childNode = (DependencyNode) iterator.next();
dependencyList.add( childNode );
populateFlatTreeList( childNode, dependencyList );
}
}
private DependencyTree collectDependencies( MavenProject project, ArtifactRepository localRepository )
throws ArtifactResolutionException, ProjectBuildingException, InvalidDependencyVersionException
{
try
{
return dependencyTreeBuilder.buildDependencyTree( project, localRepository, artifactFactory,
artifactMetadataSource, collector );
}
catch ( DependencyTreeBuilderException e )
{
getLogger().error( "Unable to build dependency tree.", e );
return null;
}
}
private static String createId( String groupId, String artifactId, String version )
{
return groupId + ":" + artifactId + ":" + version;
}
private RepositoryArtifactIndex getIndex()
throws RepositoryIndexException
{
Configuration configuration = archivaConfiguration.getConfiguration();
File indexPath = new File( configuration.getIndexPath() );
return factory.createStandardIndex( indexPath );
}
private MavenProject readProject()
throws ProjectBuildingException
{
Configuration configuration = archivaConfiguration.getConfiguration();
List repositories = repositoryFactory.createRepositories( configuration );
Artifact artifact = artifactFactory.createProjectArtifact( groupId, artifactId, version );
// TODO: maybe we can decouple the assembly parts of the project builder from the repository handling to get rid of the temp repo
ArtifactRepository localRepository = repositoryFactory.createLocalRepository( configuration );
return projectBuilder.buildFromRepository( artifact, repositories, localRepository );
} }
private boolean checkParameters() private boolean checkParameters()
@ -338,16 +225,11 @@ public class ShowArtifactAction
return result; return result;
} }
public Model getModel() public ArchivaProjectModel getModel()
{ {
return model; return model;
} }
public Collection getDependencies()
{
return dependencies;
}
public String getGroupId() public String getGroupId()
{ {
return groupId; return groupId;
@ -368,11 +250,6 @@ public class ShowArtifactAction
this.artifactId = artifactId; this.artifactId = artifactId;
} }
public List getDependencyTree()
{
return dependencyTree;
}
public String getVersion() public String getVersion()
{ {
return version; return version;
@ -383,165 +260,6 @@ public class ShowArtifactAction
this.version = version; this.version = version;
} }
public String getArtifactPath()
{
return artifactPath;
}
public static class DependencyWrapper
{
private final String groupId;
private final String artifactId;
/**
* Versions added. We ignore duplicates since you might add those with varying classifiers.
*/
private Set versions = new HashSet();
private String version;
private String scope;
private String classifier;
public DependencyWrapper( StandardArtifactIndexRecord record )
{
this.groupId = record.getGroupId();
this.artifactId = record.getArtifactId();
addVersion( record.getVersion() );
}
public DependencyWrapper( Dependency dependency )
{
this.groupId = dependency.getGroupId();
this.artifactId = dependency.getArtifactId();
this.scope = dependency.getScope();
this.classifier = dependency.getClassifier();
addVersion( dependency.getVersion() );
}
public String getScope()
{
return scope;
}
public String getClassifier()
{
return classifier;
}
public void addVersion( String version )
{
// We use DefaultArtifactVersion to get the correct sorting order later, however it does not have
// hashCode properly implemented, so we add it here.
// TODO: add these methods to the actual DefaultArtifactVersion and use that.
versions.add( new DefaultArtifactVersion( version )
{
public int hashCode()
{
int result;
result = getBuildNumber();
result = 31 * result + getMajorVersion();
result = 31 * result + getMinorVersion();
result = 31 * result + getIncrementalVersion();
result = 31 * result + ( getQualifier() != null ? getQualifier().hashCode() : 0 );
return result;
}
public boolean equals( Object o )
{
if ( this == o )
{
return true;
}
if ( o == null || getClass() != o.getClass() )
{
return false;
}
DefaultArtifactVersion that = (DefaultArtifactVersion) o;
if ( getBuildNumber() != that.getBuildNumber() )
{
return false;
}
if ( getIncrementalVersion() != that.getIncrementalVersion() )
{
return false;
}
if ( getMajorVersion() != that.getMajorVersion() )
{
return false;
}
if ( getMinorVersion() != that.getMinorVersion() )
{
return false;
}
if ( getQualifier() != null ? !getQualifier().equals( that.getQualifier() )
: that.getQualifier() != null )
{
return false;
}
return true;
}
} );
if ( versions.size() == 1 )
{
this.version = version;
}
else
{
this.version = null;
}
}
public String getGroupId()
{
return groupId;
}
public String getArtifactId()
{
return artifactId;
}
public List getVersions()
{
List versions = new ArrayList( this.versions );
Collections.sort( versions );
return versions;
}
public String getVersion()
{
return version;
}
}
public String getRepositoryId()
{
return repositoryId;
}
public List getMailingLists()
{
return mailingLists;
}
public String getRepositoryUrlName()
{
return repositoryUrlName;
}
public List getReports() public List getReports()
{ {
return reports; return reports;

View File

@ -19,9 +19,11 @@ package org.apache.maven.archiva.web.check;
* under the License. * under the License.
*/ */
import org.apache.maven.archiva.configuration.ArchivaConfiguration;
import org.apache.maven.archiva.configuration.Configuration;
import org.apache.maven.archiva.configuration.RepositoryConfiguration; import org.apache.maven.archiva.configuration.RepositoryConfiguration;
import org.apache.maven.archiva.database.ArchivaDAO;
import org.apache.maven.archiva.database.ArchivaDatabaseException;
import org.apache.maven.archiva.database.ObjectNotFoundException;
import org.apache.maven.archiva.model.ArchivaRepository;
import org.codehaus.plexus.logging.AbstractLogEnabled; import org.codehaus.plexus.logging.AbstractLogEnabled;
import org.codehaus.plexus.rbac.profile.RoleProfileException; import org.codehaus.plexus.rbac.profile.RoleProfileException;
import org.codehaus.plexus.rbac.profile.RoleProfileManager; import org.codehaus.plexus.rbac.profile.RoleProfileManager;
@ -49,7 +51,7 @@ public class RoleExistanceEnvironmentCheck
/** /**
* @plexus.requirement * @plexus.requirement
*/ */
private ArchivaConfiguration archivaConfiguration; private ArchivaDAO dao;
/** /**
* @plexus.requirement role-hint="archiva" * @plexus.requirement role-hint="archiva"
@ -64,15 +66,14 @@ public class RoleExistanceEnvironmentCheck
{ {
try try
{ {
// check if there is potential for role/repo disconnect List repos = dao.getRepositoryDAO().getRepositories();
Configuration configuration = archivaConfiguration.getConfiguration();
if ( configuration.isValid() )
{
List repos = configuration.getRepositories();
for ( Iterator i = repos.iterator(); i.hasNext(); ) if ( hasManagedRepository( repos ) )
{ {
RepositoryConfiguration repository = (RepositoryConfiguration) i.next(); Iterator it = repos.iterator();
while ( it.hasNext() )
{
RepositoryConfiguration repository = (RepositoryConfiguration) it.next();
roleProfileManager.getDynamicRole( "archiva-repository-manager", repository.getId() ); roleProfileManager.getDynamicRole( "archiva-repository-manager", repository.getId() );
@ -85,9 +86,33 @@ public class RoleExistanceEnvironmentCheck
list.add( this.getClass().getName() + "error initializing roles: " + rpe.getMessage() ); list.add( this.getClass().getName() + "error initializing roles: " + rpe.getMessage() );
getLogger().info( "error initializing roles", rpe ); getLogger().info( "error initializing roles", rpe );
} }
catch ( ObjectNotFoundException e )
{
list.add( this.getClass().getName() + "error initializing roles (repository not found): " + e.getMessage() );
getLogger().info( "error initializing roles", e );
}
catch ( ArchivaDatabaseException e )
{
list.add( this.getClass().getName() + "error initializing roles (database error): " + e.getMessage() );
getLogger().info( "error initializing roles", e );
}
checked = true; checked = true;
} }
} }
public boolean hasManagedRepository( List repos )
{
Iterator it = repos.iterator();
while ( it.hasNext() )
{
ArchivaRepository repo = (ArchivaRepository) it.next();
if ( repo.isManaged() )
{
return true;
}
}
return false;
}
} }

View File

@ -21,10 +21,14 @@ package org.apache.maven.archiva.web.interceptor;
import com.opensymphony.xwork.ActionInvocation; import com.opensymphony.xwork.ActionInvocation;
import com.opensymphony.xwork.interceptor.Interceptor; import com.opensymphony.xwork.interceptor.Interceptor;
import org.apache.maven.archiva.configuration.ArchivaConfiguration;
import org.apache.maven.archiva.configuration.Configuration; import org.apache.maven.archiva.database.ArchivaDAO;
import org.apache.maven.archiva.model.ArchivaRepository;
import org.codehaus.plexus.logging.AbstractLogEnabled; import org.codehaus.plexus.logging.AbstractLogEnabled;
import java.util.Iterator;
import java.util.List;
/** /**
* An interceptor that makes the application configuration available * An interceptor that makes the application configuration available
* *
@ -39,7 +43,7 @@ public class ConfigurationInterceptor
/** /**
* @plexus.requirement * @plexus.requirement
*/ */
private ArchivaConfiguration archivaConfiguration; private ArchivaDAO dao;
/** /**
* @param actionInvocation * @param actionInvocation
@ -49,22 +53,14 @@ public class ConfigurationInterceptor
public String intercept( ActionInvocation actionInvocation ) public String intercept( ActionInvocation actionInvocation )
throws Exception throws Exception
{ {
Configuration configuration = archivaConfiguration.getConfiguration(); List repos = dao.getRepositoryDAO().getRepositories();
if ( !configuration.isValid() ) if ( !hasManagedRepository( repos ) )
{ {
if ( configuration.getRepositories().isEmpty() ) getLogger().info( "No repositories exist - forwarding to repository configuration page" );
{
getLogger().info( "No repositories were configured - forwarding to repository configuration page" );
return "config-repository-needed"; return "config-repository-needed";
} }
else else
{
getLogger().info( "Configuration is incomplete - forwarding to configuration page" );
return "config-needed";
}
}
else
{ {
return actionInvocation.invoke(); return actionInvocation.invoke();
} }
@ -79,4 +75,29 @@ public class ConfigurationInterceptor
{ {
// This space left intentionally blank // This space left intentionally blank
} }
public boolean hasManagedRepository( List repos )
{
if ( repos == null )
{
return false;
}
if ( repos.isEmpty() )
{
return false;
}
Iterator it = repos.iterator();
while ( it.hasNext() )
{
ArchivaRepository repo = (ArchivaRepository) it.next();
if ( repo.isManaged() )
{
return true;
}
}
return false;
}
} }

View File

@ -74,11 +74,6 @@ public class ProxiedDavServer
*/ */
private ProxyRequestHandler proxyRequestHandler; private ProxyRequestHandler proxyRequestHandler;
/**
* @plexus.requirement
*/
private ConfiguredRepositoryFactory repositoryFactory;
private RepositoryConfiguration repositoryConfiguration; private RepositoryConfiguration repositoryConfiguration;
private ArtifactRepository managedRepository; private ArtifactRepository managedRepository;

View File

@ -20,8 +20,10 @@ package org.apache.maven.archiva.web.repository;
*/ */
import org.apache.maven.archiva.configuration.ArchivaConfiguration; import org.apache.maven.archiva.configuration.ArchivaConfiguration;
import org.apache.maven.archiva.configuration.Configuration; import org.apache.maven.archiva.database.ArchivaDAO;
import org.apache.maven.archiva.configuration.RepositoryConfiguration; import org.apache.maven.archiva.database.ArchivaDatabaseException;
import org.apache.maven.archiva.database.ObjectNotFoundException;
import org.apache.maven.archiva.model.ArchivaRepository;
import org.apache.maven.archiva.security.ArchivaRoleConstants; import org.apache.maven.archiva.security.ArchivaRoleConstants;
import org.codehaus.plexus.registry.Registry; import org.codehaus.plexus.registry.Registry;
import org.codehaus.plexus.registry.RegistryListener; import org.codehaus.plexus.registry.RegistryListener;
@ -40,15 +42,16 @@ import org.codehaus.plexus.webdav.servlet.DavServerRequest;
import org.codehaus.plexus.webdav.servlet.multiplexed.MultiplexedWebDavServlet; import org.codehaus.plexus.webdav.servlet.multiplexed.MultiplexedWebDavServlet;
import org.codehaus.plexus.webdav.util.WebdavMethodUtil; import org.codehaus.plexus.webdav.util.WebdavMethodUtil;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.File; 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;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/** /**
* RepositoryServlet * RepositoryServlet
* *
@ -74,9 +77,15 @@ public class RepositoryServlet
*/ */
private AuditLog audit; private AuditLog audit;
private Configuration configuration; /**
* @plexus.requirement role-hint="jdo"
*/
private ArchivaDAO dao;
private ArchivaConfiguration archivaConfiguration; /**
* @plexus.requirement
*/
private ArchivaConfiguration configuration;
public void initComponents() public void initComponents()
throws ServletException throws ServletException
@ -87,46 +96,73 @@ public class RepositoryServlet
httpAuth = (HttpAuthenticator) lookup( HttpAuthenticator.ROLE, "basic" ); httpAuth = (HttpAuthenticator) lookup( HttpAuthenticator.ROLE, "basic" );
audit = (AuditLog) lookup( AuditLog.ROLE ); audit = (AuditLog) lookup( AuditLog.ROLE );
archivaConfiguration = (ArchivaConfiguration) lookup( ArchivaConfiguration.class.getName() ); dao = (ArchivaDAO) lookup( ArchivaDAO.ROLE, "jdo" );
configuration = archivaConfiguration.getConfiguration(); configuration = (ArchivaConfiguration) lookup( ArchivaConfiguration.class.getName() );
archivaConfiguration.addChangeListener( this ); configuration.addChangeListener( this );
} }
public void initServers( ServletConfig servletConfig ) public void initServers( ServletConfig servletConfig )
throws DavServerException throws DavServerException
{ {
List repositories = configuration.getRepositories(); try
{
List repositories = dao.getRepositoryDAO().getRepositories();
Iterator itrepos = repositories.iterator(); Iterator itrepos = repositories.iterator();
while ( itrepos.hasNext() ) while ( itrepos.hasNext() )
{ {
RepositoryConfiguration repoConfig = (RepositoryConfiguration) itrepos.next(); ArchivaRepository repo = (ArchivaRepository) itrepos.next();
File repoDir = new File( repoConfig.getDirectory() ); if ( !repo.isManaged() )
{
// Skip non-managed.
continue;
}
File repoDir = new File( repo.getUrl().getPath() );
if ( !repoDir.exists() ) if ( !repoDir.exists() )
{ {
repoDir.mkdirs(); repoDir.mkdirs();
} }
DavServerComponent server = createServer( repoConfig.getUrlName(), repoDir, servletConfig ); DavServerComponent server = createServer( repo.getId(), repoDir, servletConfig );
server.addListener( audit ); server.addListener( audit );
} }
} }
catch ( ArchivaDatabaseException e )
public RepositoryConfiguration getRepositoryConfiguration( DavServerRequest request )
{ {
return configuration.getRepositoryByUrlName( request.getPrefix() ); throw new DavServerException( "Unable to initialized dav servers: " + e.getMessage(), e );
}
}
public ArchivaRepository getRepository( DavServerRequest request )
{
String id = request.getPrefix();
try
{
return dao.getRepositoryDAO().getRepository( id );
}
catch ( ObjectNotFoundException e )
{
log( "Unable to find repository for id [" + id + "]" );
return null;
}
catch ( ArchivaDatabaseException e )
{
log( "Unable to find repository for id [" + id + "]: " + e.getMessage(), e );
return null;
}
} }
public String getRepositoryName( DavServerRequest request ) public String getRepositoryName( DavServerRequest request )
{ {
RepositoryConfiguration repoConfig = getRepositoryConfiguration( request ); ArchivaRepository repoConfig = getRepository( request );
if ( repoConfig == null ) if ( repoConfig == null )
{ {
return "Unknown"; return "Unknown";
} }
return repoConfig.getName(); return repoConfig.getModel().getName();
} }
public boolean isAuthenticated( DavServerRequest davRequest, HttpServletResponse response ) public boolean isAuthenticated( DavServerRequest davRequest, HttpServletResponse response )
@ -146,7 +182,6 @@ public class RepositoryServlet
new AuthenticationException( "User Credentials Invalid" ) ); new AuthenticationException( "User Credentials Invalid" ) );
return false; return false;
} }
} }
catch ( AuthenticationException e ) catch ( AuthenticationException e )
{ {
@ -185,16 +220,15 @@ public class RepositoryServlet
permission = ArchivaRoleConstants.OPERATION_REPOSITORY_UPLOAD; permission = ArchivaRoleConstants.OPERATION_REPOSITORY_UPLOAD;
} }
AuthorizationResult authzResult = AuthorizationResult authzResult = securitySystem.authorize( securitySession, permission, davRequest
securitySystem.authorize( securitySession, permission, getRepositoryConfiguration( davRequest ) .getPrefix() );
.getId() );
if ( !authzResult.isAuthorized() ) if ( !authzResult.isAuthorized() )
{ {
if ( authzResult.getException() != null ) if ( authzResult.getException() != null )
{ {
log( "Authorization Denied [ip=" + request.getRemoteAddr() + ",isWriteRequest=" + isWriteRequest + log( "Authorization Denied [ip=" + request.getRemoteAddr() + ",isWriteRequest=" + isWriteRequest
",permission=" + permission + "] : " + authzResult.getException().getMessage() ); + ",permission=" + permission + "] : " + authzResult.getException().getMessage() );
} }
// Issue HTTP Challenge. // Issue HTTP Challenge.
@ -218,12 +252,9 @@ public class RepositoryServlet
public void afterConfigurationChange( Registry registry, String propertyName, Object propertyValue ) public void afterConfigurationChange( Registry registry, String propertyName, Object propertyValue )
{ {
configuration = archivaConfiguration.getConfiguration();
if ( propertyName.startsWith( "repositories" ) ) if ( propertyName.startsWith( "repositories" ) )
{ {
log( "Triggering managed repository configuration change with " + propertyName + " set to " + log( "Triggering managed repository configuration change with " + propertyName + " set to " + propertyValue );
propertyValue );
getDavManager().removeAllServers(); getDavManager().removeAllServers();
try try

View File

@ -25,17 +25,22 @@ import com.opensymphony.xwork.util.OgnlValueStack;
import org.apache.commons.lang.StringEscapeUtils; import org.apache.commons.lang.StringEscapeUtils;
import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.StringUtils;
import org.apache.maven.archiva.common.artifact.managed.ManagedArtifact; import org.apache.maven.archiva.database.ArchivaDAO;
import org.apache.maven.archiva.configuration.RepositoryConfiguration; import org.apache.maven.archiva.database.ArchivaDatabaseException;
import org.apache.maven.archiva.repositories.ActiveManagedRepositories; import org.apache.maven.archiva.database.Constraint;
import org.apache.maven.project.ProjectBuildingException; import org.apache.maven.archiva.database.ObjectNotFoundException;
import org.apache.maven.archiva.database.constraints.ArtifactsRelatedConstraint;
import org.apache.maven.archiva.model.ArchivaArtifact;
import org.apache.maven.archiva.model.ArchivaRepository;
import org.apache.maven.archiva.repository.layout.BidirectionalRepositoryLayout;
import org.apache.maven.archiva.repository.layout.BidirectionalRepositoryLayoutFactory;
import org.apache.maven.archiva.repository.layout.LayoutException;
import org.codehaus.plexus.component.repository.exception.ComponentLookupException; import org.codehaus.plexus.component.repository.exception.ComponentLookupException;
import java.io.IOException; import java.io.IOException;
import java.io.Writer; import java.io.Writer;
import java.util.Iterator; import java.util.Iterator;
import java.util.Map; import java.util.List;
import java.util.Map.Entry;
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
@ -56,7 +61,12 @@ public class DownloadArtifact
/** /**
* @plexus.requirement * @plexus.requirement
*/ */
private ActiveManagedRepositories managedRepositories; private ArchivaDAO dao;
/**
* @plexus.requirement
*/
private BidirectionalRepositoryLayoutFactory layoutFactory;
private HttpServletRequest req; private HttpServletRequest req;
@ -77,8 +87,7 @@ public class DownloadArtifact
this.res = (HttpServletResponse) pageContext.getResponse(); this.res = (HttpServletResponse) pageContext.getResponse();
try try
{ {
managedRepositories = (ActiveManagedRepositories) PlexusTagUtil.lookup( pageContext, dao = (ArchivaDAO) PlexusTagUtil.lookup( pageContext, ArchivaDAO.ROLE );
ActiveManagedRepositories.ROLE );
} }
catch ( ComponentLookupException e ) catch ( ComponentLookupException e )
{ {
@ -92,25 +101,36 @@ public class DownloadArtifact
try try
{ {
ManagedArtifact managedArtifact = managedRepositories.findArtifact( groupId, artifactId, version ); Constraint constraint = new ArtifactsRelatedConstraint( groupId, artifactId, version );
List relatedArtifacts = dao.getArtifactDAO().queryArtifacts( constraint );
if ( managedArtifact != null ) if ( relatedArtifacts != null )
{ {
RepositoryConfiguration repoConfig = managedRepositories.getRepositoryConfiguration( managedArtifact String repoId = ( (ArchivaArtifact) relatedArtifacts.get( 0 ) ).getModel().getRepositoryId();
.getRepositoryId() ); ArchivaRepository repo = dao.getRepositoryDAO().getRepository( repoId );
String prefix = req.getContextPath() + "/repository/" + repoConfig.getUrlName(); BidirectionalRepositoryLayout layout = layoutFactory.getLayout( repo.getLayoutType() );
String prefix = req.getContextPath() + "/repository/" + repoId;
if ( mini ) if ( mini )
{ {
appendMini( sb, prefix, managedArtifact ); appendMini( sb, prefix, repo, layout, relatedArtifacts );
} }
else else
{ {
appendNormal( sb, prefix, managedArtifact ); appendNormal( sb, prefix, repo, layout, relatedArtifacts );
} }
} }
} }
catch ( ProjectBuildingException e ) catch ( ObjectNotFoundException e )
{
appendError( sb, e );
}
catch ( ArchivaDatabaseException e )
{
appendError( sb, e );
}
catch ( LayoutException e )
{ {
appendError( sb, e ); appendError( sb, e );
} }
@ -127,17 +147,19 @@ public class DownloadArtifact
return super.end( writer, body ); return super.end( writer, body );
} }
private void appendError( StringBuffer sb, ProjectBuildingException e ) private void appendError( StringBuffer sb, Exception e )
{ {
/* do nothing */ /* do nothing */
} }
private void appendMini( StringBuffer sb, String prefix, ManagedArtifact managedArtifact ) private void appendMini( StringBuffer sb, String prefix, ArchivaRepository repo,
BidirectionalRepositoryLayout layout, List relatedArtifacts )
{ {
/* do nothing */ /* do nothing */
} }
private void appendNormal( StringBuffer sb, String prefix, ManagedArtifact managedArtifact ) private void appendNormal( StringBuffer sb, String prefix, ArchivaRepository repo,
BidirectionalRepositoryLayout layout, List relatedArtifacts )
{ {
/* /*
* <div class="download"> * <div class="download">
@ -161,33 +183,25 @@ public class DownloadArtifact
// Heading // Heading
sb.append( "<h2>" ); sb.append( "<h2>" );
if ( managedArtifact.getAttached().isEmpty() ) if ( relatedArtifacts.size() > 1 )
{ {
sb.append( "Download" ); sb.append( "Downloads" );
} }
else else
{ {
sb.append( "Downloads" ); sb.append( "Download" );
} }
sb.append( "</h2>" ); sb.append( "</h2>" );
// Body // Body
sb.append( "<p class=\"body\">" ); sb.append( "<p class=\"body\">" );
appendLink( sb, prefix, managedArtifact.getPath(), "main" ); Iterator it = relatedArtifacts.iterator();
Iterator it = managedArtifact.getAttached().entrySet().iterator();
while ( it.hasNext() ) while ( it.hasNext() )
{ {
Map.Entry entry = (Entry) it.next(); ArchivaArtifact artifact = (ArchivaArtifact) it.next();
String type = (String) entry.getKey();
String path = (String) entry.getValue();
if ( StringUtils.isNotBlank( path ) ) appendLink( sb, prefix, layout, artifact );
{
sb.append( "<br/>" );
appendLink( sb, prefix, path, type );
}
} }
sb.append( "</div>" ); // close "downloadbox.bd.c" sb.append( "</div>" ); // close "downloadbox.bd.c"
@ -197,9 +211,12 @@ public class DownloadArtifact
sb.append( "</div>" ); // close "download" sb.append( "</div>" ); // close "download"
} }
private void appendLink( StringBuffer sb, String prefix, String path, String type ) private void appendLink( StringBuffer sb, String prefix, BidirectionalRepositoryLayout layout,
ArchivaArtifact artifact )
{ {
StringBuffer url = new StringBuffer(); StringBuffer url = new StringBuffer();
String path = layout.toPath( artifact );
String type = artifact.getType();
url.append( prefix ); url.append( prefix );
url.append( "/" ).append( path ); url.append( "/" ).append( path );