RSS: add option display headline timestamp.

Conflicts:
	plugins/RSS/config.py
	plugins/RSS/plugin.py
This commit is contained in:
Daniel Folkinshteyn 2013-05-05 11:23:15 -04:00 committed by Valentin Lorentz
parent e4ddda4aeb
commit c27070895b
2 changed files with 31 additions and 20 deletions

View File

@ -87,6 +87,12 @@ conf.registerChannelValue(RSS, 'showLinks',
along with the title of the feed when the rss command is called. along with the title of the feed when the rss command is called.
supybot.plugins.RSS.announce.showLinks affects whether links will be supybot.plugins.RSS.announce.showLinks affects whether links will be
listed when a feed is automatically announced."""))) listed when a feed is automatically announced.""")))
conf.registerChannelValue(RSS, 'showPubDate',
registry.Boolean(False, """Determines whether the bot will list the
publication datetime stamp along with the title of the feed when the rss
command is called.
supybot.plugins.RSS.announce.showPubDate affects whether this will be
listed when a feed is automatically announced."""))
conf.registerGlobalValue(RSS, 'defaultNumberOfHeadlines', conf.registerGlobalValue(RSS, 'defaultNumberOfHeadlines',
registry.PositiveInteger(1, _("""Indicates how many headlines an rss feed registry.PositiveInteger(1, _("""Indicates how many headlines an rss feed
will output by default, if no number is provided."""))) will output by default, if no number is provided.""")))
@ -108,8 +114,12 @@ conf.registerChannelValue(RSS.announce, 'showLinks',
along with the title of the feed when a feed is automatically along with the title of the feed when a feed is automatically
announced."""))) announced.""")))
conf.registerChannelValue(RSS.announce, 'showPubDate',
registry.Boolean(False, """Determines whether the bot will list the
publication datetime stamp along with the title of the feed when a feed
is automatically announced."""))
conf.registerGlobalValue(RSS.announce, 'cachePeriod', conf.registerGlobalValue(RSS.announce, 'cachePeriod',
registry.PositiveInteger(86400, """Maximum age of cached RSS headlines, registry.PositiveInteger(604800, """Maximum age of cached RSS headlines,
in seconds. Headline cache is used to avoid re-announcing old news.""")) in seconds. Headline cache is used to avoid re-announcing old news."""))

View File

@ -141,25 +141,25 @@ class RSS(callbacks.Plugin):
self.releaseLock(url) self.releaseLock(url)
time.sleep(0.1) # So other threads can run. time.sleep(0.1) # So other threads can run.
def buildHeadlines(self, headlines, channel, config='announce.showLinks'): def buildHeadlines(self, headlines, channel, linksconfig='announce.showLinks', dateconfig='announce.showPubDate'):
newheadlines = [] newheadlines = []
if self.registryValue(config, channel): for headline in headlines:
for headline in headlines: link = ''
pubDate = ''
if self.registryValue(linksconfig, channel):
if headline[1]: if headline[1]:
if self.registryValue('stripRedirect'): if self.registryValue('stripRedirect'):
h = re.sub('^.*http://', 'http://', headline[1]) link = ' <%s>' % (re.sub('^.*http://', 'http://', headline[1]),)
else: else:
h = headline[1] link = ' <%s>' % (headline[1],)
newheadlines.append(format('%s %u', if self.registryValue(dateconfig, channel):
headline[0], if headline[2]:
h.encode('utf-8'))) pubDate = ' [%s]' % (headline[2],)
else: newheadlines.append(format('%s%s%s',
newheadlines.append(format('%s', headline[0])) headline[0],
else: link.encode('utf-8'),
for headline in headlines: pubDate))
newheadlines = [format('%s', h[0]) for h in headlines] return newheadlines
return map(lambda x:x.replace('\n', ' ').replace('\r', ''),
newheadlines)
def _newHeadlines(self, irc, channels, name, url): def _newHeadlines(self, irc, channels, name, url):
try: try:
@ -175,7 +175,7 @@ class RSS(callbacks.Plugin):
#oldresults = self.cachedFeeds[url] #oldresults = self.cachedFeeds[url]
#oldheadlines = self.getHeadlines(oldresults) #oldheadlines = self.getHeadlines(oldresults)
oldheadlines = self.cachedHeadlines[url] oldheadlines = self.cachedHeadlines[url]
oldheadlines = filter(lambda x: t - x[2] < self.registryValue('announce.cachePeriod'), oldheadlines) oldheadlines = filter(lambda x: t - x[3] < self.registryValue('announce.cachePeriod'), oldheadlines)
except KeyError: except KeyError:
oldheadlines = [] oldheadlines = []
newresults = self.getFeed(url) newresults = self.getFeed(url)
@ -340,8 +340,9 @@ class RSS(callbacks.Plugin):
for d in self._sortFeedItems(feed['items']): for d in self._sortFeedItems(feed['items']):
if 'title' in d: if 'title' in d:
title = conv(d['title']) title = conv(d['title'])
link = d.get('link') # defaults to None link = d.get('link')
headlines.append((title, link, t)) pubDate = d.get('pubDate', d.get('updated'))
headlines.append((title, link, pubDate, t))
return headlines return headlines
@internationalizeDocstring @internationalizeDocstring
@ -460,7 +461,7 @@ class RSS(callbacks.Plugin):
if not headlines: if not headlines:
irc.error(_('Couldn\'t get RSS feed.')) irc.error(_('Couldn\'t get RSS feed.'))
return return
headlines = self.buildHeadlines(headlines, channel, 'showLinks') headlines = self.buildHeadlines(headlines, channel, 'showLinks', 'showPubDate')
if n: if n:
headlines = headlines[:n] headlines = headlines[:n]
else: else: