diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/rbot/ircbot.rb | 17 | ||||
-rw-r--r-- | lib/rbot/message.rb | 64 | ||||
-rw-r--r-- | lib/rbot/rfc2812.rb | 10 |
3 files changed, 69 insertions, 22 deletions
diff --git a/lib/rbot/ircbot.rb b/lib/rbot/ircbot.rb index f1aa7e50..966e5a84 100644 --- a/lib/rbot/ircbot.rb +++ b/lib/rbot/ircbot.rb @@ -83,6 +83,9 @@ class IrcBot # bot's Language data attr_reader :lang + # capabilities info for the server + attr_reader :capabilities + # channel info for channels the bot is in attr_reader :channels @@ -250,6 +253,19 @@ class IrcBot @nick = @config['irc.nick'] @client = IrcClient.new + @client[:isupport] = proc { |data| + if data[:capab] + sendq "CAPAB IDENTIFY-MSG" + end + } + @client[:datastr] = proc { |data| + debug data.inspect + if data[:text] == "IDENTIFY-MSG" + @capabilities["identify-msg".to_sym] = true + else + debug "Not handling RPL_DATASTR #{data[:servermessage]}" + end + } @client[:privmsg] = proc { |data| message = PrivMessage.new(self, data[:source], data[:target], data[:message]) onprivmsg(message) @@ -430,6 +446,7 @@ class IrcBot end @socket.emergency_puts "PASS " + @config['server.password'] if @config['server.password'] @socket.emergency_puts "NICK #{@nick}\nUSER #{@config['irc.user']} 4 #{@config['server.name']} :Ruby bot. (c) Tom Gilbert" + @capabilities = Hash.new start_server_pings end diff --git a/lib/rbot/message.rb b/lib/rbot/message.rb index a92194e9..fcbdbc56 100644 --- a/lib/rbot/message.rb +++ b/lib/rbot/message.rb @@ -8,25 +8,25 @@ module Irc # (a user message is defined as having a source hostmask, a target # nick/channel and a message part) class BasicUserMessage - + # associated bot attr_reader :bot - + # when the message was received attr_reader :time # hostmask of message source attr_reader :source - + # nick of message source attr_reader :sourcenick - + # url part of message source attr_reader :sourceaddress - + # nick/channel message was sent to attr_reader :target - + # contents of the message attr_accessor :message @@ -47,18 +47,32 @@ module Irc @message = BasicUserMessage.stripcolour message @replied = false + @identified = false + if @msg_wants_id && @bot.capabilities["identify-msg".to_sym] + if @message =~ /([-+])(.*)/ + @identified = ($1=="+") + @message = $2 + else + warning "Message does not have identification" + end + end + # split source into consituent parts if source =~ /^((\S+)!(\S+))$/ @sourcenick = $2 @sourceaddress = $3 end - + if target && target.downcase == @bot.nick.downcase @address = true end - + end - + + def identified? + return @identified + end + # returns true if the message was addressed to the bot. # This includes any private message to the bot, or any public message # which looks like it's addressed to the bot, e.g. "bot: foo", "bot, foo", @@ -87,10 +101,10 @@ module Irc # The +message+ member will have any bot addressing "^bot: " removed # (address? will return true in this case) class UserMessage < BasicUserMessage - + # for plugin messages, the name of the plugin invoked by the message attr_reader :plugin - + # for plugin messages, the rest of the message, with the plugin name # removed attr_reader :params @@ -102,11 +116,11 @@ module Irc # channel the message was in, nil for privately addressed messages attr_reader :channel - + # for PRIVMSGs, true if the message was a CTCP ACTION (CTCP stuff # will be stripped from the message) attr_reader :action - + # instantiate a new UserMessage # bot:: associated bot class # source:: hostmask of the message source @@ -118,7 +132,7 @@ module Irc @private = false @plugin = nil @action = false - + if target.downcase == @bot.nick.downcase @private = true @address = true @@ -137,19 +151,19 @@ module Irc break end } - + # even if they used above prefixes, we allow for silly people who - # combine all possible types, e.g. "|rbot: hello", or + # combine all possible types, e.g. "|rbot: hello", or # "/msg rbot rbot: hello", etc if @message.gsub!(/^\s*#{Regexp.escape(bot.nick)}\s*([:;,>]|\s)\s*/i, "") @address = true end - + if(@message =~ /^\001ACTION\s(.+)\001/) @message = $1 @action = true end - + # free splitting for plugins @params = @message.dup if @params.gsub!(/^\s*(\S+)[\s$]*/, "") @@ -192,10 +206,18 @@ module Irc # class to manage IRC PRIVMSGs class PrivMessage < UserMessage + def initialize(bot, source, target, message) + @msg_wants_id = true + super + end end - + # class to manage IRC NOTICEs class NoticeMessage < UserMessage + def initialize(bot, source, target, message) + @msg_wants_id = true + super + end end # class to manage IRC KICKs @@ -204,7 +226,7 @@ module Irc class KickMessage < BasicUserMessage # channel user was kicked from attr_reader :channel - + def initialize(bot, source, target, channel, message="") super(bot, source, target, message) @channel = channel @@ -252,7 +274,7 @@ module Irc @address = (sourcenick.downcase == @bot.nick.downcase) end end - + # class to manage channel parts # same as a join, but can have a message too class PartMessage < JoinMessage diff --git a/lib/rbot/rfc2812.rb b/lib/rbot/rfc2812.rb index 8dc2016c..965da0a1 100644 --- a/lib/rbot/rfc2812.rb +++ b/lib/rbot/rfc2812.rb @@ -809,6 +809,7 @@ module Irc RPL_STATSPING=246 RPL_STATSBLINE=247 ERR_NOSERVICEHOST=492 + RPL_DATASTR=290 # implements RFC 2812 and prior IRC RFCs. # clients register handler proc{}s for different server events and IrcClient @@ -956,9 +957,13 @@ module Irc # PREFIX=(ov)@+ CASEMAPPING=ascii CAPAB IRCD=dancer :are available # on this server" # - argv.each {|a| + argv[0,argv.length-1].each {|a| if a =~ /^(.*)=(.*)$/ data[$1.downcase.to_sym] = $2 + debug "server's #{$1.downcase.to_sym} is #{$2}" + else + data[a.downcase.to_sym] = true + debug "server supports #{a.downcase.to_sym}" end } handle(:isupport, data) @@ -1030,6 +1035,9 @@ module Irc when RPL_ENDOFMOTD data[:motd] = @motd handle(:motd, data) + when RPL_DATASTR + data[:text] = argv[1] + handle(:datastr, data) else handle(:unknown, data) end |