move internal class oArtifactDownloadInfo to rest api to have a reusable class

git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1340411 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Olivier Lamy 2012-05-19 10:43:26 +00:00
parent f95589e117
commit fce624a1fe
1 changed files with 30 additions and 136 deletions

View File

@ -32,20 +32,18 @@ import org.apache.archiva.metadata.repository.MetadataRepositoryException;
import org.apache.archiva.metadata.repository.MetadataResolutionException; import org.apache.archiva.metadata.repository.MetadataResolutionException;
import org.apache.archiva.metadata.repository.MetadataResolver; import org.apache.archiva.metadata.repository.MetadataResolver;
import org.apache.archiva.metadata.repository.RepositorySession; import org.apache.archiva.metadata.repository.RepositorySession;
import org.apache.archiva.metadata.repository.storage.maven2.MavenArtifactFacet;
import org.apache.archiva.model.ArtifactReference;
import org.apache.archiva.reports.RepositoryProblemFacet; import org.apache.archiva.reports.RepositoryProblemFacet;
import org.apache.archiva.repository.ManagedRepositoryContent;
import org.apache.archiva.repository.RepositoryContentFactory; import org.apache.archiva.repository.RepositoryContentFactory;
import org.apache.archiva.repository.RepositoryException; import org.apache.archiva.repository.RepositoryException;
import org.apache.archiva.repository.RepositoryNotFoundException;
import org.apache.archiva.rest.api.model.ArtifactDownloadInfo;
import org.apache.archiva.rest.services.utils.ArtifactDownloadInfoBuilder;
import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.StringUtils;
import org.apache.maven.artifact.versioning.DefaultArtifactVersion; import org.apache.maven.artifact.versioning.DefaultArtifactVersion;
import org.springframework.context.annotation.Scope; import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Controller; import org.springframework.stereotype.Controller;
import javax.inject.Inject; import javax.inject.Inject;
import java.text.DecimalFormat;
import java.text.DecimalFormatSymbols;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.Collections; import java.util.Collections;
@ -53,7 +51,6 @@ import java.util.Comparator;
import java.util.HashMap; import java.util.HashMap;
import java.util.LinkedHashMap; import java.util.LinkedHashMap;
import java.util.List; import java.util.List;
import java.util.Locale;
import java.util.Map; import java.util.Map;
/** /**
@ -120,13 +117,22 @@ public class ShowArtifactAction
{ {
return handleArtifact( repositorySession ); return handleArtifact( repositorySession );
} }
catch ( Exception e )
{
log.warn( "Unable to getProjectVersionMetadata: " + e.getMessage(), e );
addActionError( "Unable to getProjectVersionMetadata - consult application logs." );
return ERROR;
}
finally finally
{ {
repositorySession.close(); repositorySession.close();
} }
} }
private String handleArtifact( RepositorySession session ) private String handleArtifact( RepositorySession session )
throws RepositoryNotFoundException, RepositoryException
{ {
// In the future, this should be replaced by the repository grouping mechanism, so that we are only making // In the future, this should be replaced by the repository grouping mechanism, so that we are only making
// simple resource requests here and letting the resolver take care of it // simple resource requests here and letting the resolver take care of it
@ -149,6 +155,7 @@ public class ShowArtifactAction
} }
private ProjectVersionMetadata getProjectVersionMetadata( RepositorySession session ) private ProjectVersionMetadata getProjectVersionMetadata( RepositorySession session )
throws RepositoryNotFoundException, RepositoryException
{ {
ProjectVersionMetadata versionMetadata = null; ProjectVersionMetadata versionMetadata = null;
artifacts = new LinkedHashMap<String, List<ArtifactDownloadInfo>>(); artifacts = new LinkedHashMap<String, List<ArtifactDownloadInfo>>();
@ -223,7 +230,10 @@ public class ShowArtifactAction
l = new ArrayList<ArtifactDownloadInfo>(); l = new ArrayList<ArtifactDownloadInfo>();
this.artifacts.put( artifact.getVersion(), l ); this.artifacts.put( artifact.getVersion(), l );
} }
l.add( new ArtifactDownloadInfo( artifact ) ); ArtifactDownloadInfoBuilder builder = new ArtifactDownloadInfoBuilder().forArtifactMetadata(
artifact ).withManagedRepositoryContent(
repositoryFactory.getManagedRepositoryContent( repositoryId ) );
l.add( builder.build() );
} }
} }
} }
@ -390,6 +400,12 @@ public class ShowArtifactAction
// TODO: why re-retrieve? // TODO: why re-retrieve?
projectMetadata = getProjectVersionMetadata( repositorySession ); projectMetadata = getProjectVersionMetadata( repositorySession );
} }
catch ( Exception e )
{
log.warn( "Unable to getProjectVersionMetadata: " + e.getMessage(), e );
addActionError( "Unable to getProjectVersionMetadata - consult application logs." );
return ERROR;
}
finally finally
{ {
repositorySession.close(); repositorySession.close();
@ -459,6 +475,13 @@ public class ShowArtifactAction
return ERROR; return ERROR;
} }
} }
catch ( Exception e )
{
log.warn( "Unable to getProjectVersionMetadata: " + e.getMessage(), e );
addActionError( "Unable to getProjectVersionMetadata - consult application logs." );
return ERROR;
}
finally finally
{ {
repositorySession.close(); repositorySession.close();
@ -612,134 +635,5 @@ public class ShowArtifactAction
this.repositoryFactory = repositoryFactory; this.repositoryFactory = repositoryFactory;
} }
// TODO: move this into the artifact metadata itself via facets where necessary
public class ArtifactDownloadInfo
{
private String type;
private String namespace;
private String project;
private String size;
private String id;
private String repositoryId;
private String version;
private String path;
private String classifier;
public ArtifactDownloadInfo( ArtifactMetadata artifact )
{
repositoryId = artifact.getRepositoryId();
// TODO: use metadata resolver capability instead - maybe the storage path could be stored in the metadata
// though keep in mind the request may not necessarily need to reflect the storage
ManagedRepositoryContent repo;
try
{
repo = repositoryFactory.getManagedRepositoryContent( repositoryId );
}
catch ( RepositoryException e )
{
throw new RuntimeException( e );
}
ArtifactReference ref = new ArtifactReference();
ref.setArtifactId( artifact.getProject() );
ref.setGroupId( artifact.getNamespace() );
ref.setVersion( artifact.getVersion() );
path = repo.toPath( ref );
path = path.substring( 0, path.lastIndexOf( "/" ) + 1 ) + artifact.getId();
// TODO: need to accommodate Maven 1 layout too. Non-maven repository formats will need to generate this
// facet (perhaps on the fly) if wanting to display the Maven 2 elements on the Archiva pages
String type = null;
MavenArtifactFacet facet = (MavenArtifactFacet) artifact.getFacet( MavenArtifactFacet.FACET_ID );
if ( facet != null )
{
this.type = facet.getType();
this.classifier = facet.getClassifier();
}
namespace = artifact.getNamespace();
project = artifact.getProject();
// TODO: find a reusable formatter for this
double s = artifact.getSize();
String symbol = "b";
if ( s > 1024 )
{
symbol = "K";
s /= 1024;
if ( s > 1024 )
{
symbol = "M";
s /= 1024;
if ( s > 1024 )
{
symbol = "G";
s /= 1024;
}
}
}
DecimalFormat df = new DecimalFormat( "#,###.##", new DecimalFormatSymbols( Locale.US ) );
size = df.format( s ) + " " + symbol;
id = artifact.getId();
version = artifact.getVersion();
}
public String getNamespace()
{
return namespace;
}
public String getType()
{
return type;
}
public String getProject()
{
return project;
}
public String getSize()
{
return size;
}
public String getId()
{
return id;
}
public String getVersion()
{
return version;
}
public String getRepositoryId()
{
return repositoryId;
}
public String getPath()
{
return path;
}
public String getClassifier()
{
return classifier;
}
}
} }