Class SyndFeedInput


  • public class SyndFeedInput
    extends Object
    Parses an XML document (File, InputStream, Reader, W3C SAX InputSource, W3C DOM Document or JDom DOcument) into an SyndFeedImpl.

    It delegates to a WireFeedInput to handle all feed types.

    • Constructor Detail

      • SyndFeedInput

        public SyndFeedInput()
        Creates a SyndFeedInput instance with input validation turned off.

      • SyndFeedInput

        public SyndFeedInput​(boolean validate,
                             Locale locale)
        Creates a SyndFeedInput instance.

        Parameters:
        validate - indicates if the input should be validated. NOT IMPLEMENTED YET (validation does not happen)
    • Method Detail

      • setXmlHealerOn

        public void setXmlHealerOn​(boolean heals)
        Enables XML healing in the WiredFeedInput instance.

        Healing trims leading chars from the stream (empty spaces and comments) until the XML prolog.

        Healing resolves HTML entities (from literal to code number) in the reader.

        The healing is done only with the build(File) and build(Reader) signatures.

        By default is TRUE.

        Parameters:
        heals - TRUE enables stream healing, FALSE disables it.
      • getXmlHealerOn

        public boolean getXmlHealerOn()
        Indicates if the WiredFeedInput instance will XML heal (if necessary) the character stream.

        Healing trims leading chars from the stream (empty spaces and comments) until the XML prolog.

        Healing resolves HTML entities (from literal to code number) in the reader.

        The healing is done only with the build(File) and build(Reader) signatures.

        By default is TRUE.

        Returns:
        TRUE if healing is enabled, FALSE if not.
      • isAllowDoctypes

        public boolean isAllowDoctypes()
        Indicates whether Doctype declarations are allowed.
        Returns:
        true when Doctype declarations are allowed, false otherwise
      • setAllowDoctypes

        public void setAllowDoctypes​(boolean allowDoctypes)
        Since ROME 1.5.1 we fixed a security vulnerability by disallowing Doctype declarations by default. This change breaks the compatibility with at least RSS 0.91N because it requires a Doctype declaration. You are able to allow Doctype declarations again with this property. You should only activate it when the feeds that you process are absolutely trustful.
        Parameters:
        allowDoctypes - true when Doctype declarations should be allowed again, false otherwise
      • build

        public SyndFeed build​(org.jdom2.Document document)
                       throws IllegalArgumentException,
                              FeedException
        Builds SyndFeedImpl from an JDOM document.

        Parameters:
        document - JDOM document to read to create the SyndFeedImpl.
        Returns:
        the SyndFeedImpl read from the JDOM document.
        Throws:
        IllegalArgumentException - thrown if feed type could not be understood by any of the underlying parsers.
        FeedException - if the feed could not be parsed
      • isPreserveWireFeed

        public boolean isPreserveWireFeed()
        Returns:
        true if the WireFeed is made available in the SyndFeed. False by default.
      • setPreserveWireFeed

        public void setPreserveWireFeed​(boolean preserveWireFeed)
        Parameters:
        preserveWireFeed - set to true to make the WireFeed is made available in the SyndFeed. False by default.