X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=data%2Frbot%2Fplugins%2Fquotes.rb;h=2d9bedcd00b614cc872b877b54c2f5a4ee7ec798;hb=69db4133c5ccfa41c35b43c67fce1d5ff640bfd5;hp=aae70592e629c0d7193ddce9a5a3cae8072532ba;hpb=6e8e503ede5f3a1a55826c94a87a6be9a5daed0e;p=user%2Fhenk%2Fcode%2Fruby%2Frbot.git diff --git a/data/rbot/plugins/quotes.rb b/data/rbot/plugins/quotes.rb index aae70592..2d9bedcd 100644 --- a/data/rbot/plugins/quotes.rb +++ b/data/rbot/plugins/quotes.rb @@ -1,6 +1,12 @@ -# GB: Ok, we *really* need to switch to db for this plugin too +#-- vim:sw=2:et +#++ +# +# :title: Quotes plugin +# +# TODO:: use message mapper instead of multiple ifs +# TODO:: switch to db -Quote = Struct.new("Quote", :num, :date, :source, :quote) +define_structure :Quote, :num, :date, :source, :quote class QuotePlugin < Plugin def initialize @@ -20,6 +26,7 @@ class QuotePlugin < Plugin @changed[channel] = false } end + def save Dir.mkdir("#{@bot.botclass}/quotes") if(!FileTest.directory?("#{@bot.botclass}/quotes")) @lists.each {|channel, quotes| @@ -42,17 +49,20 @@ class QuotePlugin < Plugin end } end + def cleanup @lists.clear @changed.clear 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) @@ -66,6 +76,7 @@ class QuotePlugin < Plugin @lists[channel].length - 1 end end + def delquote(channel, num) return false unless(@lists.has_key?(channel)) return false unless(@lists[channel].length > 0) @@ -77,6 +88,7 @@ class QuotePlugin < Plugin end return false end + def countquote(source, channel=nil, regexp=nil) unless(channel) total=0 @@ -94,6 +106,7 @@ 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) @@ -104,6 +117,7 @@ class QuotePlugin < Plugin return nil end end + def help(plugin, topic="") case topic when "addquote" @@ -126,6 +140,7 @@ class QuotePlugin < Plugin 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) @@ -135,7 +150,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})" @@ -143,7 +158,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}" @@ -154,7 +169,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}" @@ -165,7 +180,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}" @@ -176,7 +191,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}" @@ -186,7 +201,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}" @@ -197,7 +212,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}" @@ -208,7 +223,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 @@ -218,7 +233,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}" @@ -227,14 +242,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}" @@ -246,12 +261,12 @@ 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)) + 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)) + 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}" @@ -261,7 +276,7 @@ class QuotePlugin < Plugin end when (/^getquote\s+(\d+)$/) num = $1.to_i - if(@bot.auth.allow?("getquote", m.source, m.replyto)) + 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}" @@ -271,7 +286,7 @@ class QuotePlugin < Plugin end when (/^whenquote\s+(\d+)$/) num = $1.to_i - if(@bot.auth.allow?("getquote", m.source, m.replyto)) + 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}" @@ -281,7 +296,7 @@ class QuotePlugin < Plugin end when (/^whoquote\s+(\d+)$/) num = $1.to_i - if(@bot.auth.allow?("getquote", m.source, m.replyto)) + 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}" @@ -290,7 +305,7 @@ class QuotePlugin < Plugin end end when (/^topicquote$/) - if(@bot.auth.allow?("topicquote", m.source, m.replyto)) + 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}" @@ -300,7 +315,7 @@ class QuotePlugin < Plugin end when (/^topicquote\s+(\d+)$/) num = $1.to_i - if(@bot.auth.allow?("topicquote", m.source, m.replyto)) + 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}" @@ -310,7 +325,7 @@ class QuotePlugin < Plugin end when (/^delquote\s+(\d+)$/) num = $1.to_i - if(@bot.auth.allow?("delquote", m.source, m.replyto)) + if(@bot.auth.allow?("quote::del", m.source, m.replyto)) if(delquote(m.target.to_s, num)) m.okay else @@ -319,7 +334,7 @@ class QuotePlugin < Plugin end when (/^searchquote\s+(.*)$/) reg = $1 - if(@bot.auth.allow?("getquote", m.source, m.replyto)) + 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}" @@ -329,7 +344,7 @@ class QuotePlugin < Plugin end when (/^countquote(?:\s+(.*))?$/) reg = $1 - 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.target.to_s, reg) if(reg && reg.length > 0) m.reply "#{total} quotes match: #{reg}" @@ -341,5 +356,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