Author: olamy
Date: Thu Apr 25 11:30:11 2013
New Revision: 1475709

URL: http://svn.apache.org/r1475709
Log:
try to use timestamped version if exist locally

Modified:
    
archiva/trunk/archiva-modules/archiva-web/archiva-rest/archiva-rest-services/src/main/java/org/apache/archiva/rest/services/DefaultBrowseService.java

Modified: 
archiva/trunk/archiva-modules/archiva-web/archiva-rest/archiva-rest-services/src/main/java/org/apache/archiva/rest/services/DefaultBrowseService.java
URL: 
http://svn.apache.org/viewvc/archiva/trunk/archiva-modules/archiva-web/archiva-rest/archiva-rest-services/src/main/java/org/apache/archiva/rest/services/DefaultBrowseService.java?rev=1475709&r1=1475708&r2=1475709&view=diff
==============================================================================
--- 
archiva/trunk/archiva-modules/archiva-web/archiva-rest/archiva-rest-services/src/main/java/org/apache/archiva/rest/services/DefaultBrowseService.java
 (original)
+++ 
archiva/trunk/archiva-modules/archiva-web/archiva-rest/archiva-rest-services/src/main/java/org/apache/archiva/rest/services/DefaultBrowseService.java
 Thu Apr 25 11:30:11 2013
@@ -23,6 +23,7 @@ import org.apache.archiva.admin.model.be
 import org.apache.archiva.common.utils.VersionComparator;
 import org.apache.archiva.common.utils.VersionUtil;
 import org.apache.archiva.dependency.tree.maven2.DependencyTreeBuilder;
+import org.apache.archiva.maven2.metadata.MavenMetadataReader;
 import org.apache.archiva.maven2.model.Artifact;
 import org.apache.archiva.maven2.model.TreeEntry;
 import org.apache.archiva.metadata.generic.GenericMetadataFacet;
@@ -38,11 +39,13 @@ import org.apache.archiva.metadata.repos
 import 
org.apache.archiva.metadata.repository.storage.maven2.ArtifactMetadataVersionComparator;
 import org.apache.archiva.metadata.repository.storage.maven2.MavenProjectFacet;
 import org.apache.archiva.model.ArchivaArtifact;
+import org.apache.archiva.model.ArchivaRepositoryMetadata;
 import org.apache.archiva.proxy.model.RepositoryProxyConnectors;
 import org.apache.archiva.repository.ManagedRepositoryContent;
 import org.apache.archiva.repository.RepositoryContentFactory;
 import org.apache.archiva.repository.RepositoryException;
 import org.apache.archiva.repository.RepositoryNotFoundException;
+import org.apache.archiva.repository.metadata.MetadataTools;
 import org.apache.archiva.rest.api.model.ArtifactContent;
 import org.apache.archiva.rest.api.model.ArtifactContentEntry;
 import org.apache.archiva.rest.api.model.BrowseResult;
@@ -54,6 +57,7 @@ import org.apache.archiva.rest.api.servi
 import org.apache.archiva.rest.api.services.BrowseService;
 import org.apache.archiva.rest.services.utils.ArtifactContentEntryComparator;
 import org.apache.archiva.security.ArchivaSecurityException;
+import org.apache.archiva.xml.XMLException;
 import org.apache.commons.collections.CollectionUtils;
 import org.apache.commons.io.FileUtils;
 import org.apache.commons.io.IOUtils;
@@ -805,6 +809,37 @@ public class DefaultBrowseService
                     return true;
                 }
 
+                // in case of SNAPSHOT we can have timestamped version locally 
!
+                if ( StringUtils.endsWith( version, VersionUtil.SNAPSHOT ) )
+                {
+                    File metadataFile = new File( file.getParent(), 
MetadataTools.MAVEN_METADATA );
+                    if ( metadataFile.exists() )
+                    {
+                        try
+                        {
+                            ArchivaRepositoryMetadata 
archivaRepositoryMetadata =
+                                MavenMetadataReader.read( metadataFile );
+                            int buildNumber = 
archivaRepositoryMetadata.getSnapshotVersion().getBuildNumber();
+                            String timeStamp = 
archivaRepositoryMetadata.getSnapshotVersion().getTimestamp();
+                            // rebuild file name with timestamped version and 
build number
+                            File timeStampFile = new File( file.getParent(), 
artifactId + "-" + StringUtils.remove( version,
+                                                                               
                               "-"
+                                                                               
                                   + VersionUtil.SNAPSHOT )
+                                + "-" + timeStamp + "-" + Integer.toString( 
buildNumber ) + ( StringUtils.isEmpty(
+                                classifier ) ? "" : "-" + classifier ) + 
".jar" );
+
+                            if ( timeStampFile.exists() )
+                            {
+                                return true;
+                            }
+                        }
+                        catch ( XMLException e )
+                        {
+                            log.warn( "skip fail to find timestamped snapshot 
file: {}", e.getMessage() );
+                        }
+                    }
+                }
+
                 String path = managedRepositoryContent.toPath( archivaArtifact 
);
 
                 file = connectors.fetchFromProxies( managedRepositoryContent, 
path );


Reply via email to