mirror of https://github.com/apache/archiva.git
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:
parent
9e2d664ab3
commit
454fb5b0be
|
@ -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();
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
}
|
|
@ -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 );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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() );
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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 );
|
||||||
|
|
Loading…
Reference in New Issue