T - the WireFeed typepublic abstract class AbstractFeedView<T extends com.rometools.rome.feed.WireFeed> extends AbstractView
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 typically extend from either
 AbstractRssFeedView or AbstractAtomFeedView instead of from this class.
 
Thanks to Jettro Coenradie and Sergio Bossa for the original feed view prototype!
AbstractRssFeedView, 
AbstractAtomFeedViewDEFAULT_CONTENT_TYPEloggerPATH_VARIABLES, RESPONSE_STATUS_ATTRIBUTE, SELECTED_CONTENT_TYPE| Constructor and Description | 
|---|
| AbstractFeedView() | 
| Modifier and Type | Method and Description | 
|---|---|
| protected abstract void | buildFeedEntries(Map<String,Object> model,
                T feed,
                HttpServletRequest request,
                HttpServletResponse response)Subclasses must implement this method to build feed entries, given the model. | 
| protected void | buildFeedMetadata(Map<String,Object> model,
                 T feed,
                 HttpServletRequest request)Populate the feed metadata (title, link, description, etc.). | 
| protected abstract T | newFeed()Create a new feed to hold the entries. | 
| protected void | renderMergedOutputModel(Map<String,Object> model,
                       HttpServletRequest request,
                       HttpServletResponse response)Subclasses must implement this method to actually render the view. | 
addStaticAttribute, createMergedOutputModel, createRequestContext, createTemporaryOutputStream, exposeModelAsRequestAttributes, formatViewName, generatesDownloadContent, getAttributesMap, getBeanName, getContentType, getRequestContextAttribute, getRequestToExpose, getStaticAttributes, isExposePathVariables, prepareResponse, render, setAttributes, setAttributesCSV, setAttributesMap, setBeanName, setContentType, setExposeContextBeansAsAttributes, setExposedContextBeanNames, setExposePathVariables, setRequestContextAttribute, setResponseContentType, toString, writeToResponsegetServletContext, getTempDir, getWebApplicationContext, initApplicationContext, initServletContext, isContextRequired, setServletContextgetApplicationContext, getMessageSourceAccessor, initApplicationContext, obtainApplicationContext, requiredContextClass, setApplicationContextprotected final void renderMergedOutputModel(Map<String,Object> model, HttpServletRequest request, HttpServletResponse response) throws Exception
AbstractViewThe first step will be preparing the request: In the JSP case, this would mean setting model objects as request attributes. The second step will be the actual rendering of the view, for example including the JSP via a RequestDispatcher.
renderMergedOutputModel in class AbstractViewmodel - combined output Map (never null),
 with dynamic values taking precedence over static attributesrequest - current HTTP requestresponse - current HTTP responseException - if rendering failedprotected abstract T newFeed()
protected void buildFeedMetadata(Map<String,Object> model, T feed, HttpServletRequest request)
Default is an empty implementation. Subclasses can override this method to add meta fields such as title, link description, etc.
model - the model, in case meta information must be populated from itfeed - the feed being populatedrequest - in case we need locale etc. Shouldn't look at attributes.protected abstract void buildFeedEntries(Map<String,Object> model, T feed, HttpServletRequest request, HttpServletResponse response) throws Exception
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.
model - the model Mapfeed - the feed to add entries torequest - in case we need locale etc. Shouldn't look at attributes.response - in case we need to set cookies. Shouldn't write to it.Exception - any exception that occurred during building