X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=data%2Frbot%2Fplugins%2Fquotes.rb;h=73f1b9e7f7c9e397d4a32f35c080966328d87af3;hb=1e841175468b3e0357ab278a226a237fe4d7687e;hp=6094737c1143403928e6d532c8e19ce25128299a;hpb=6e113069ee929d5e0ea788da44c8eb981c3c4f74;p=user%2Fhenk%2Fcode%2Fruby%2Frbot.git diff --git a/data/rbot/plugins/quotes.rb b/data/rbot/plugins/quotes.rb index 6094737c..73f1b9e7 100644 --- a/data/rbot/plugins/quotes.rb +++ b/data/rbot/plugins/quotes.rb @@ -1,10 +1,20 @@ -Quote = Struct.new("Quote", "num", "date", "source", "quote") +#-- vim:sw=2:et +#++ +# +# :title: Quotes plugin +# +# TODO:: use message mapper instead of multiple ifs +# TODO:: switch to db + +define_structure :Quote, :num, :date, :source, :quote class QuotePlugin < Plugin def initialize super @lists = Hash.new + @changed = Hash.new Dir["#{@bot.botclass}/quotes/*"].each {|f| + next if File.directory?(f) channel = File.basename(f) @lists[channel] = Array.new if(!@lists.has_key?(channel)) IO.foreach(f) {|line| @@ -13,24 +23,47 @@ class QuotePlugin < Plugin @lists[channel][num] = Quote.new(num, $2, $3, $4) end } + @changed[channel] = false } end + def save Dir.mkdir("#{@bot.botclass}/quotes") if(!FileTest.directory?("#{@bot.botclass}/quotes")) @lists.each {|channel, quotes| - File.open("#{@bot.botclass}/quotes/#{channel}", "w") {|file| - quotes.compact.each {|q| - file.puts "#{q.num} | #{q.date} | #{q.source} | #{q.quote}" - } - } + begin + if @changed[channel] + debug "Writing new quotefile for channel #{channel} ..." + Utils.safe_save("#{@bot.botclass}/quotes/#{channel}") {|file| + quotes.compact.each {|q| + file.puts "#{q.num} | #{q.date} | #{q.source} | #{q.quote}" + } + } + @changed[channel] = false + else + debug "Not writing quotefile for channel #{channel} (unchanged)" + end + rescue => e + error "failed to write quotefile for channel #{channel}!\n#{$!}" + error "#{e.class}: #{e}" + error e.backtrace.join("\n") + end } end + + def cleanup + @lists.clear + @changed.clear + super + end + def addquote(source, channel, quote) @lists[channel] = Array.new if(!@lists.has_key?(channel)) num = @lists[channel].length - @lists[channel][num] = Quote.new(num, Time.new, source, quote) + @lists[channel][num] = Quote.new(num, Time.new, source.fullform, quote) + @changed[channel] = true return num end + def getquote(source, channel, num=nil) return nil unless(@lists.has_key?(channel)) return nil unless(@lists[channel].length > 0) @@ -41,18 +74,22 @@ class QuotePlugin < Plugin else # random quote return @lists[channel].compact[rand(@lists[channel].nitems)], - @lists[channel].length - 1 + @lists[channel].length - 1 end end + def delquote(channel, num) return false unless(@lists.has_key?(channel)) return false unless(@lists[channel].length > 0) if(@lists[channel][num]) @lists[channel][num] = nil + @lists[channel].pop if num == @lists[channel].length - 1 + @changed[channel] = true return true end return false end + def countquote(source, channel=nil, regexp=nil) unless(channel) total=0 @@ -70,38 +107,41 @@ class QuotePlugin < Plugin end return matches.length end + def searchquote(source, channel, regexp) return nil unless(@lists.has_key?(channel)) return nil unless(@lists[channel].length > 0) matches = @lists[channel].compact.find_all {|a| a.quote =~ /#{regexp}/i } if(matches.length > 0) - return matches[rand(matches.length)], @lists[channel].length - 1 + return matches[rand(matches.length)], @lists[channel].length - 1 else return nil end end + def help(plugin, topic="") case topic - when "addquote" - return "addquote [] => Add quote for channel . You only need to supply if you are addressing #{@bot.nick} privately. Responds to !addquote without addressing if so configured" - when "delquote" - return "delquote [] => delete quote from with number . You only need to supply if you are addressing #{@bot.nick} privately. Responds to !delquote without addressing if so configured" - when "getquote" - return "getquote [] [] => get quote from with number . You only need to supply if you are addressing #{@bot.nick} privately. Without , a random quote will be returned. Responds to !getquote without addressing if so configured" - when "searchquote" - return "searchquote [] => search for quote from that matches . You only need to supply if you are addressing #{@bot.nick} privately. Responds to !searchquote without addressing if so configured" - when "topicquote" - return "topicquote [] [] => set topic to quote from with number . You only need to supply if you are addressing #{@bot.nick} privately. Without , a random quote will be set. Responds to !topicquote without addressing if so configured" - when "countquote" - return "countquote [] => count quotes from that match . You only need to supply if you are addressing #{@bot.nick} privately. Responds to !countquote without addressing if so configured" - when "whoquote" - return "whoquote [] => show who added quote . You only need to supply if you are addressing #{@bot.nick} privately" - when "whenquote" - return "whenquote [] => show when quote was added. You only need to supply if you are addressing #{@bot.nick} privately" - else - return "Quote module (Quote storage and retrieval) topics: addquote, delquote, getquote, searchquote, topicquote, countquote, whoquote, whenquote" + when "addquote" + return "addquote [] => Add quote for channel . You only need to supply if you are addressing #{@bot.nick} privately. Responds to !addquote without addressing if so configured" + when "delquote" + return "delquote [] => delete quote from with number . You only need to supply if you are addressing #{@bot.nick} privately. Responds to !delquote without addressing if so configured" + when "getquote" + return "getquote [] [] => get quote from with number . You only need to supply if you are addressing #{@bot.nick} privately. Without , a random quote will be returned. Responds to !getquote without addressing if so configured" + when "searchquote" + return "searchquote [] => search for quote from that matches . You only need to supply if you are addressing #{@bot.nick} privately. Responds to !searchquote without addressing if so configured" + when "topicquote" + return "topicquote [] [] => set topic to quote from with number . You only need to supply if you are addressing #{@bot.nick} privately. Without , a random quote will be set. Responds to !topicquote without addressing if so configured" + when "countquote" + return "countquote [] => count quotes from that match . You only need to supply if you are addressing #{@bot.nick} privately. Responds to !countquote without addressing if so configured" + when "whoquote" + return "whoquote [] => show who added quote . You only need to supply if you are addressing #{@bot.nick} privately" + when "whenquote" + return "whenquote [] => show when quote was added. You only need to supply if you are addressing #{@bot.nick} privately" + else + return "Quote module (Quote storage and retrieval) topics: addquote, delquote, getquote, searchquote, topicquote, countquote, whoquote, whenquote" end end + def listen(m) return unless(m.kind_of? PrivMessage) @@ -111,7 +151,7 @@ class QuotePlugin < Plugin when (/^addquote\s+(#\S+)\s+(.*)/) channel = $1 quote = $2 - if(@bot.auth.allow?("addquote", m.source, m.replyto)) + if(@bot.auth.allow?("quote::other::add", m.source, m.replyto)) if(channel =~ /^#/) num = addquote(m.source, channel, quote) m.reply "added the quote (##{num})" @@ -119,7 +159,7 @@ class QuotePlugin < Plugin end when (/^getquote\s+(#\S+)$/) channel = $1 - if(@bot.auth.allow?("getquote", m.source, m.replyto)) + if(@bot.auth.allow?("quote::other::get", m.source, m.replyto)) quote, total = getquote(m.source, channel) if(quote) m.reply "[#{quote.num}] #{quote.quote}" @@ -130,7 +170,7 @@ class QuotePlugin < Plugin when (/^getquote\s+(#\S+)\s+(\d+)$/) channel = $1 num = $2.to_i - if(@bot.auth.allow?("getquote", m.source, m.replyto)) + if(@bot.auth.allow?("quote::other::get", m.source, m.replyto)) quote, total = getquote(m.source, channel, num) if(quote) m.reply "[#{quote.num}] #{quote.quote}" @@ -141,7 +181,7 @@ class QuotePlugin < Plugin when (/^whoquote\s+(#\S+)\s+(\d+)$/) channel = $1 num = $2.to_i - if(@bot.auth.allow?("getquote", m.source, m.replyto)) + if(@bot.auth.allow?("quote::other::get", m.source, m.replyto)) quote, total = getquote(m.source, channel, num) if(quote) m.reply "quote #{quote.num} added by #{quote.source}" @@ -152,7 +192,7 @@ class QuotePlugin < Plugin when (/^whenquote\s+(#\S+)\s+(\d+)$/) channel = $1 num = $2.to_i - if(@bot.auth.allow?("getquote", m.source, m.replyto)) + if(@bot.auth.allow?("quote::other::get", m.source, m.replyto)) quote, total = getquote(m.source, channel, num) if(quote) m.reply "quote #{quote.num} added on #{quote.date}" @@ -162,7 +202,7 @@ class QuotePlugin < Plugin end when (/^topicquote\s+(#\S+)$/) channel = $1 - if(@bot.auth.allow?("topicquote", m.source, m.replyto)) + if(@bot.auth.allow?("quote::other::topic", m.source, m.replyto)) quote, total = getquote(m.source, channel) if(quote) @bot.topic channel, "[#{quote.num}] #{quote.quote}" @@ -173,7 +213,7 @@ class QuotePlugin < Plugin when (/^topicquote\s+(#\S+)\s+(\d+)$/) channel = $1 num = $2.to_i - if(@bot.auth.allow?("topicquote", m.source, m.replyto)) + if(@bot.auth.allow?("quote::other::topic", m.source, m.replyto)) quote, total = getquote(m.source, channel, num) if(quote) @bot.topic channel, "[#{quote.num}] #{quote.quote}" @@ -184,7 +224,7 @@ class QuotePlugin < Plugin when (/^delquote\s+(#\S+)\s+(\d+)$/) channel = $1 num = $2.to_i - if(@bot.auth.allow?("delquote", m.source, m.replyto)) + if(@bot.auth.allow?("quote::other::del", m.source, m.replyto)) if(delquote(channel, num)) m.okay else @@ -194,7 +234,7 @@ class QuotePlugin < Plugin when (/^searchquote\s+(#\S+)\s+(.*)$/) channel = $1 reg = $2 - if(@bot.auth.allow?("getquote", m.source, m.replyto)) + if(@bot.auth.allow?("quote::other::get", m.source, m.replyto)) quote, total = searchquote(m.source, channel, reg) if(quote) m.reply "[#{quote.num}] #{quote.quote}" @@ -203,14 +243,14 @@ class QuotePlugin < Plugin end end when (/^countquote$/) - if(@bot.auth.allow?("getquote", m.source, m.replyto)) + if(@bot.auth.allow?("quote::get::count", m.source, m.replyto)) total = countquote(m.source) m.reply "#{total} quotes" end when (/^countquote\s+(#\S+)\s*(.*)$/) channel = $1 reg = $2 - if(@bot.auth.allow?("getquote", m.source, m.replyto)) + if(@bot.auth.allow?("quote::other::get::count", m.source, m.replyto)) total = countquote(m.source, channel, reg) if(reg.length > 0) m.reply "#{total} quotes match: #{reg}" @@ -222,13 +262,13 @@ class QuotePlugin < Plugin elsif (m.address? || (@bot.config["QUOTE_LISTEN"] && command.gsub!(/^!/, ""))) case command when (/^addquote\s+(.+)/) - if(@bot.auth.allow?("addquote", m.source, m.replyto)) - num = addquote(m.source, m.target, $1) + if(@bot.auth.allow?("quote::add", m.source, m.replyto)) + num = addquote(m.source, m.target.to_s, $1) m.reply "added the quote (##{num})" end when (/^getquote$/) - if(@bot.auth.allow?("getquote", m.source, m.replyto)) - quote, total = getquote(m.source, m.target) + if(@bot.auth.allow?("quote::get", m.source, m.replyto)) + quote, total = getquote(m.source, m.target.to_s) if(quote) m.reply "[#{quote.num}] #{quote.quote}" else @@ -237,8 +277,8 @@ class QuotePlugin < Plugin end when (/^getquote\s+(\d+)$/) num = $1.to_i - if(@bot.auth.allow?("getquote", m.source, m.replyto)) - quote, total = getquote(m.source, m.target, num) + if(@bot.auth.allow?("quote::get", m.source, m.replyto)) + quote, total = getquote(m.source, m.target.to_s, num) if(quote) m.reply "[#{quote.num}] #{quote.quote}" else @@ -247,8 +287,8 @@ class QuotePlugin < Plugin end when (/^whenquote\s+(\d+)$/) num = $1.to_i - if(@bot.auth.allow?("getquote", m.source, m.replyto)) - quote, total = getquote(m.source, m.target, num) + if(@bot.auth.allow?("quote::get", m.source, m.replyto)) + quote, total = getquote(m.source, m.target.to_s, num) if(quote) m.reply "quote #{quote.num} added on #{quote.date}" else @@ -257,8 +297,8 @@ class QuotePlugin < Plugin end when (/^whoquote\s+(\d+)$/) num = $1.to_i - if(@bot.auth.allow?("getquote", m.source, m.replyto)) - quote, total = getquote(m.source, m.target, num) + if(@bot.auth.allow?("quote::get", m.source, m.replyto)) + quote, total = getquote(m.source, m.target.to_s, num) if(quote) m.reply "quote #{quote.num} added by #{quote.source}" else @@ -266,8 +306,8 @@ class QuotePlugin < Plugin end end when (/^topicquote$/) - if(@bot.auth.allow?("topicquote", m.source, m.replyto)) - quote, total = getquote(m.source, m.target) + if(@bot.auth.allow?("quote::topic", m.source, m.replyto)) + quote, total = getquote(m.source, m.target.to_s) if(quote) @bot.topic m.target, "[#{quote.num}] #{quote.quote}" else @@ -276,8 +316,8 @@ class QuotePlugin < Plugin end when (/^topicquote\s+(\d+)$/) num = $1.to_i - if(@bot.auth.allow?("topicquote", m.source, m.replyto)) - quote, total = getquote(m.source, m.target, num) + if(@bot.auth.allow?("quote::topic", m.source, m.replyto)) + quote, total = getquote(m.source, m.target.to_s, num) if(quote) @bot.topic m.target, "[#{quote.num}] #{quote.quote}" else @@ -286,8 +326,8 @@ class QuotePlugin < Plugin end when (/^delquote\s+(\d+)$/) num = $1.to_i - if(@bot.auth.allow?("delquote", m.source, m.replyto)) - if(delquote(m.target, num)) + if(@bot.auth.allow?("quote::del", m.source, m.replyto)) + if(delquote(m.target.to_s, num)) m.okay else m.reply "quote not found!" @@ -295,8 +335,8 @@ class QuotePlugin < Plugin end when (/^searchquote\s+(.*)$/) reg = $1 - if(@bot.auth.allow?("getquote", m.source, m.replyto)) - quote, total = searchquote(m.source, m.target, reg) + if(@bot.auth.allow?("quote::get", m.source, m.replyto)) + quote, total = searchquote(m.source, m.target.to_s, reg) if(quote) m.reply "[#{quote.num}] #{quote.quote}" else @@ -305,8 +345,8 @@ class QuotePlugin < Plugin end when (/^countquote(?:\s+(.*))?$/) reg = $1 - if(@bot.auth.allow?("getquote", m.source, m.replyto)) - total = countquote(m.source, m.target, reg) + if(@bot.auth.allow?("quote::get::count", m.source, m.replyto)) + total = countquote(m.source, m.target.to_s, reg) if(reg && reg.length > 0) m.reply "#{total} quotes match: #{reg}" else @@ -317,5 +357,9 @@ class QuotePlugin < Plugin end end end + plugin = QuotePlugin.new plugin.register("quotes") +plugin.default_auth('other', false) # Prevent random people from editing other channels quote lists by default +plugin.default_auth('other::get', true) # But allow them to view them +plugin.default_auth('del', false) # Prevent random people from removing quotes