From 9e20940da4694a352a1a11476756d9dd7e021d4a Mon Sep 17 00:00:00 2001 From: Tom Gilbert Date: Sat, 16 Jul 2005 00:19:33 +0000 Subject: autoop plugin submitted by Rene Nussbaumer, tweaked by me. --- rbot/plugins/autoop.rb | 68 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 rbot/plugins/autoop.rb (limited to 'rbot') diff --git a/rbot/plugins/autoop.rb b/rbot/plugins/autoop.rb new file mode 100644 index 00000000..094ee343 --- /dev/null +++ b/rbot/plugins/autoop.rb @@ -0,0 +1,68 @@ +class AutoOP < Plugin + @@handlers = { + "addop" => "handle_addop", + "rmop" => "handle_rmop", + "listop" => "handle_listop" + } + + def help(plugin, topic="") + "perform autoop based on hostmask - usage: addop , rmop , listop" + 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 + end + end + + def handle_addop(m, params) + ma = /^(.+?)(\s+(.+))?$/.match(params) + channels = ma[2] ? ma[2] : @bot.config['JOIN_CHANNELS'] + if(ma[1] && channels) + @registry[ma[1]] = channels.split(/,\s*/).collect { |x| + x.strip + } + @bot.okay m.replyto + else + m.reply @bot.lang.get('dunno') + end + end + + def handle_rmop(m, params) + if(!@registry.delete(params)) + m.reply @bot.lang.get('dunno') + else + @bot.okay m.replyto + 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 + end +end + +plugin = AutoOP.new +plugin.register("autoop") + -- cgit v1.2.3