class ::String # Calculate the penalty which will be assigned to this message # by the IRCd def irc_send_penalty # According to eggrdop, the initial penalty is penalty = 1 + self.length/100 # on everything but UnderNET where it's # penalty = 2 + self.length/120 cmd, pars = self.split($;,2) debug "cmd: #{cmd}, pars: #{pars.inspect}" case cmd.to_sym when :KICK chan, nick, msg = pars.split chan = chan.split(',') nick = nick.split(',') penalty += nick.length penalty *= chan.length when :MODE chan, modes, argument = pars.split extra = 0 if modes extra = 1 if argument extra += modes.split(/\+|-/).length else extra += 3 * modes.split(/\+|-/).length end end if argument extra += 2 * argument.split.length end penalty += extra * chan.split.length when :TOPIC penalty += 1 penalty += 2 unless pars.split.length < 2 when :PRIVMSG, :NOTICE dests = pars.split($;,2).first penalty += dests.split(',').length when :WHO # I'm too lazy to implement this one correctly penalty += 5 when :AWAY, :JOIN, :VERSION, :TIME, :TRACE, :WHOIS, :DNS penalty += 2 when :INVITE, :NICK penalty += 3 when :ISON penalty += 1 else # Unknown messages penalty += 1 end if penalty > 99 debug "Wow, more than 99 secs of penalty!" penalty = 99 end if penalty < 2 debug "Wow, less than 2 secs of penalty!" penalty = 2 end debug "penalty: #{penalty}" return penalty end end module Irc # RFC 2812 Internet Relay Chat: Client Protocol # RPL_WELCOME=001 # "Welcome to the Internet Relay Network # !@" RPL_YOURHOST=002 # "Your host is , running version " RPL_CREATED=003 # "This server was created " RPL_MYINFO=004 # " # " # # - The server sends Replies 001 to 004 to a user upon # successful registration. # # RPL_BOUNCE=005 # # "Try server , port " RPL_ISUPPORT=005 # "005 nick PREFIX=(ov)@+ CHANTYPES=#& :are supported by this server" # # - Sent by the server to a user to suggest an alternative # server. This is often used when the connection is # refused because the server is already full. # RPL_USERHOST=302 # ":*1 *( " " )" # # - Reply format used by USERHOST to list replies to # the query list. The reply string is composed as # follows: # # reply = nickname [ "*" ] "=" ( "+" / "-" ) hostname # # The '*' indicates whether the client has registered # as an Operator. The '-' or '+' characters represent # whether the client has set an AWAY message or not # respectively. # RPL_ISON=303 # ":*1 *( " " )" # # - Reply format used by ISON to list replies to the # query list. # RPL_AWAY=301 # " :" RPL_UNAWAY=305 # ":You are no longer marked as being away" RPL_NOWAWAY=306 # ":You have been marked as being away" # # - These replies are used with the AWAY command (if # allowed). RPL_AWAY is sent to any client sending a # PRIVMSG to a client which is away. RPL_AWAY is only # sent by the server to which the client is connected. # Replies RPL_UNAWAY and RPL_NOWAWAY are sent when the # client removes and sets an AWAY message. # RPL_WHOISUSER=311 # " * :" RPL_WHOISSERVER=312 # " :" RPL_WHOISOPERATOR=313 # " :is an IRC operator" RPL_WHOISIDLE=317 # " :seconds idle" RPL_ENDOFWHOIS=318 # " :End of WHOIS list" RPL_WHOISCHANNELS=319 # " :*( ( "@" / "+" ) " " )" # # - Replies 311 - 313, 317 - 319 are all replies # generated in response to a WHOIS message. Given that # there are enough parameters present, the answering # server MUST either formulate a reply out of the above # numerics (if the query nick is found) or return an # error reply. The '*' in RPL_WHOISUSER is there as # the literal character and not as a wild card. For # each reply set, only RPL_WHOISCHANNELS may appear # more than once (for long lists of channel names). # The '@' and '+' characters next to the channel name # indicate whether a client is a channel operator or # has been granted permission to speak on a moderated # channel. The RPL_ENDOFWHOIS reply is used to mark # the end of processing a WHOIS message. # RPL_WHOWASUSER=314 # " * :" RPL_ENDOFWHOWAS=369 # " :End of WHOWAS" # # - When replying to a WHOWAS message, a server MUST use # the replies RPL_WHOWASUSER, RPL_WHOISSERVER or # ERR_WASNOSUCHNICK for each nickname in the presented # list. At the end of all reply batches, there MUST # be RPL_ENDOFWHOWAS (even if there was only one reply # and it was an error). # RPL_LISTSTART=321 # Obsolete. Not used. # RPL_LIST=322 # " <# visible> :" RPL_LISTEND=323 # ":End of LIST" # # - Replies RPL_LIST, RPL_LISTEND mark the actual replies # with data and end of the server's response to a LIST # command. If there are no channels available to return, # only the end reply MUST be sent. # RPL_UNIQOPIS=325 # " " # RPL_CHANNELMODEIS=324 # " " # RPL_NOTOPIC=331 # " :No topic is set" RPL_TOPIC=332 # " :" # # - When sending a TOPIC message to determine the # channel topic, one of two replies is sent. If # the topic is set, RPL_TOPIC is sent back else # RPL_NOTOPIC. # RPL_TOPIC_INFO=333 # RPL_INVITING=341 # " " # # - Returned by the server to indicate that the # attempted INVITE message was successful and is # being passed onto the end client. # RPL_SUMMONING=342 # " :Summoning user to IRC" # # - Returned by a server answering a SUMMON message to # indicate that it is summoning that user. # RPL_INVITELIST=346 # " " RPL_ENDOFINVITELIST=347 # " :End of channel invite list" # # - When listing the 'invitations masks' for a given channel, # a server is required to send the list back using the # RPL_INVITELIST and RPL_ENDOFINVITELIST messages. A # separate RPL_INVITELIST is sent for each active mask. # After the masks have been listed (or if none present) a # RPL_ENDOFINVITELIST MUST be sent. # RPL_EXCEPTLIST=348 # " " RPL_ENDOFEXCEPTLIST=349 # " :End of channel exception list" # # - When listing the 'exception masks' for a given channel, # a server is required to send the list back using the # RPL_EXCEPTLIST and RPL_ENDOFEXCEPTLIST messages. A # separate RPL_EXCEPTLIST is sent for each active mask. # After the masks have been listed (or if none present) # a RPL_ENDOFEXCEPTLIST MUST be sent. # RPL_VERSION=351 # ". :" # # - Reply by the server showing its version details. # The is the version of the software being # used (including any patchlevel revisions) and the # is used to indicate if the server is # running in "debug mode". # # The "comments" field may contain any comments about # the version or further version details. # RPL_WHOREPLY=352 # " # ( "H" / "G" > ["*"] [ ( "@" / "+" ) ] # : " # RPL_ENDOFWHO=315 # " :End of WHO list" # # - The RPL_WHOREPLY and RPL_ENDOFWHO pair are used # to answer a WHO message. The RPL_WHOREPLY is only # sent if there is an appropriate match to the WHO # query. If there is a list of parameters supplied # with a WHO message, a RPL_ENDOFWHO MUST be sent # after processing each list item with being # the item. # RPL_NAMREPLY=353 # "( "=" / "*" / "@" ) # :[ "@" / "+" ] *( " " [ "@" / "+" ] ) # - "@" is used for secret channels, "*" for private # channels, and "=" for others (public channels). # RPL_ENDOFNAMES=366 # " :End of NAMES list" # # - To reply to a NAMES message, a reply pair consisting # of RPL_NAMREPLY and RPL_ENDOFNAMES is sent by the # server back to the client. If there is no channel # found as in the query, then only RPL_ENDOFNAMES is # returned. The exception to this is when a NAMES # message is sent with no parameters and all visible # channels and contents are sent back in a series of # RPL_NAMEREPLY messages with a RPL_ENDOFNAMES to mark # the end. # RPL_LINKS=364 # " : " RPL_ENDOFLINKS=365 # " :End of LINKS list" # # - In replying to the LINKS message, a server MUST send # replies back using the RPL_LINKS numeric and mark the # end of the list using an RPL_ENDOFLINKS reply. # RPL_BANLIST=367 # " " RPL_ENDOFBANLIST=368 # " :End of channel ban list" # # - When listing the active 'bans' for a given channel, # a server is required to send the list back using the # RPL_BANLIST and RPL_ENDOFBANLIST messages. A separate # RPL_BANLIST is sent for each active banmask. After the # banmasks have been listed (or if none present) a # RPL_ENDOFBANLIST MUST be sent. # RPL_INFO=371 # ":" RPL_ENDOFINFO=374 # ":End of INFO list" # # - A server responding to an INFO message is required to # send all its 'info' in a series of RPL_INFO messages # with a RPL_ENDOFINFO reply to indicate the end of the # replies. # RPL_MOTDSTART=375 # ":- Message of the day - " RPL_MOTD=372 # ":- " RPL_ENDOFMOTD=376 # ":End of MOTD command" # # - When responding to the MOTD message and the MOTD file # is found, the file is displayed line by line, with # each line no longer than 80 characters, using # RPL_MOTD format replies. These MUST be surrounded # by a RPL_MOTDSTART (before the RPL_MOTDs) and an # RPL_ENDOFMOTD (after). # RPL_YOUREOPER=381 # ":You are now an IRC operator" # # - RPL_YOUREOPER is sent back to a client which has # just successfully issued an OPER message and gained # operator status. # RPL_REHASHING=382 # " :Rehashing" # # - If the REHASH option is used and an operator sends # a REHASH message, an RPL_REHASHING is sent back to # the operator. # RPL_YOURESERVICE=383 # "You are service " # # - Sent by the server to a service upon successful # registration. # RPL_TIME=391 # " :" # # - When replying to the TIME message, a server MUST send # the reply using the RPL_TIME format above. The string # showing the time need only contain the correct day and # time there. There is no further requirement for the # time string. # RPL_USERSSTART=392 # ":UserID Terminal Host" RPL_USERS=393 # ": " RPL_ENDOFUSERS=394 # ":End of users" RPL_NOUSERS=395 # ":Nobody logged in" # # - If the USERS message is handled by a server, the # replies RPL_USERSTART, RPL_USERS, RPL_ENDOFUSERS and # RPL_NOUSERS are used. RPL_USERSSTART MUST be sent # first, following by either a sequence of RPL_USERS # or a single RPL_NOUSER. Following this is # RPL_ENDOFUSERS. # RPL_TRACELINK=200 # "Link # V # # " RPL_TRACECONNECTING=201 # "Try. " RPL_TRACEHANDSHAKE=202 # "H.S. " RPL_TRACEUNKNOWN=203 # "???? []" RPL_TRACEOPERATOR=204 # "Oper " RPL_TRACEUSER=205 # "User " RPL_TRACESERVER=206 # "Serv S C # @ V" RPL_TRACESERVICE=207 # "Service " RPL_TRACENEWTYPE=208 # " 0 " RPL_TRACECLASS=209 # "Class " RPL_TRACERECONNECT=210 # Unused. RPL_TRACELOG=261 # "File " RPL_TRACEEND=262 # " :End of TRACE" # # - The RPL_TRACE* are all returned by the server in # response to the TRACE message. How many are # returned is dependent on the TRACE message and # whether it was sent by an operator or not. There # is no predefined order for which occurs first. # Replies RPL_TRACEUNKNOWN, RPL_TRACECONNECTING and # RPL_TRACEHANDSHAKE are all used for connections # which have not been fully established and are either # unknown, still attempting to connect or in the # process of completing the 'server handshake'. # RPL_TRACELINK is sent by any server which handles # a TRACE message and has to pass it on to another # server. The list of RPL_TRACELINKs sent in # response to a TRACE command traversing the IRC # network should reflect the actual connectivity of # the servers themselves along that path. # # RPL_TRACENEWTYPE is to be used for any connection # which does not fit in the other categories but is # being displayed anyway. # RPL_TRACEEND is sent to indicate the end of the list. # RPL_LOCALUSERS=265 # ":Current local users: 3 Max: 4" RPL_GLOBALUSERS=266 # ":Current global users: 3 Max: 4" RPL_STATSCONN=250 # "::Highest connection count: 4 (4 clients) (251 since server was # (re)started)" RPL_STATSLINKINFO=211 # " # #