diff options
author | Tom Gilbert <tom@linuxbrit.co.uk> | 2005-08-12 19:51:24 +0000 |
---|---|---|
committer | Tom Gilbert <tom@linuxbrit.co.uk> | 2005-08-12 19:51:24 +0000 |
commit | e74384474f445f916e58e7a0b5afe9a519b77f86 (patch) | |
tree | 42d98997f25330cfdc2b35e4813a99ce65edda03 | |
parent | f6cd49278021305198e5ec7f9060d2410a3a661d (diff) |
fix autoop plugin
-rw-r--r-- | data/rbot/plugins/autoop.rb | 90 |
1 files changed, 39 insertions, 51 deletions
diff --git a/data/rbot/plugins/autoop.rb b/data/rbot/plugins/autoop.rb index d4067a32..9da5bd37 100644 --- a/data/rbot/plugins/autoop.rb +++ b/data/rbot/plugins/autoop.rb @@ -1,68 +1,56 @@ class AutoOP < Plugin - @@handlers = { - "add" => "handle_addop", - "rm" => "handle_rmop", - "list" => "handle_listop" - } - def help(plugin, topic="") - "perform autoop based on hostmask - usage: addop <hostmask>, rmop <hostmask>, listop" + "perform autoop based on hostmask - usage: addop <hostmask> [channel channel ...], rmop <hostmask> [channel], list - list current ops. If you don't specify which channels, all channels are assumed" end def join(m) - if(!m.address?) - @registry.each { |mask,channels| - if(Irc.netmaskmatch(mask, m.source) && channels.include?(m.channel)) - @bot.mode(m.channel, "+o", m.sourcenick) - end - } - end - end - - def privmsg(m) - if(m.private?) - if (!m.params || m.params == "list") - handle_listop(m) - elsif (m.params =~ /^add\s+(.+)$/) - handle_addop(m, $1) - elsif (m.params =~ /^rm\s+(.+)$/) - handle_rmop(m, $1) - end - else - m.reply "private message only please!" + return if m.address? + @registry.each { |mask,channels| + if(Irc.netmaskmatch(mask, m.source) && + (channels.empty? || channels.include?(m.channel))) + @bot.mode(m.channel, "+o", m.sourcenick) + return end + } end - def handle_addop(m, params) - ma = /^(.+?)(\s+(.+))?$/.match(params) - channels = ma[2] ? ma[2] : @bot.config['irc.join_channels'] - if(ma[1] && channels) - @registry[ma[1]] = channels - m.okay - else - m.reply @bot.lang.get('dunno') - end + def add(m, params) + @registry[params[:mask]] = params[:channels].dup + m.okay end - def handle_rmop(m, params) - if(!@registry.delete(params)) - m.reply @bot.lang.get('dunno') - else - m.okay - end + def rm(m, params) + unless @registry.has_key?(params[:mask]) + m.reply @bot.lang.get('dunno') + return + end + if (params[:channels] && @registry[params[:mask]] != nil) + params[:channels].each do |c| + @registry[params[:mask]] = @registry[params[:mask]].reject {|ele| ele =~ /^#{c}$/i} + end + elsif(!@registry.delete(params[:mask])) + m.reply @bot.lang.get('dunno') + else + m.okay + end end - def handle_listop(m) - if(@registry.length) - @registry.each { |mask,channels| - m.reply "#{mask} in #{channels.join(', ')}" - } - else - m.reply "No entrys" - end + def list(m, params) + if(@registry.length) + @registry.each { |mask,channels| + m.reply "#{mask} in #{channels.empty? ? 'all channels' : channels.join(', ')}" + } + else + m.reply "No entrys" + end end end plugin = AutoOP.new -plugin.register("autoop") + +plugin.map 'autoop list', :action => 'list' +plugin.map 'autoop add :mask *channels', :action => 'add' +plugin.map 'autoop add :mask', :action => 'add' +plugin.map 'autoop rm :mask *channels', :action => 'rm' +plugin.map 'autoop rm :mask', :action => 'rm' |