From c62eee75db1d841624b9b74761b91b02ff54ec67 Mon Sep 17 00:00:00 2001 From: Giuseppe Bilotta Date: Mon, 5 Feb 2007 19:36:48 +0000 Subject: rss plugin: the refresh rate of each rss can be set independently of the global one. Set to 0 to reset --- data/rbot/plugins/rss.rb | 39 +++++++++++++++++++++++++++------------ 1 file changed, 27 insertions(+), 12 deletions(-) (limited to 'data') diff --git a/data/rbot/plugins/rss.rb b/data/rbot/plugins/rss.rb index 75fc9b47..22a6dc18 100644 --- a/data/rbot/plugins/rss.rb +++ b/data/rbot/plugins/rss.rb @@ -30,6 +30,7 @@ class ::RssBlob attr_accessor :handle attr_accessor :type attr :watchers + attr_accessor :refresh_rate attr_accessor :xml attr_accessor :title attr_accessor :items @@ -44,6 +45,7 @@ class ::RssBlob end @type = type @watchers=[] + @refresh_rate = nil @xml = xml @title = nil @items = nil @@ -89,7 +91,7 @@ class ::RssBlob end def to_a - [@handle,@url,@type,@watchers] + [@handle,@url,@type,@refresh_rate,@watchers] end def to_s(watchers=false) @@ -189,7 +191,7 @@ class RSSFeedsPlugin < Plugin when "add" "rss add #{Bold}handle#{Bold} #{Bold}url#{Bold} [#{Bold}type#{Bold}] : add a new rss called #{Bold}handle#{Bold} from url #{Bold}url#{Bold} (of type #{Bold}type#{Bold})" when "change" - "rss change #{Bold}what#{Bold} of #{Bold}handle#{Bold} to #{Bold}new#{Bold} : change the handle, url or type of rss called #{Bold}handle#{Bold} to value #{Bold}new#{Bold}" + "rss change #{Bold}what#{Bold} of #{Bold}handle#{Bold} to #{Bold}new#{Bold} : change the #{Underline}handle#{Underline}, #{Underline}url#{Underline}, #{Underline}type#{Underline} or #{Underline}refresh#{Underline} rate of rss called #{Bold}handle#{Bold} to value #{Bold}new#{Bold}" when /^(del(ete)?|rm)$/ "rss del(ete)|rm #{Bold}handle#{Bold} : delete rss feed #{Bold}handle#{Bold}" when "replace" @@ -283,6 +285,7 @@ class RSSFeedsPlugin < Plugin @feeds.each { |handle, feed| next if wanted and !handle.match(/#{wanted}/i) reply << "#{feed.handle}: #{feed.url} (in format: #{feed.type ? feed.type : 'default'})" + (reply << " refreshing every #{Utils.secs_to_string(feed.refresh_rate)}") if feed.refresh_rate (reply << " (watched)") if feed.watched_by?(m.replyto) reply << "\n" } @@ -299,7 +302,9 @@ class RSSFeedsPlugin < Plugin watchlist.each { |handle, feed| next if wanted and !handle.match(/#{wanted}/i) next unless feed.watched_by?(m.replyto) - reply << "#{feed.handle}: #{feed.url} (in format: #{feed.type ? feed.type : 'default'})\n" + reply << "#{feed.handle}: #{feed.url} (in format: #{feed.type ? feed.type : 'default'})" + (reply << " refreshing every #{Utils.secs_to_string(feed.refresh_rate)}") if feed.refresh_rate + reply << "\n" } if reply.empty? reply = "no watched feeds" @@ -344,9 +349,11 @@ class RSSFeedsPlugin < Plugin m.reply "There already is a feed with handle #{new}" return else - @feeds[new] = feed - @feeds.delete(handle) - feed.handle = new + feed.mutex.synchronize do + @feeds[new] = feed + @feeds.delete(handle) + feed.handle = new + end handle = new end when :url @@ -360,6 +367,12 @@ class RSSFeedsPlugin < Plugin feed.mutex.synchronize do feed.type = new end + when :refresh + new = params[:new].to_i + new = nil if new == 0 + feed.mutex.synchronize do + feed.refresh_rate = new + end else m.reply "Don't know how to change #{params[:what]} for feeds" return @@ -500,10 +513,12 @@ class RSSFeedsPlugin < Plugin status[:failures] = failures - seconds = @bot.config['rss.thread_sleep'] * (failures + 1) - seconds += seconds * (rand(100)-50)/100 - debug "watcher for #{feed} going to sleep #{seconds} seconds.." - @bot.timer.reschedule(@watch[feed.handle], seconds) + feed.mutex.synchronize do + seconds = (feed.refresh_rate || @bot.config['rss.thread_sleep']) * (failures + 1) + seconds += seconds * (rand(100)-50)/100 + debug "watcher for #{feed} going to sleep #{seconds} seconds.." + @bot.timer.reschedule(@watch[feed.handle], seconds) + end } debug "watcher for #{feed} added" end @@ -655,10 +670,10 @@ plugin.map 'rss add :handle :url :type', :defaults => {:type => nil} plugin.map 'rss change :what of :handle to :new', :action => 'change_rss', - :requirements => { :what => /handle|url|format|type/ } + :requirements => { :what => /handle|url|format|type|refresh/ } plugin.map 'rss change :what for :handle to :new', :action => 'change_rss', - :requirements => { :what => /handle|url|format|type/ } + :requirements => { :what => /handle|url|format|type|refesh/ } plugin.map 'rss del :handle', :action => 'del_rss' plugin.map 'rss delete :handle', -- cgit v1.2.3