Raw File
README.rst
.. _plugin-RSS:

Documentation for the RSS plugin for Supybot
============================================

Purpose
-------
Provides basic functionality for handling RSS/RDF feeds, and allows announcing
them periodically to channels.
In order to use this plugin you must have the following modules
installed:
* feedparser: http://feedparser.org/

Usage
-----
This plugin is useful both for announcing updates to RSS feeds in a
channel, and for retrieving the headlines of RSS feeds via command.  Use
the "add" command to add feeds to this plugin, and use the "announce"
command to determine what feeds should be announced in a given channel.

Basic usage
^^^^^^^^^^^

1. Add a feed using
   ``@rss add limnoria https://github.com/ProgVal/Limnoria/tags.atom``.

   * This is RSS feed of Limnoria's stable releases.
   * You can now check the latest news from the feed with ``@limnoria``.

2. To have new news automatically announced on the channel, use
   ``@rss announce add Limnoria``.

To add another feed, simply replace limnoria and the address using name
of the feed and address of the feed. For example, YLE News:

1. ``@rss add yle http://yle.fi/uutiset/rss/uutiset.rss?osasto=news``
2. ``@rss announce add yle``

News on their own lines
^^^^^^^^^^^^^^^^^^^^^^^

If you want the feed topics to be on their own lines instead of being separated by
the separator which you have configured you can set `reply.onetoone` to False.

Please first read the help for that configuration variable

``@config help reply.onetoone``

and understand what it says and then you can do

``@config reply.onetoone False``

.. _commands-RSS:

Commands
--------
.. _command-rss-add:

add <name> <url>
  Adds a command to this plugin that will look up the RSS feed at the given URL.

.. _command-rss-announce.add:

announce add [<channel>] <name|url> [<name|url> ...]
  Adds the list of feeds to the current list of announced feeds in <channel>. Valid feeds include the names of registered feeds as well as URLs for RSS feeds. <channel> is only necessary if the message isn't sent in the channel itself.

.. _command-rss-announce.channels:

announce channels <name|url>
  Returns a list of channels that the given feed name or URL is being announced to.

.. _command-rss-announce.list:

announce list [<channel>]
  Returns the list of feeds announced in <channel>. <channel> is only necessary if the message isn't sent in the channel itself.

.. _command-rss-announce.remove:

announce remove [<channel>] <name|url> [<name|url> ...]
  Removes the list of feeds from the current list of announced feeds in <channel>. Valid feeds include the names of registered feeds as well as URLs for RSS feeds. <channel> is only necessary if the message isn't sent in the channel itself.

.. _command-rss-info:

info <url|feed>
  Returns information from the given RSS feed, namely the title, URL, description, and last update date, if available.

.. _command-rss-remove:

remove <name>
  Removes the command for looking up RSS feeds at <name> from this plugin.

.. _command-rss-rss:

rss <name|url> [<number of headlines>]
  Gets the title components of the given RSS feed. If <number of headlines> is given, return only that many headlines.

.. _conf-RSS:

Configuration
-------------

.. _conf-supybot.plugins.RSS.announce:


supybot.plugins.RSS.announce
  This config variable defaults to " ", is network-specific, and is  channel-specific.

  Determines which RSS feeds should be announced in the channel; valid input is a list of strings (either registered RSS feeds or RSS feed URLs) separated by spaces.

.. _conf-supybot.plugins.RSS.announceFormat:


supybot.plugins.RSS.announceFormat
  This config variable defaults to "News from $feed_name: $title <$link>", is network-specific, and is  channel-specific.

  The format the bot will use for displaying headlines of a RSS feed that is announced. See supybot.plugins.RSS.format for the available variables.

.. _conf-supybot.plugins.RSS.defaultNumberOfHeadlines:


supybot.plugins.RSS.defaultNumberOfHeadlines
  This config variable defaults to "1", is network-specific, and is  channel-specific.

  Indicates how many headlines an rss feed will output by default, if no number is provided.

.. _conf-supybot.plugins.RSS.feeds:


supybot.plugins.RSS.feeds
  This config variable defaults to " ", is not network-specific, and is  not channel-specific.

  Determines what feeds should be accessible as commands.

.. _conf-supybot.plugins.RSS.format:


supybot.plugins.RSS.format
  This config variable defaults to "$date: $title <$link>", is network-specific, and is  channel-specific.

  The format the bot will use for displaying headlines of a RSS feed that is triggered manually. In addition to fields defined by feedparser ($published (the entry date), $title, $link, $description, $id, etc.), the following variables can be used: $feed_name, $date (parsed date, as defined in supybot.reply.format.time)

.. _conf-supybot.plugins.RSS.headlineSeparator:


supybot.plugins.RSS.headlineSeparator
  This config variable defaults to " | ", is network-specific, and is  channel-specific.

  Determines what string is used to separate headlines in new feeds.

.. _conf-supybot.plugins.RSS.initialAnnounceHeadlines:


supybot.plugins.RSS.initialAnnounceHeadlines
  This config variable defaults to "5", is network-specific, and is  channel-specific.

  Indicates how many headlines an rss feed will output when it is first added to announce for a channel.

.. _conf-supybot.plugins.RSS.keywordBlacklist:


supybot.plugins.RSS.keywordBlacklist
  This config variable defaults to " ", is network-specific, and is  channel-specific.

  Space separated list of strings, lets you filter headlines to those not containing any items in this blacklist.

.. _conf-supybot.plugins.RSS.keywordWhitelist:


supybot.plugins.RSS.keywordWhitelist
  This config variable defaults to " ", is network-specific, and is  channel-specific.

  Space separated list of strings, lets you filter headlines to those containing one or more items in this whitelist.

.. _conf-supybot.plugins.RSS.maximumAnnounceHeadlines:


supybot.plugins.RSS.maximumAnnounceHeadlines
  This config variable defaults to "5", is network-specific, and is  channel-specific.

  Indicates how many new news entries may be sent at the same time. Extra entries will be discarded.

.. _conf-supybot.plugins.RSS.notice:


supybot.plugins.RSS.notice
  This config variable defaults to "False", is network-specific, and is  channel-specific.

  Determines whether announces will be sent as notices instead of privmsgs.

.. _conf-supybot.plugins.RSS.public:


supybot.plugins.RSS.public
  This config variable defaults to "True", is not network-specific, and is  not channel-specific.

  Determines whether this plugin is publicly visible.

.. _conf-supybot.plugins.RSS.sortFeedItems:


supybot.plugins.RSS.sortFeedItems
  This config variable defaults to "asInFeed", is not network-specific, and is  not channel-specific.

  Determines whether feed items should be sorted by their publication/update timestamp or kept in the same order as they appear in a feed.  Valid strings: asInFeed, oldestFirst, newestFirst, outdatedFirst, and updatedFirst.

.. _conf-supybot.plugins.RSS.waitPeriod:


supybot.plugins.RSS.waitPeriod
  This config variable defaults to "1800", is not network-specific, and is  not channel-specific.

  Indicates how many seconds the bot will wait between retrieving RSS feeds; requests made within this period will return cached results.

back to top