You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@archiva.apache.org by br...@apache.org on 2006/12/11 07:43:40 UTC

svn commit: r485529 - in /maven/archiva/trunk/archiva-webapp/src/main: java/org/apache/maven/archiva/web/action/ShowArtifactAction.java webapp/WEB-INF/jsp/showArtifact.jsp

Author: brett
Date: Sun Dec 10 22:43:39 2006
New Revision: 485529

URL: http://svn.apache.org/viewvc?view=rev&rev=485529
Log:
[MRM-242] Replace the proxy url of the Download link into the absolute url
Submitted by: Nap Ramirez (applied with modifications)

Modified:
    maven/archiva/trunk/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/ShowArtifactAction.java
    maven/archiva/trunk/archiva-webapp/src/main/webapp/WEB-INF/jsp/showArtifact.jsp

Modified: maven/archiva/trunk/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/ShowArtifactAction.java
URL: http://svn.apache.org/viewvc/maven/archiva/trunk/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/ShowArtifactAction.java?view=diff&rev=485529&r1=485528&r2=485529
==============================================================================
--- maven/archiva/trunk/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/ShowArtifactAction.java (original)
+++ maven/archiva/trunk/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/ShowArtifactAction.java Sun Dec 10 22:43:39 2006
@@ -16,6 +16,7 @@
  * limitations under the License.
  */
 
+import org.apache.commons.lang.StringUtils;
 import org.apache.lucene.index.Term;
 import org.apache.lucene.search.TermQuery;
 import org.apache.maven.archiva.configuration.Configuration;
@@ -28,6 +29,7 @@
 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.web.util.VersionMerger;
 import org.apache.maven.artifact.Artifact;
 import org.apache.maven.artifact.factory.ArtifactFactory;
@@ -35,6 +37,7 @@
 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.resolver.ArtifactResolver;
 import org.apache.maven.artifact.versioning.DefaultArtifactVersion;
 import org.apache.maven.model.Dependency;
 import org.apache.maven.model.Model;
@@ -46,7 +49,7 @@
 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.commons.lang.StringUtils;
+import org.apache.maven.wagon.ResourceDoesNotExistException;
 import org.codehaus.plexus.util.xml.pull.XmlPullParserException;
 import org.codehaus.plexus.xwork.action.PlexusActionSupport;
 
@@ -102,12 +105,17 @@
      * @plexus.requirement
      */
     private ArtifactCollector collector;
-    
+
     /**
      * @plexus.requirement
      */
     private DependencyTreeBuilder dependencyTreeBuilder;
 
+    /**
+     * @plexus.requirement
+     */
+    private ArtifactResolver artifactResolver;
+
     private String groupId;
 
     private String artifactId;
@@ -117,11 +125,16 @@
     private Model model;
 
     private Collection dependencies;
-    
+
     private List dependencyTree;
 
+    private String repositoryId;
+
+    private String artifactPath;
+
     public String artifact()
-        throws ConfigurationStoreException, IOException, XmlPullParserException, ProjectBuildingException
+        throws ConfigurationStoreException, IOException, XmlPullParserException, ProjectBuildingException,
+        ResourceDoesNotExistException, ProxyException, ArtifactResolutionException
     {
         if ( !checkParameters() )
         {
@@ -132,6 +145,26 @@
 
         model = project.getModel();
 
+        Configuration configuration = configurationStore.getConfigurationFromStore();
+        List repositories = repositoryFactory.createRepositories( configuration );
+
+        Artifact artifact = artifactFactory.createBuildArtifact( project.getGroupId(), project.getArtifactId(),
+                                                                 project.getVersion(), project.getPackaging() );
+
+        for ( Iterator i = repositories.iterator(); i.hasNext(); )
+        {
+            ArtifactRepository repository = (ArtifactRepository) i.next();
+
+            String path = repository.pathOf( artifact );
+            File f = new File( repository.getBasedir(), path );
+            if ( f.exists() )
+            {
+                repositoryId = repository.getId();
+
+                artifactPath = path;
+            }
+        }
+
         return SUCCESS;
     }
 
@@ -148,7 +181,7 @@
         model = project.getModel();
 
         // 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;
     }
@@ -171,7 +204,7 @@
         String id = createId( groupId, artifactId, version );
         List records = index.search( new LuceneQuery( new TermQuery( new Term( "dependencies", id ) ) ) );
 
-        dependencies = VersionMerger.merge(records);
+        dependencies = VersionMerger.merge( records );
 
         return SUCCESS;
     }
@@ -197,11 +230,10 @@
 
         getLogger().debug( " processing : " + groupId + ":" + artifactId + ":" + version );
 
-        DependencyTree dependencies =
-            collectDependencies( project, artifact, localRepository, repositories );
-        
+        DependencyTree dependencies = collectDependencies( project, artifact, localRepository, repositories );
+
         this.dependencyTree = new ArrayList();
-        
+
         populateFlatTreeList( dependencies.getRootNode(), dependencyTree );
 
         return SUCCESS;
@@ -220,7 +252,7 @@
     }
 
     private DependencyTree collectDependencies( MavenProject project, Artifact artifact,
-                                              ArtifactRepository localRepository, List repositories )
+                                                ArtifactRepository localRepository, List repositories )
         throws ArtifactResolutionException, ProjectBuildingException, InvalidDependencyVersionException,
         ConfigurationStoreException
     {
@@ -323,7 +355,7 @@
     {
         return dependencyTree;
     }
-    
+
     public String getVersion()
     {
         return version;
@@ -334,6 +366,11 @@
         this.version = version;
     }
 
+    public String getArtifactPath()
+    {
+        return artifactPath;
+    }
+
     public static class DependencyWrapper
     {
         private final String groupId;
@@ -473,4 +510,8 @@
         }
     }
 
+    public String getRepositoryId()
+    {
+        return repositoryId;
+    }
 }

Modified: maven/archiva/trunk/archiva-webapp/src/main/webapp/WEB-INF/jsp/showArtifact.jsp
URL: http://svn.apache.org/viewvc/maven/archiva/trunk/archiva-webapp/src/main/webapp/WEB-INF/jsp/showArtifact.jsp?view=diff&rev=485529&r1=485528&r2=485529
==============================================================================
--- maven/archiva/trunk/archiva-webapp/src/main/webapp/WEB-INF/jsp/showArtifact.jsp (original)
+++ maven/archiva/trunk/archiva-webapp/src/main/webapp/WEB-INF/jsp/showArtifact.jsp Sun Dec 10 22:43:39 2006
@@ -70,15 +70,8 @@
 
 <div class="sidebar3">
   <div id="download">
-    <c:set var="url">
-      <ww:url action="proxy">
-        <%-- TODO! create a tag for this, include classifier for javadoc, sources below --%>
-        <%-- TODO: what about other repositories? --%>
-        <%-- TODO! extension probably doesn't match type. Use artifact handler instead. --%>
-        <ww:param name="path"
-                  value="%{'${model.groupId}/${model.artifactId}/${model.version}/${model.artifactId}-${model.version}.${model.packaging}'}"/>
-      </ww:url>
-    </c:set>
+    <%-- TODO! create a tag for this, include classifier for javadoc, sources below --%>
+    <c:url var="url" value="/repository/${repositoryId}/${artifactPath}"/>
     <a href="${url}">Download</a>
   </div>
 </div>