diff options
author | Giuseppe Bilotta <giuseppe.bilotta@gmail.com> | 2006-08-02 00:04:19 +0000 |
---|---|---|
committer | Giuseppe Bilotta <giuseppe.bilotta@gmail.com> | 2006-08-02 00:04:19 +0000 |
commit | 7bef95455cfbec9cf77db283a11e177f4c981b6a (patch) | |
tree | 8c0d5baf067f060075dc49efc366a82cb63e495a /lib/rbot | |
parent | fdc64bd6634ae0aa3b9ecc4973648114f4a83ef5 (diff) |
Modularized core now functional. Still a lot to do and auth missing, but the bot is almost usable now
Diffstat (limited to 'lib/rbot')
-rw-r--r-- | lib/rbot/botuser.rb | 12 | ||||
-rw-r--r-- | lib/rbot/core/core.rb | 286 | ||||
-rw-r--r-- | lib/rbot/ircbot.rb | 46 | ||||
-rw-r--r-- | lib/rbot/plugins.rb | 13 |
4 files changed, 222 insertions, 135 deletions
diff --git a/lib/rbot/botuser.rb b/lib/rbot/botuser.rb index 67d7d842..98408a0d 100644 --- a/lib/rbot/botuser.rb +++ b/lib/rbot/botuser.rb @@ -258,10 +258,7 @@ module Irc def set_permission(cmd, val)
raise TypeError, "#{val.inspect} must be true or false" unless [true,false].include?(val)
Irc::error_if_not_command(cmd)
- cmd.path.each { |k|
- set_permission(k.to_s, true) unless @perm.has_key?(k)
- }
- @perm[path.last] = val
+ @perm[cmd.command] = val
end
# Tells if command _cmd_ is permitted. We do this by returning
@@ -308,7 +305,12 @@ module Irc def set_permission(cmd, val, chan="*")
k = chan.to_s.to_sym
@perm[k] = PermissionSet.new unless @perm.has_key?(k)
- @perm[k].set_permission(cmd, val)
+ case cmd
+ when String
+ @perm[k].set_permission(Command.new(cmd), val)
+ else
+ @perm[k].set_permission(cmd, val)
+ end
end
# Checks if BotUser is allowed to do something on channel _chan_,
diff --git a/lib/rbot/core/core.rb b/lib/rbot/core/core.rb index c9210d59..fcf5ac3a 100644 --- a/lib/rbot/core/core.rb +++ b/lib/rbot/core/core.rb @@ -4,8 +4,6 @@ class Core < CoreBotModule
- # TODO cleanup
- # handle incoming IRC PRIVMSG +m+
def listen(m)
return unless m.class <= PrivMessage
if(m.private? && m.message =~ /^\001PING\s+(.+)\001/)
@@ -13,105 +11,116 @@ class Core < CoreBotModule @bot.irclog "@ #{m.sourcenick} pinged me"
return
end
+ end
+
+ def bot_join(m, param)
+ if param[:pass]
+ @bot.join param[:chan], param[:pass]
+ else
+ @bot.join param[:chan]
+ end
+ end
+
+ def bot_part(m, param)
+ if param[:chan]
+ @bot.part param[:chan]
+ else
+ @bot.part m.target if m.public?
+ end
+ end
+
+ def bot_quit(m, param)
+ @bot.quit(param[:msg] ? param[:msg].join(" ") : nil)
+ end
+
+ def bot_restart(m, param)
+ @bot.restart(param[:msg] ? param[:msg].join(" ") : nil)
+ end
+
+ def bot_hide(m, param)
+ @bot.join 0
+ end
+
+ def bot_save(m, param)
+ @bot.save
+ m.okay
+ end
+
+ def bot_nick(m, param)
+ @bot.nickchg(param[:nick])
+ end
+
+ def bot_say(m, param)
+ @bot.say param[:where], param[:what].join(" ")
+ end
+
+ def bot_action(m, param)
+ @bot.action param[:where], param[:what].join(" ")
+ end
+
+ def bot_mode(m, param)
+ @bot.mode param[:where], param[:what], param[:who].join(" ")
+ end
+
+ def bot_ping(m, param)
+ m.reply "pong"
+ end
+
+ def bot_rescan(m, param)
+ m.reply "saving ..."
+ @bot.save
+ m.reply "rescanning ..."
+ @bot.rescan
+ m.reply "done. #{@plugins.status(true)}"
+ end
+
+ def bot_quiet(m, param)
+ if param.has_key?(:where)
+ @bot.set_quiet param[:where].sub(/^here$/, m.target)
+ else
+ @bot.set_quiet
+ end
+ end
- if(m.address?)
- case m.message
- when (/^join\s+(\S+)\s+(\S+)$/i)
- @bot.join $1, $2 if(@bot.auth.allow?("join", m.source, m.replyto))
- when (/^join\s+(\S+)$/i)
- @bot.join $1 if(@bot.auth.allow?("join", m.source, m.replyto))
- when (/^part$/i)
- @bot.part m.target if(m.public? && @bot.auth.allow?("join", m.source, m.replyto))
- when (/^part\s+(\S+)$/i)
- @bot.part $1 if(@bot.auth.allow?("join", m.source, m.replyto))
- when (/^quit(?:\s+(.*))?$/i)
- @bot.quit $1 if(@bot.auth.allow?("quit", m.source, m.replyto))
- when (/^restart(?:\s+(.*))?$/i)
- @bot.restart $1 if(@bot.auth.allow?("quit", m.source, m.replyto))
- when (/^hide$/i)
- @bot.join 0 if(@bot.auth.allow?("join", m.source, m.replyto))
- when (/^save$/i)
- if(@bot.auth.allow?("config", m.source, m.replyto))
- @bot.save
- m.okay
- end
- when (/^nick\s+(\S+)$/i)
- @bot.nickchg($1) if(@bot.auth.allow?("nick", m.source, m.replyto))
- when (/^say\s+(\S+)\s+(.*)$/i)
- @bot.say $1, $2 if(@bot.auth.allow?("say", m.source, m.replyto))
- when (/^action\s+(\S+)\s+(.*)$/i)
- @bot.action $1, $2 if(@bot.auth.allow?("say", m.source, m.replyto))
- # when (/^topic\s+(\S+)\s+(.*)$/i)
- # topic $1, $2 if(@bot.auth.allow?("topic", m.source, m.replyto))
- when (/^mode\s+(\S+)\s+(\S+)\s+(.*)$/i)
- @bot.mode $1, $2, $3 if(@bot.auth.allow?("mode", m.source, m.replyto))
- when (/^ping$/i)
- @bot.say m.replyto, "pong"
- when (/^rescan$/i)
- if(@bot.auth.allow?("config", m.source, m.replyto))
- m.reply "saving ..."
- @bot.save
- m.reply "rescanning ..."
- @bot.rescan
- m.reply "done. #{@plugins.status(true)}"
- end
- when (/^quiet$/i)
- if(@bot.auth.allow?("talk", m.source, m.replyto))
- m.okay
- @bot.set_quiet
- end
- when (/^quiet in (\S+)$/i)
- where = $1
- if(@bot.auth.allow?("talk", m.source, m.replyto))
- m.okay
- where.gsub!(/^here$/, m.target) if m.public?
- @bot.set_quiet(where)
- end
- when (/^talk$/i)
- if(@bot.auth.allow?("talk", m.source, m.replyto))
- @bot.reset_quiet
- m.okay
- end
- when (/^talk in (\S+)$/i)
- where = $1
- if(@bot.auth.allow?("talk", m.source, m.replyto))
- where.gsub!(/^here$/, m.target) if m.public?
- @bot.reset_quiet(where)
- m.okay
- end
- when (/^status\??$/i)
- m.reply status if @bot.auth.allow?("status", m.source, m.replyto)
- when (/^registry stats$/i)
- if @bot.auth.allow?("config", m.source, m.replyto)
- m.reply @registry.stat.inspect
- end
- when (/^(help\s+)?config(\s+|$)/)
- @config.privmsg(m)
- when (/^(version)|(introduce yourself)$/i)
- @bot.say m.replyto, "I'm a v. #{$version} rubybot, (c) Tom Gilbert - http://linuxbrit.co.uk/rbot/"
- when (/^help(?:\s+(.*))?$/i)
- @bot.say m.replyto, help($1)
- #TODO move these to a "chatback" plugin
- when (/^(botsnack|ciggie)$/i)
- @bot.say m.replyto, @lang.get("thanks_X") % m.sourcenick if(m.public?)
- @bot.say m.replyto, @lang.get("thanks") if(m.private?)
- when (/^(hello|howdy|hola|salut|bonjour|sup|niihau|hey|hi(\W|$)|yo(\W|$)).*/i)
- @bot.say m.replyto, @lang.get("hello_X") % m.sourcenick if(m.public?)
- @bot.say m.replyto, @lang.get("hello") if(m.private?)
- end
+ def bot_talk(m, param)
+ if param.has_key?(:where)
+ @bot.reset_quiet param[:where].sub(/^here$/, m.target)
else
- # stuff to handle when not addressed
- case m.message
- when (/^\s*(hello|howdy|hola|salut|bonjour|sup|niihau|hey|hi|yo(\W|$))[\s,-.]+#{Regexp.escape(@bot.nick)}$/i)
- @bot.say m.replyto, @lang.get("hello_X") % m.sourcenick
- when (/^#{Regexp.escape(@bot.nick)}!*$/)
- @bot.say m.replyto, @lang.get("hello_X") % m.sourcenick
- else
- # @keywords.privmsg(m)
- end
+ @bot.reset_quiet
end
end
+ def bot_status(m, param)
+ m.reply @bot.status
+ end
+
+ # TODO is this one of the methods that disappeared when the bot was moved
+ # from the single-file to the multi-file registry?
+ #
+ # def bot_reg_stat(m, param)
+ # m.reply @registry.stat.inspect
+ # end
+
+ def bot_version(m, param)
+ m.reply "I'm a v. #{$version} rubybot, (c) Tom Gilbert - http://linuxbrit.co.uk/rbot/"
+ end
+
+ def bot_help(m, param)
+ m.reply @bot.help(param[:topic].join(" "))
+ end
+
+ #TODO move these to a "chatback" plugin
+ # when (/^(botsnack|ciggie)$/i)
+ # @bot.say m.replyto, @lang.get("thanks_X") % m.sourcenick if(m.public?)
+ # @bot.say m.replyto, @lang.get("thanks") if(m.private?)
+ # when (/^(hello|howdy|hola|salut|bonjour|sup|niihau|hey|hi(\W|$)|yo(\W|$)).*/i)
+ # @bot.say m.replyto, @lang.get("hello_X") % m.sourcenick if(m.public?)
+ # @bot.say m.replyto, @lang.get("hello") if(m.private?)
+ # when (/^\s*(hello|howdy|hola|salut|bonjour|sup|niihau|hey|hi|yo(\W|$))[\s,-.]+#{Regexp.escape(@bot.nick)}$/i)
+ # @bot.say m.replyto, @lang.get("hello_X") % m.sourcenick
+ # when (/^#{Regexp.escape(@bot.nick)}!*$/)
+ # @bot.say m.replyto, @lang.get("hello_X") % m.sourcenick
+
# handle help requests for "core" topics
def help(topic="")
case topic
@@ -141,10 +150,10 @@ class Core < CoreBotModule return "talk [in here|<channel>] => with no arguments, resume speaking in all channels, if \"in here\", resume speaking in this channel, or resume speaking in <channel>"
when "version"
return "version => describes software version"
- when "botsnack"
- return "botsnack => reward #{myself} for being good"
- when "hello"
- return "hello|hi|hey|yo [#{myself}] => greet the bot"
+ # when "botsnack"
+ # return "botsnack => reward #{myself} for being good"
+ # when "hello"
+ # return "hello|hi|hey|yo [#{myself}] => greet the bot"
else
return "Core help topics: quit, restart, config, join, part, hide, save, rescan, nick, say, action, topic, quiet, talk, version, botsnack, hello"
end
@@ -153,3 +162,80 @@ end core = Core.new
+core.map "quit *msg",
+ :action => 'bot_quit',
+ :defaults => { :msg => nil },
+ :auth => 'core::quit::quit'
+core.map "restart *msg",
+ :action => 'bot_restart',
+ :defaults => { :msg => nil },
+ :auth => 'core::quit::restart'
+
+core.map "save",
+ :action => 'bot_save',
+ :auth => 'core::config::save'
+core.map "rescan",
+ :action => 'bot_rescan',
+ :auth => 'core::config::rescan'
+core.map "nick :nick",
+ :action => 'bot_nick',
+ :auth => 'core::config::nick'
+core.map "status",
+ :action => 'bot_status',
+ :auth => 'core::config::show::status'
+ # TODO see above
+ #
+ # core.map "registry stats",
+ # :action => 'bot_reg_stat',
+ # :auth => 'core::config::show::registry'
+core.map "version",
+ :action => 'bot_version',
+ :auth => 'core::config::show::version'
+
+core.map "quiet",
+ :action => 'bot_quiet',
+ :auth => 'core::talk::quiet'
+core.map "quiet in :chan",
+ :action => 'bot_quiet',
+ :auth => 'core::talk::quiet'
+core.map "talk",
+ :action => 'bot_talk',
+ :auth => 'core::talk::talk'
+core.map "quiet in :chan",
+ :action => 'bot_quiet',
+ :auth => 'core::talk::talk'
+
+core.map "join :chan :pass",
+ :action => 'bot_join',
+ :defaults => {:pass => nil},
+ :auth => 'core::movearound::join'
+core.map "part :chan",
+ :action => 'bot_part',
+ :defaults => {:chan => nil},
+ :auth => 'core::movearound::part'
+core.map "hide",
+ :action => 'bot_hide',
+ :auth => 'core::movearound::hide'
+
+core.map "say :where *what",
+ :action => 'bot_say',
+ :auth => 'core::talk::say'
+core.map "action :where *what",
+ :action => 'bot_action',
+ :auth => 'core::talk::act'
+core.map "mode :where :what *who",
+ :action => 'bot_mode',
+ :auth => 'core::talk::mode'
+
+core.map "ping",
+ :action => 'bot_ping'
+core.map "help *topic",
+ :action => 'bot_help',
+ :default => { :topic => [""] }
+
+# TODO the first line should probably go to the auth module?
+#
+core.default_auth('*', true)
+core.default_auth('core', false)
+core.default_auth('core::config::show', true)
+
diff --git a/lib/rbot/ircbot.rb b/lib/rbot/ircbot.rb index d567189b..f1d9e127 100644 --- a/lib/rbot/ircbot.rb +++ b/lib/rbot/ircbot.rb @@ -864,35 +864,23 @@ class IrcBot sendq "MODE #{channel} #{mode} #{target}", channel, 2 end - # # m:: message asking for help - # # topic:: optional topic help is requested for - # # respond to online help requests - # def help(topic=nil) - # topic = nil if topic == "" - # case topic - # when nil - # helpstr = "help topics: core, auth, keywords" - # helpstr += @plugins.helptopics - # helpstr += " (help <topic> for more info)" - # when /^core$/i - # helpstr = corehelp - # when /^core\s+(.+)$/i - # helpstr = corehelp $1 - # when /^auth$/i - # helpstr = @auth.help - # when /^auth\s+(.+)$/i - # helpstr = @auth.help $1 - # when /^keywords$/i - # helpstr = @keywords.help - # when /^keywords\s+(.+)$/i - # helpstr = @keywords.help $1 - # else - # unless(helpstr = @plugins.help(topic)) - # helpstr = "no help for topic #{topic}" - # end - # end - # return helpstr - # end + # m:: message asking for help + # topic:: optional topic help is requested for + # respond to online help requests + def help(topic=nil) + topic = nil if topic == "" + case topic + when nil + helpstr = "help topics: " + helpstr += @plugins.helptopics + helpstr += " (help <topic> for more info)" + else + unless(helpstr = @plugins.help(topic)) + helpstr = "no help for topic #{topic}" + end + end + return helpstr + end # returns a string describing the current status of the bot (uptime etc) def status diff --git a/lib/rbot/plugins.rb b/lib/rbot/plugins.rb index bb4c744a..31fb1134 100644 --- a/lib/rbot/plugins.rb +++ b/lib/rbot/plugins.rb @@ -153,6 +153,14 @@ module Plugins end end + # Sets the default auth for command _cmd_ to _val_ on channel _chan_: + # usually _chan_ is either "*" for everywhere, public and private (in + # which case it can be omitted) or "?" for private communications + # + def default_auth(cmd, val, chan="*") + Auth::anonbotuser.set_permission(cmd, val) + end + # return an identifier for this plugin, defaults to a list of the message # prefixes handled (used for error messages etc) def name @@ -325,6 +333,8 @@ module Plugins # add one or more directories to the list of directories to # load botmodules from # + # TODO find a way to specify necessary plugins which _must_ be loaded + # def add_botmodule_dir(*dirlist) @dirs += dirlist debug "Botmodule loading path: #{@dirs.join(', ')}" @@ -438,7 +448,7 @@ module Plugins # return list of help topics (plugin names) def helptopics - return " [#{status}]" + return status end def length @@ -475,6 +485,7 @@ module Plugins when /^(\S+)\s*(.*)$/ key = $1 params = $2 + # TODO should also check core_module and plugins [core_commands, plugin_commands].each { |pl| if(pl.has_key?(key)) begin |