Interface RSSGenerator

All Superinterfaces:
Initializable
All Known Implementing Classes:
DefaultRSSGenerator

public interface RSSGenerator
extends Initializable
The master class for generating different kinds of Feeds (including RSS1.0, 2.0 and Atom).

This class can produce quite a few different styles of feeds. The following modes are available:

  • wiki - All the changes to the given page are enumerated and announced as diffs.
  • full - Each page is only considered once. This produces a very RecentChanges-style feed, where each page is only listed once, even if it has changed multiple times.
  • blog - Each page change is assumed to be a blog entry, so no diffs are produced, but the page content is always completely in the entry in rendered HTML.
Since:
1.7.5.
  • Field Details

  • Method Details

    • generate

      Generates the RSS resource. You probably want to output this result into a file or something, or serve as output from a servlet.
      Returns:
      A RSS 1.0 feed in the "full" mode.
    • generateFeed

      String generateFeed​(Context wikiContext, List<Page> changed, String mode, String type) throws IllegalArgumentException
      Generates a feed based on a context and list of changes.
      Parameters:
      wikiContext - The WikiContext
      changed - A list of Entry objects
      mode - The mode (wiki/blog)
      type - The type (RSS10, RSS20, ATOM). Default is RSS 1.0
      Returns:
      Fully formed XML.
      Throws:
      IllegalArgumentException - If an illegal mode is given.
    • isEnabled

      boolean isEnabled()
      Returns true if RSS generation is enabled.
      Returns:
      whether RSS generation is currently enabled
    • setEnabled

      void setEnabled​(boolean enabled)
      Turns RSS generation on or off. This setting is used to set the "enabled" flag only for use by callers, and does not actually affect whether the generate() or generateFeed(Context, List, String, String) methods output anything.
      Parameters:
      enabled - whether RSS generation is considered enabled.
    • getRssFile

      returns the rss file.
      Returns:
      the rss file.
    • generateFullWikiRSS

      String generateFullWikiRSS​(Context wikiContext, Feed feed)
      Generates an RSS feed for the entire wiki. Each item should be an instance of the RSSItem class.
      Parameters:
      wikiContext - A WikiContext
      feed - A Feed to generate the feed to.
      Returns:
      feed.getString().
    • generateWikiPageRSS

      String generateWikiPageRSS​(Context wikiContext, List<Page> changed, Feed feed)
      Create RSS/Atom as if this page was a wikipage (in contrast to Blog mode).
      Parameters:
      wikiContext - The WikiContext
      changed - A List of changed WikiPages.
      feed - A Feed object to fill.
      Returns:
      the RSS representation of the wiki context
    • generateBlogRSS

      String generateBlogRSS​(Context wikiContext, List<Page> changed, Feed feed)
      Creates RSS from modifications as if this page was a blog (using the WeblogPlugin).
      Parameters:
      wikiContext - The WikiContext, as usual.
      changed - A list of the changed pages.
      feed - A valid Feed object. The feed will be used to create the RSS/Atom, depending on which kind of an object you want to put in it.
      Returns:
      A String of valid RSS or Atom.
    • format

      static String format​(String s)
      Does the required formatting and entity replacement for XML.
      Parameters:
      s - String to format.
      Returns:
      A formatted string.
    • getContentType

      static String getContentType​(String mode)
      Returns the content type of this RSS feed.
      Parameters:
      mode - the RSS mode: RSS10, RSS20 or ATOM.
      Returns:
      the content type
      Since:
      2.3.15