Class AbstractAtomFeedView

All Implemented Interfaces:
Aware, BeanNameAware, ApplicationContextAware, ServletContextAware, View

public abstract class AbstractAtomFeedView extends AbstractFeedView<com.rometools.rome.feed.atom.Feed>
Abstract superclass for Atom Feed views, using the ROME package.

NOTE: As of Spring 4.1, this is based on the com.rometools variant of ROME, version 1.5. Please upgrade your build dependency.

Application-specific view classes will extend this class. The view will be held in the subclass itself, not in a template. Main entry points are the AbstractFeedView.buildFeedMetadata(java.util.Map<java.lang.String, java.lang.Object>, T, jakarta.servlet.http.HttpServletRequest) and buildFeedEntries(java.util.Map<java.lang.String, java.lang.Object>, com.rometools.rome.feed.atom.Feed, jakarta.servlet.http.HttpServletRequest, jakarta.servlet.http.HttpServletResponse).

Thanks to Jettro Coenradie and Sergio Bossa for the original feed view prototype!

Since:
3.0
Author:
Arjen Poutsma, Juergen Hoeller
See Also:
  • Field Details

  • Constructor Details

    • AbstractAtomFeedView

      public AbstractAtomFeedView()
  • Method Details

    • setFeedType

      public void setFeedType(String feedType)
      Set the Rome feed type to use.

      Defaults to Atom 1.0.

      See Also:
    • newFeed

      protected com.rometools.rome.feed.atom.Feed newFeed()
      Create a new Feed instance to hold the entries.

      By default returns an Atom 1.0 feed, but the subclass can specify any Feed.

      Specified by:
      newFeed in class AbstractFeedView<com.rometools.rome.feed.atom.Feed>
      Returns:
      the newly created Feed instance
      See Also:
    • buildFeedEntries

      protected final void buildFeedEntries(Map<String,Object> model, com.rometools.rome.feed.atom.Feed feed, HttpServletRequest request, HttpServletResponse response) throws Exception
      Specified by:
      buildFeedEntries in class AbstractFeedView<com.rometools.rome.feed.atom.Feed>
      Parameters:
      model - the model Map
      feed - the feed to add entries to
      request - in case we need locale etc. Shouldn't look at attributes.
      response - in case we need to set cookies. Shouldn't write to it.
      Throws:
      Exception - any exception that occurred during building
    • buildFeedEntries

      protected abstract List<com.rometools.rome.feed.atom.Entry> buildFeedEntries(Map<String,Object> model, HttpServletRequest request, HttpServletResponse response) throws Exception
      Subclasses must implement this method to build feed entries, given the model.

      Note that the passed-in HTTP response is just supposed to be used for setting cookies or other HTTP headers. The built feed itself will automatically get written to the response after this method returns.

      Parameters:
      model - the model Map
      request - in case we need locale etc. Shouldn't look at attributes.
      response - in case we need to set cookies. Shouldn't write to it.
      Returns:
      the feed entries to be added to the feed
      Throws:
      Exception - any exception that occurred during document building
      See Also:
      • Entry