aboutsummaryrefslogtreecommitdiffstats
path: root/archiva-modules
diff options
context:
space:
mode:
authorMaria Odea B. Ching <oching@apache.org>2008-04-07 02:56:58 +0000
committerMaria Odea B. Ching <oching@apache.org>2008-04-07 02:56:58 +0000
commitede408e255f4729d19fb12dec94edefd233a27e9 (patch)
tree0ed138ac8f27dd9dd82cc0c7b617e70201291bac /archiva-modules
parent7161e98cd321d7018589f70371e791b32f5fc098 (diff)
downloadarchiva-ede408e255f4729d19fb12dec94edefd233a27e9.tar.gz
archiva-ede408e255f4729d19fb12dec94edefd233a27e9.zip
[MRM-123]
-generate feeds for new artifacts in the repo and new versions of artifacts -added tests git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@645347 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'archiva-modules')
-rw-r--r--archiva-modules/archiva-web/archiva-rss/pom.xml4
-rw-r--r--archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/RssFeedEntry.java11
-rw-r--r--archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/RssFeedGenerator.java70
-rw-r--r--archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/processor/NewArtifactsRssFeedProcessor.java178
-rw-r--r--archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/processor/RssFeedProcessor.java35
-rw-r--r--archiva-modules/archiva-web/archiva-rss/src/test/java/org/apache/archiva/rss/RssFeedGeneratorTest.java23
-rw-r--r--archiva-modules/archiva-web/archiva-rss/src/test/java/org/apache/archiva/rss/processor/NewArtifactsRssFeedProcessorTest.java108
7 files changed, 401 insertions, 28 deletions
diff --git a/archiva-modules/archiva-web/archiva-rss/pom.xml b/archiva-modules/archiva-web/archiva-rss/pom.xml
index 585f1653e..c7909fb43 100644
--- a/archiva-modules/archiva-web/archiva-rss/pom.xml
+++ b/archiva-modules/archiva-web/archiva-rss/pom.xml
@@ -10,6 +10,10 @@
<url>http://maven.apache.org</url>
<dependencies>
<dependency>
+ <groupId>org.apache.archiva</groupId>
+ <artifactId>archiva-model</artifactId>
+ </dependency>
+ <dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
</dependency>
diff --git a/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/RssFeedEntry.java b/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/RssFeedEntry.java
index 9a766d8b1..c1ef9fe69 100644
--- a/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/RssFeedEntry.java
+++ b/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/RssFeedEntry.java
@@ -44,6 +44,17 @@ public class RssFeedEntry
private String guid;
private String source;
+
+ public RssFeedEntry()
+ {
+
+ }
+
+ public RssFeedEntry( String title, String link )
+ {
+ this.title = title;
+ this.link = link;
+ }
public String getTitle()
{
diff --git a/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/RssFeedGenerator.java b/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/RssFeedGenerator.java
index c6f50b341..8357436aa 100644
--- a/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/RssFeedGenerator.java
+++ b/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/RssFeedGenerator.java
@@ -37,7 +37,9 @@ import com.sun.syndication.feed.synd.SyndEntryImpl;
import com.sun.syndication.feed.synd.SyndFeed;
import com.sun.syndication.feed.synd.SyndFeedImpl;
import com.sun.syndication.io.FeedException;
+import com.sun.syndication.io.SyndFeedInput;
import com.sun.syndication.io.SyndFeedOutput;
+import com.sun.syndication.io.XmlReader;
/**
* Generates RSS feeds.
@@ -55,23 +57,52 @@ public class RssFeedGenerator
public static String DEFAULT_FEEDTYPE = "rss_2.0";
public static String DEFAULT_LANGUAGE = "en-us";
+
+ /**
+ * @plexus.configuration default-value="${appserver.base}/data/rss"
+ */
+ private String rssDirectory;
public void generateFeed( String title, String link, String description, List<RssFeedEntry> dataEntries,
- File outputFile )
- {
- SyndFeed feed = new SyndFeedImpl();
- feed.setFeedType( DEFAULT_FEEDTYPE );
+ String outputFilename )
+ {
+ File outputFile = new File( rssDirectory, outputFilename );
+ SyndFeed feed = null;
+ List<SyndEntry> existingEntries = null;
+
+ if( outputFile.exists() )
+ {
+ try
+ {
+ SyndFeedInput input = new SyndFeedInput();
+ feed = input.build( new XmlReader( outputFile ) );
+ existingEntries = feed.getEntries();
+ }
+ catch ( IOException ie )
+ {
+ log.error( "Error occurred while reading existing feed : " + ie.getLocalizedMessage() );
+ }
+ catch ( FeedException fe )
+ {
+ log.error( "Error occurred while reading existing feed : " + fe.getLocalizedMessage() );
+ }
+ }
+ else
+ {
+ feed = new SyndFeedImpl();
+
+ feed.setTitle( title );
+ feed.setLink( link );
+ feed.setDescription( description );
+ feed.setLanguage( DEFAULT_LANGUAGE );
+ }
- feed.setTitle( title );
- feed.setLink( link );
- feed.setDescription( description );
- feed.setLanguage( DEFAULT_LANGUAGE );
+ feed.setFeedType( DEFAULT_FEEDTYPE );
feed.setPublishedDate( Calendar.getInstance().getTime() );
-
- feed.setEntries( getEntries( dataEntries ) );
-
+ feed.setEntries( getEntries( dataEntries, existingEntries ) );
+
try
- {
+ {
Writer writer = new FileWriter( outputFile );
SyndFeedOutput output = new SyndFeedOutput();
output.output( feed, writer );
@@ -87,9 +118,14 @@ public class RssFeedGenerator
}
}
- private List<SyndEntry> getEntries( List<RssFeedEntry> dataEntries )
- {
- List<SyndEntry> entries = new ArrayList<SyndEntry>();
+ private List<SyndEntry> getEntries( List<RssFeedEntry> dataEntries, List<SyndEntry> existingEntries )
+ {
+ List<SyndEntry> entries = existingEntries;
+ if( entries == null )
+ {
+ entries = new ArrayList<SyndEntry>();
+ }
+
SyndEntry entry;
SyndContent description;
@@ -111,4 +147,8 @@ public class RssFeedGenerator
return entries;
}
+ public void setRssDirectory( String rssDirectory )
+ {
+ this.rssDirectory = rssDirectory;
+ }
}
diff --git a/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/processor/NewArtifactsRssFeedProcessor.java b/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/processor/NewArtifactsRssFeedProcessor.java
new file mode 100644
index 000000000..a05eb0929
--- /dev/null
+++ b/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/processor/NewArtifactsRssFeedProcessor.java
@@ -0,0 +1,178 @@
+package org.apache.archiva.rss.processor;
+
+/*
+ * 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 java.util.ArrayList;
+import java.util.Calendar;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+import org.apache.archiva.rss.RssFeedEntry;
+import org.apache.archiva.rss.RssFeedGenerator;
+import org.apache.commons.lang.StringUtils;
+import org.apache.maven.archiva.model.ArchivaArtifact;
+
+/**
+ * Process new artifacts in the repository and generate RSS feeds.
+ *
+ * @author <a href="mailto:oching@apache.org">Maria Odea Ching</a>
+ * @version
+ * @plexus.component role="org.apache.archiva.rss.processor.RssFeedProcessor" role-hint="new-artifacts"
+ */
+public class NewArtifactsRssFeedProcessor
+ implements RssFeedProcessor
+{
+ public static final String NEW_ARTIFACTS_IN_REPO = "New Artifacts in Repository ";
+
+ public static final String NEW_VERSIONS_OF_ARTIFACT = "New Versions of Artifact ";
+
+ /**
+ * @plexus.requirement
+ */
+ private RssFeedGenerator generator;
+
+ /**
+ * Process the newly discovered artifacts in the repository. Generate feeds for new artifacts in the repository and
+ * new versions of artifact.
+ */
+ public void process( List<ArchivaArtifact> data )
+ {
+ processNewArtifactsInRepo( data );
+ processNewVersionsOfArtifact( data );
+ }
+
+ private void processNewArtifactsInRepo( List<ArchivaArtifact> data )
+ {
+ List<RssFeedEntry> entries = new ArrayList<RssFeedEntry>();
+ String repoId = getRepoId( data );
+
+ RssFeedEntry entry =
+ new RssFeedEntry( NEW_ARTIFACTS_IN_REPO + "\'" + repoId + "\'" + " as of " +
+ Calendar.getInstance().getTime(), "http://localhost:8080/archiva/repository/" + repoId );
+ String description = "These are the new artifacts found in repository " + "\'" + repoId + "\'" + ": \n";
+
+ for ( ArchivaArtifact artifact : data )
+ {
+ description = description + artifact.toString() + "\n";
+ }
+ entry.setDescription( description );
+ entries.add( entry );
+
+ generateFeed( "new_artifacts_" + repoId + ".xml", NEW_ARTIFACTS_IN_REPO + "\'" + repoId + "\'",
+ "http://localhost:8080/archiva/repository/" + repoId, "New artifacts found in repository " +
+ "\'" + repoId + "\'" + " during repository scan.", entries );
+ }
+
+ private void processNewVersionsOfArtifact( List<ArchivaArtifact> data )
+ {
+ String repoId = getRepoId( data );
+
+ List<String> artifacts = new ArrayList<String>();
+
+ for ( ArchivaArtifact artifact : data )
+ {
+ artifacts.add( artifact.toString() );
+ }
+
+ Collections.sort( artifacts );
+
+ Map<String, String> artifactsMap = toMap( artifacts );
+
+ for ( String key : artifactsMap.keySet() )
+ {
+ List<RssFeedEntry> entries = new ArrayList<RssFeedEntry>();
+ String artifactPath = getArtifactPath( key );
+ RssFeedEntry entry =
+ new RssFeedEntry( NEW_VERSIONS_OF_ARTIFACT + "\'" + key + "\'" + " as of " +
+ Calendar.getInstance().getTime(), "http://localhost:8080/archiva/repository/" + repoId + "/" +
+ artifactPath );
+
+ String description =
+ "These are the new versions of artifact " + "\'" + key + "\'" + " in the repository: \n" +
+ StringUtils.replace( ( (String) artifactsMap.get( key ) ), "|", "\n" );
+
+ entry.setDescription( description );
+ entries.add( entry );
+
+ generateFeed( "new_versions_" + repoId + "_" + key + ".xml", NEW_VERSIONS_OF_ARTIFACT + "\'" + key + "\'",
+ "http://localhost:8080/archiva/repository/" + repoId + "/" + artifactPath,
+ "New versions of artifact " + "\'" + key + "\' found in repository " + "\'" + repoId + "\'" +
+ " during repository scan.", entries );
+ }
+ }
+
+ private String getRepoId( List<ArchivaArtifact> data )
+ {
+ String repoId = "";
+ if ( !data.isEmpty() )
+ {
+ repoId = ( (ArchivaArtifact) data.get( 0 ) ).getModel().getRepositoryId();
+ }
+
+ return repoId;
+ }
+
+ private void generateFeed( String filename, String title, String link, String description,
+ List<RssFeedEntry> dataEntries )
+ {
+ generator.generateFeed( title, link, description, dataEntries, filename );
+ }
+
+ private Map<String, String> toMap( List<String> artifacts )
+ {
+ Map<String, String> artifactsMap = new HashMap<String, String>();
+ for ( String id : artifacts )
+ {
+ String key = StringUtils.substringBefore( id, ":" );
+ key = key + ":" + StringUtils.substringBefore( StringUtils.substringAfter( id, ":" ), ":" );
+
+ String value = (String) artifactsMap.get( key );
+ if ( value != null )
+ {
+ value = value + "|" + id;
+ }
+ else
+ {
+ value = id;
+ }
+ artifactsMap.put( key, value );
+ }
+
+ return artifactsMap;
+ }
+
+ private String getArtifactPath( String key )
+ {
+ return StringUtils.replace( StringUtils.replace( key, ".", "/" ), ":", "/" );
+ }
+
+ public RssFeedGenerator getGenerator()
+ {
+ return generator;
+ }
+
+ public void setGenerator( RssFeedGenerator generator )
+ {
+ this.generator = generator;
+ }
+
+}
diff --git a/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/processor/RssFeedProcessor.java b/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/processor/RssFeedProcessor.java
new file mode 100644
index 000000000..29c4ad563
--- /dev/null
+++ b/archiva-modules/archiva-web/archiva-rss/src/main/java/org/apache/archiva/rss/processor/RssFeedProcessor.java
@@ -0,0 +1,35 @@
+package org.apache.archiva.rss.processor;
+
+/*
+ * 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 java.util.List;
+
+import org.apache.maven.archiva.model.ArchivaArtifact;
+
+/**
+ * Process data that will be fed into the RssFeedGenerator
+ *
+ * @author <a href="mailto:oching@apache.org">Maria Odea Ching</a>
+ * @version
+ */
+public interface RssFeedProcessor
+{
+ void process( List<ArchivaArtifact> data );
+}
diff --git a/archiva-modules/archiva-web/archiva-rss/src/test/java/org/apache/archiva/rss/RssFeedGeneratorTest.java b/archiva-modules/archiva-web/archiva-rss/src/test/java/org/apache/archiva/rss/RssFeedGeneratorTest.java
index ac86c827c..74a5189f0 100644
--- a/archiva-modules/archiva-web/archiva-rss/src/test/java/org/apache/archiva/rss/RssFeedGeneratorTest.java
+++ b/archiva-modules/archiva-web/archiva-rss/src/test/java/org/apache/archiva/rss/RssFeedGeneratorTest.java
@@ -49,35 +49,30 @@ public class RssFeedGeneratorTest
public void testGenerateFeed()
throws Exception
- {
- File outputFile = new File( getBasedir(), "/target/test-classes/rss-feeds/generated-rss2.0-feed.xml" );
-
+ {
+ generator.setRssDirectory( getBasedir() + "/target/test-classes/rss-feeds/" );
+
List<RssFeedEntry> entries = new ArrayList<RssFeedEntry>();
- RssFeedEntry entry = new RssFeedEntry();
+ RssFeedEntry entry = new RssFeedEntry( "Item 1", "http://rss-2.0-test-feed.com");
- entry.setTitle( "Item 1" );
- entry.setLink( "http://rss-2.0-test-feed.com" );
entry.setDescription( "RSS 2.0 feed item 1." );
entry.setGuid( "http://rss-2.0-test-feed.com/item1" );
entries.add( entry );
- entry = new RssFeedEntry();
- entry.setTitle( "Item 2" );
- entry.setLink( "http://rss-2.0-test-feed.com" );
+ entry = new RssFeedEntry( "Item 2", "http://rss-2.0-test-feed.com" );
entry.setDescription( "RSS 2.0 feed item 2." );
entry.setGuid( "http://rss-2.0-test-feed.com/item2" );
entries.add( entry );
- entry = new RssFeedEntry();
- entry.setTitle( "Item 3" );
- entry.setLink( "http://rss-2.0-test-feed.com" );
+ entry = new RssFeedEntry( "Item 3", "http://rss-2.0-test-feed.com" );
entry.setDescription( "RSS 2.0 feed item 3." );
entry.setGuid( "http://rss-2.0-test-feed.com/item3" );
entries.add( entry );
generator.generateFeed( "Test Feed", "http://localhost:8080/archiva", "The test feed from Archiva.", entries,
- outputFile );
+ "generated-rss2.0-feed.xml" );
+ File outputFile = new File( getBasedir(), "/target/test-classes/rss-feeds/generated-rss2.0-feed.xml" );
String generatedContent = FileUtils.readFileToString( outputFile );
XMLAssert.assertXpathEvaluatesTo( "Test Feed", "//channel/title", generatedContent );
@@ -89,5 +84,7 @@ public class RssFeedGeneratorTest
"<channel><item><title>Item 1</title></item><item><title>Item 2</title></item>"
+ "<item><title>Item 3</title></item></channel>";
XMLAssert.assertXpathsEqual( "//channel/item/title", expectedItem1, "//channel/item/title", generatedContent );
+
+ outputFile.deleteOnExit();
}
}
diff --git a/archiva-modules/archiva-web/archiva-rss/src/test/java/org/apache/archiva/rss/processor/NewArtifactsRssFeedProcessorTest.java b/archiva-modules/archiva-web/archiva-rss/src/test/java/org/apache/archiva/rss/processor/NewArtifactsRssFeedProcessorTest.java
new file mode 100644
index 000000000..b638c6dc6
--- /dev/null
+++ b/archiva-modules/archiva-web/archiva-rss/src/test/java/org/apache/archiva/rss/processor/NewArtifactsRssFeedProcessorTest.java
@@ -0,0 +1,108 @@
+package org.apache.archiva.rss.processor;
+
+/*
+ * 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 java.io.File;
+import java.util.ArrayList;
+import java.util.List;
+
+import org.apache.archiva.rss.RssFeedGenerator;
+import org.apache.maven.archiva.model.ArchivaArtifact;
+import org.codehaus.plexus.PlexusTestCase;
+
+/**
+ * @author <a href="mailto:oching@apache.org">Maria Odea Ching</a>
+ * @version
+ */
+public class NewArtifactsRssFeedProcessorTest
+ extends PlexusTestCase
+{
+ private RssFeedProcessor newArtifactsProcessor;
+
+ private String rssDirectory;
+
+ public void setUp()
+ throws Exception
+ {
+ super.setUp();
+
+ newArtifactsProcessor = (RssFeedProcessor) lookup( RssFeedProcessor.class, "new-artifacts" );
+ rssDirectory = getBasedir() + "/target/test-classes/rss-feeds/";
+
+ RssFeedGenerator generator = ( ( NewArtifactsRssFeedProcessor ) newArtifactsProcessor ).getGenerator();
+ generator.setRssDirectory( rssDirectory );
+ ( (NewArtifactsRssFeedProcessor) newArtifactsProcessor ).setGenerator( generator );
+ }
+
+ public void testProcess()
+ throws Exception
+ {
+ List<ArchivaArtifact> newArtifacts = new ArrayList<ArchivaArtifact>();
+
+ ArchivaArtifact artifact = new ArchivaArtifact( "org.apache.archiva", "artifact-one", "1.0", "", "jar" );
+ artifact.getModel().setRepositoryId( "test-repo" );
+ newArtifacts.add( artifact );
+
+ artifact = new ArchivaArtifact( "org.apache.archiva", "artifact-one", "1.1", "", "jar" );
+ artifact.getModel().setRepositoryId( "test-repo" );
+ newArtifacts.add( artifact );
+
+ artifact = new ArchivaArtifact( "org.apache.archiva", "artifact-one", "2.0", "", "jar" );
+ artifact.getModel().setRepositoryId( "test-repo" );
+ newArtifacts.add( artifact );
+
+ artifact = new ArchivaArtifact( "org.apache.archiva", "artifact-two", "1.0.1", "", "jar" );
+ artifact.getModel().setRepositoryId( "test-repo" );
+ newArtifacts.add( artifact );
+
+ artifact = new ArchivaArtifact( "org.apache.archiva", "artifact-two", "1.0.2", "", "jar" );
+ artifact.getModel().setRepositoryId( "test-repo" );
+ newArtifacts.add( artifact );
+
+ artifact = new ArchivaArtifact( "org.apache.archiva", "artifact-two", "1.0.3-SNAPSHOT", "", "jar" );
+ artifact.getModel().setRepositoryId( "test-repo" );
+ newArtifacts.add( artifact );
+
+ artifact = new ArchivaArtifact( "org.apache.archiva", "artifact-three", "2.0-SNAPSHOT", "", "jar" );
+ artifact.getModel().setRepositoryId( "test-repo" );
+ newArtifacts.add( artifact );
+
+ artifact = new ArchivaArtifact( "org.apache.archiva", "artifact-four", "1.1-beta-2", "", "jar" );
+ artifact.getModel().setRepositoryId( "test-repo" );
+ newArtifacts.add( artifact );
+
+ newArtifactsProcessor.process( newArtifacts );
+
+ File outputFile = new File( rssDirectory, "new_artifacts_test-repo.xml" );
+ assertTrue( outputFile.exists() );
+
+ outputFile = new File( rssDirectory, "new_versions_test-repo_org.apache.archiva:artifact-one.xml" );
+ assertTrue( outputFile.exists() );
+
+ outputFile = new File( rssDirectory, "new_versions_test-repo_org.apache.archiva:artifact-two.xml" );
+ assertTrue( outputFile.exists() );
+
+ outputFile = new File( rssDirectory, "new_versions_test-repo_org.apache.archiva:artifact-three.xml" );
+ assertTrue( outputFile.exists() );
+
+ outputFile = new File( rssDirectory, "new_versions_test-repo_org.apache.archiva:artifact-four.xml" );
+ assertTrue( outputFile.exists() );
+ }
+}