diff options
Diffstat (limited to 'rbot/rfc2812.rb')
-rw-r--r-- | rbot/rfc2812.rb | 1027 |
1 files changed, 0 insertions, 1027 deletions
diff --git a/rbot/rfc2812.rb b/rbot/rfc2812.rb deleted file mode 100644 index 6f459c80..00000000 --- a/rbot/rfc2812.rb +++ /dev/null @@ -1,1027 +0,0 @@ -module Irc - # RFC 2812 Internet Relay Chat: Client Protocol - # - RPL_WELCOME=001 - # "Welcome to the Internet Relay Network - # <nick>!<user>@<host>" - RPL_YOURHOST=002 - # "Your host is <servername>, running version <ver>" - RPL_CREATED=003 - # "This server was created <date>" - RPL_MYINFO=004 - # "<servername> <version> <available user modes> - # <available channel modes>" - # - # - The server sends Replies 001 to 004 to a user upon - # successful registration. - # - RPL_BOUNCE=005 - # "Try server <server name>, port <port number>" - # - # - 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> *( " " <reply> )" - # - # - 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<nick> *( " " <nick> )" - # - # - Reply format used by ISON to list replies to the - # query list. - # - RPL_AWAY=301 - # "<nick> :<away message>" - 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 - # "<nick> <user> <host> * :<real name>" - RPL_WHOISSERVER=312 - # "<nick> <server> :<server info>" - RPL_WHOISOPERATOR=313 - # "<nick> :is an IRC operator" - RPL_WHOISIDLE=317 - # "<nick> <integer> :seconds idle" - RPL_ENDOFWHOIS=318 - # "<nick> :End of WHOIS list" - RPL_WHOISCHANNELS=319 - # "<nick> :*( ( "@" / "+" ) <channel> " " )" - # - # - 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 - # "<nick> <user> <host> * :<real name>" - RPL_ENDOFWHOWAS=369 - # "<nick> :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 - # "<channel> <# visible> :<topic>" - 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 - # "<channel> <nickname>" - # - RPL_CHANNELMODEIS=324 - # "<channel> <mode> <mode params>" - # - RPL_NOTOPIC=331 - # "<channel> :No topic is set" - RPL_TOPIC=332 - # "<channel> :<topic>" - # - # - 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 - # <channel> <set by> <unixtime> - RPL_INVITING=341 - # "<channel> <nick>" - # - # - Returned by the server to indicate that the - # attempted INVITE message was successful and is - # being passed onto the end client. - # - RPL_SUMMONING=342 - # "<user> :Summoning user to IRC" - # - # - Returned by a server answering a SUMMON message to - # indicate that it is summoning that user. - # - RPL_INVITELIST=346 - # "<channel> <invitemask>" - RPL_ENDOFINVITELIST=347 - # "<channel> :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 - # "<channel> <exceptionmask>" - RPL_ENDOFEXCEPTLIST=349 - # "<channel> :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 - # "<version>.<debuglevel> <server> :<comments>" - # - # - Reply by the server showing its version details. - # The <version> is the version of the software being - # used (including any patchlevel revisions) and the - # <debuglevel> 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 - # "<channel> <user> <host> <server> <nick> - # ( "H" / "G" > ["*"] [ ( "@" / "+" ) ] - # :<hopcount> <real name>" - # - RPL_ENDOFWHO=315 - # "<name> :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 <name> being - # the item. - # - RPL_NAMREPLY=353 - # "( "=" / "*" / "@" ) <channel> - # :[ "@" / "+" ] <nick> *( " " [ "@" / "+" ] <nick> ) - # - "@" is used for secret channels, "*" for private - # channels, and "=" for others (public channels). - # - RPL_ENDOFNAMES=366 - # "<channel> :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 - # "<mask> <server> :<hopcount> <server info>" - RPL_ENDOFLINKS=365 - # "<mask> :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 - # "<channel> <banmask>" - RPL_ENDOFBANLIST=368 - # "<channel> :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 - # ":<string>" - 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 - # ":- <server> Message of the day - " - RPL_MOTD=372 - # ":- <text>" - 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 - # "<config file> :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 <servicename>" - # - # - Sent by the server to a service upon successful - # registration. - # - RPL_TIME=391 - # "<server> :<string showing server's local time>" - # - # - 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 - # ":<username> <ttyline> <hostname>" - 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 <version & debug level> <destination> - # <next server> V<protocol version> - # <link uptime in seconds> <backstream sendq> - # <upstream sendq>" - RPL_TRACECONNECTING=201 - # "Try. <class> <server>" - RPL_TRACEHANDSHAKE=202 - # "H.S. <class> <server>" - RPL_TRACEUNKNOWN=203 - # "???? <class> [<client IP address in dot form>]" - RPL_TRACEOPERATOR=204 - # "Oper <class> <nick>" - RPL_TRACEUSER=205 - # "User <class> <nick>" - RPL_TRACESERVER=206 - # "Serv <class> <int>S <int>C <server> - # <nick!user|*!*>@<host|server> V<protocol version>" - RPL_TRACESERVICE=207 - # "Service <class> <name> <type> <active type>" - RPL_TRACENEWTYPE=208 - # "<newtype> 0 <client name>" - RPL_TRACECLASS=209 - # "Class <class> <count>" - RPL_TRACERECONNECT=210 - # Unused. - RPL_TRACELOG=261 - # "File <logfile> <debug level>" - RPL_TRACEEND=262 - # "<server name> <version & debug level> :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_STATSLINKINFO=211 - # "<linkname> <sendq> <sent messages> - # <sent Kbytes> <received messages> - # <received Kbytes> <time open>" - # - # - reports statistics on a connection. <linkname> - # identifies the particular connection, <sendq> is - # the amount of data that is queued and waiting to be - # sent <sent messages> the number of messages sent, - # and <sent Kbytes> the amount of data sent, in - # Kbytes. <received messages> and <received Kbytes> - # are the equivalent of <sent messages> and <sent - # Kbytes> for received data, respectively. <time - # open> indicates how long ago the connection was - # opened, in seconds. - # - RPL_STATSCOMMANDS=212 - # "<command> <count> <byte count> <remote count>" - # - # - reports statistics on commands usage. - # - RPL_ENDOFSTATS=219 - # "<stats letter> :End of STATS report" - # - RPL_STATSUPTIME=242 - # ":Server Up %d days %d:%02d:%02d" - # - # - reports the server uptime. - # - RPL_STATSOLINE=243 - # "O <hostmask> * <name>" - # - # - reports the allowed hosts from where user may become IRC - # operators. - # - RPL_UMODEIS=221 - # "<user mode string>" - # - # - To answer a query about a client's own mode, - # RPL_UMODEIS is sent back. - # - RPL_SERVLIST=234 - # "<name> <server> <mask> <type> <hopcount> <info>" - # - RPL_SERVLISTEND=235 - # "<mask> <type> :End of service listing" - # - # - When listing services in reply to a SERVLIST message, - # a server is required to send the list back using the - # RPL_SERVLIST and RPL_SERVLISTEND messages. A separate - # RPL_SERVLIST is sent for each service. After the - # services have been listed (or if none present) a - # RPL_SERVLISTEND MUST be sent. - # - RPL_LUSERCLIENT=251 - # ":There are <integer> users and <integer> - # services on <integer> servers" - RPL_LUSEROP=252 - # "<integer> :operator(s) online" - RPL_LUSERUNKNOWN=253 - # "<integer> :unknown connection(s)" - RPL_LUSERCHANNELS=254 - # "<integer> :channels formed" - RPL_LUSERME=255 - # ":I have <integer> clients and <integer> - # servers" - # - # - In processing an LUSERS message, the server - # sends a set of replies from RPL_LUSERCLIENT, - # RPL_LUSEROP, RPL_USERUNKNOWN, - # RPL_LUSERCHANNELS and RPL_LUSERME. When - # replying, a server MUST send back - # RPL_LUSERCLIENT and RPL_LUSERME. The other - # replies are only sent back if a non-zero count - # is found for them. - # - RPL_ADMINME=256 - # "<server> :Administrative info" - RPL_ADMINLOC1=257 - # ":<admin info>" - RPL_ADMINLOC2=258 - # ":<admin info>" - RPL_ADMINEMAIL=259 - # ":<admin info>" - # - # - When replying to an ADMIN message, a server - # is expected to use replies RPL_ADMINME - # through to RPL_ADMINEMAIL and provide a text - # message with each. For RPL_ADMINLOC1 a - # description of what city, state and country - # the server is in is expected, followed by - # details of the institution (RPL_ADMINLOC2) - # and finally the administrative contact for the - # server (an email address here is REQUIRED) - # in RPL_ADMINEMAIL. - # - RPL_TRYAGAIN=263 - # "<command> :Please wait a while and try again." - # - # - When a server drops a command without processing it, - # it MUST use the reply RPL_TRYAGAIN to inform the - # originating client. - # - # 5.2 Error Replies - # - # Error replies are found in the range from 400 to 599. - # - ERR_NOSUCHNICK=401 - # "<nickname> :No such nick/channel" - # - # - Used to indicate the nickname parameter supplied to a - # command is currently unused. - # - ERR_NOSUCHSERVER=402 - # "<server name> :No such server" - # - # - Used to indicate the server name given currently - # does not exist. - # - ERR_NOSUCHCHANNEL=403 - # "<channel name> :No such channel" - # - # - Used to indicate the given channel name is invalid. - # - ERR_CANNOTSENDTOCHAN=404 - # "<channel name> :Cannot send to channel" - # - # - Sent to a user who is either (a) not on a channel - # which is mode +n or (b) not a chanop (or mode +v) on - # a channel which has mode +m set or where the user is - # banned and is trying to send a PRIVMSG message to - # that channel. - # - ERR_TOOMANYCHANNELS=405 - # "<channel name> :You have joined too many channels" - # - # - Sent to a user when they have joined the maximum - # number of allowed channels and they try to join - # another channel. - # - ERR_WASNOSUCHNICK=406 - # "<nickname> :There was no such nickname" - # - # - Returned by WHOWAS to indicate there is no history - # information for that nickname. - # - ERR_TOOMANYTARGETS=407 - # "<target> :<error code> recipients. <abort message>" - # - # - Returned to a client which is attempting to send a - # PRIVMSG/NOTICE using the user@host destination format - # and for a user@host which has several occurrences. - # - # - Returned to a client which trying to send a - # PRIVMSG/NOTICE to too many recipients. - # - # - Returned to a client which is attempting to JOIN a safe - # channel using the shortname when there are more than one - # such channel. - # - ERR_NOSUCHSERVICE=408 - # "<service name> :No such service" - # - # - Returned to a client which is attempting to send a SQUERY - # to a service which does not exist. - # - ERR_NOORIGIN=409 - # ":No origin specified" - # - # - PING or PONG message missing the originator parameter. - # - ERR_NORECIPIENT=411 - # ":No recipient given (<command>)" - ERR_NOTEXTTOSEND=412 - # ":No text to send" - ERR_NOTOPLEVEL=413 - # "<mask> :No toplevel domain specified" - ERR_WILDTOPLEVEL=414 - # "<mask> :Wildcard in toplevel domain" - ERR_BADMASK=415 - # "<mask> :Bad Server/host mask" - # - # - 412 - 415 are returned by PRIVMSG to indicate that - # the message wasn't delivered for some reason. - # ERR_NOTOPLEVEL and ERR_WILDTOPLEVEL are errors that - # are returned when an invalid use of - # "PRIVMSG $<server>" or "PRIVMSG #<host>" is attempted. - # - ERR_UNKNOWNCOMMAND=421 - # "<command> :Unknown command" - # - # - Returned to a registered client to indicate that the - # command sent is unknown by the server. - # - ERR_NOMOTD=422 - # ":MOTD File is missing" - # - # - Server's MOTD file could not be opened by the server. - # - ERR_NOADMININFO=423 - # "<server> :No administrative info available" - # - # - Returned by a server in response to an ADMIN message - # when there is an error in finding the appropriate - # information. - # - ERR_FILEERROR=424 - # ":File error doing <file op> on <file>" - # - # - Generic error message used to report a failed file - # operation during the processing of a message. - # - ERR_NONICKNAMEGIVEN=431 - # ":No nickname given" - # - # - Returned when a nickname parameter expected for a - # command and isn't found. - # - ERR_ERRONEUSNICKNAME=432 - # "<nick> :Erroneous nickname" - # - # - Returned after receiving a NICK message which contains - # characters which do not fall in the defined set. See - # section 2.3.1 for details on valid nicknames. - # - ERR_NICKNAMEINUSE=433 - # "<nick> :Nickname is already in use" - # - # - Returned when a NICK message is processed that results - # in an attempt to change to a currently existing - # nickname. - # - ERR_NICKCOLLISION=436 - # "<nick> :Nickname collision KILL from <user>@<host>" - # - # - Returned by a server to a client when it detects a - # nickname collision (registered of a NICK that - # already exists by another server). - # - ERR_UNAVAILRESOURCE=437 - # "<nick/channel> :Nick/channel is temporarily unavailable" - # - # - Returned by a server to a user trying to join a channel - # currently blocked by the channel delay mechanism. - # - # - Returned by a server to a user trying to change nickname - # when the desired nickname is blocked by the nick delay - # mechanism. - # - ERR_USERNOTINCHANNEL=441 - # "<nick> <channel> :They aren't on that channel" - # - # - Returned by the server to indicate that the target - # user of the command is not on the given channel. - # - ERR_NOTONCHANNEL=442 - # "<channel> :You're not on that channel" - # - # - Returned by the server whenever a client tries to - # perform a channel affecting command for which the - # client isn't a member. - # - ERR_USERONCHANNEL=443 - # "<user> <channel> :is already on channel" - # - # - Returned when a client tries to invite a user to a - # channel they are already on. - # - ERR_NOLOGIN=444 - # "<user> :User not logged in" - # - # - Returned by the summon after a SUMMON command for a - # user was unable to be performed since they were not - # logged in. - # - # - ERR_SUMMONDISABLED=445 - # ":SUMMON has been disabled" - # - # - Returned as a response to the SUMMON command. MUST be - # returned by any server which doesn't implement it. - # - ERR_USERSDISABLED=446 - # ":USERS has been disabled" - # - # - Returned as a response to the USERS command. MUST be - # returned by any server which does not implement it. - # - ERR_NOTREGISTERED=451 - # ":You have not registered" - # - # - Returned by the server to indicate that the client - # MUST be registered before the server will allow it - # to be parsed in detail. - # - ERR_NEEDMOREPARAMS=461 - # "<command> :Not enough parameters" - # - # - Returned by the server by numerous commands to - # indicate to the client that it didn't supply enough - # parameters. - # - ERR_ALREADYREGISTRED=462 - # ":Unauthorized command (already registered)" - # - # - Returned by the server to any link which tries to - # change part of the registered details (such as - # password or user details from second USER message). - # - ERR_NOPERMFORHOST=463 - # ":Your host isn't among the privileged" - # - # - Returned to a client which attempts to register with - # a server which does not been setup to allow - # connections from the host the attempted connection - # is tried. - # - ERR_PASSWDMISMATCH=464 - # ":Password incorrect" - # - # - Returned to indicate a failed attempt at registering - # a connection for which a password was required and - # was either not given or incorrect. - # - ERR_YOUREBANNEDCREEP=465 - # ":You are banned from this server" - # - # - Returned after an attempt to connect and register - # yourself with a server which has been setup to - # explicitly deny connections to you. - # - ERR_YOUWILLBEBANNED=466 - # - # - Sent by a server to a user to inform that access to the - # server will soon be denied. - # - ERR_KEYSET=467 - # "<channel> :Channel key already set" - ERR_CHANNELISFULL=471 - # "<channel> :Cannot join channel (+l)" - ERR_UNKNOWNMODE=472 - # "<char> :is unknown mode char to me for <channel>" - ERR_INVITEONLYCHAN=473 - # "<channel> :Cannot join channel (+i)" - ERR_BANNEDFROMCHAN=474 - # "<channel> :Cannot join channel (+b)" - ERR_BADCHANNELKEY=475 - # "<channel> :Cannot join channel (+k)" - ERR_BADCHANMASK=476 - # "<channel> :Bad Channel Mask" - ERR_NOCHANMODES=477 - # "<channel> :Channel doesn't support modes" - ERR_BANLISTFULL=478 - # "<channel> <char> :Channel list is full" - # - ERR_NOPRIVILEGES=481 - # ":Permission Denied- You're not an IRC operator" - # - # - Any command requiring operator privileges to operate - # MUST return this error to indicate the attempt was - # unsuccessful. - # - ERR_CHANOPRIVSNEEDED=482 - # "<channel> :You're not channel operator" - # - # - Any command requiring 'chanop' privileges (such as - # MODE messages) MUST return this error if the client - # making the attempt is not a chanop on the specified - # channel. - # - # - ERR_CANTKILLSERVER=483 - # ":You can't kill a server!" - # - # - Any attempts to use the KILL command on a server - # are to be refused and this error returned directly - # to the client. - # - ERR_RESTRICTED=484 - # ":Your connection is restricted!" - # - # - Sent by the server to a user upon connection to indicate - # the restricted nature of the connection (user mode "+r"). - # - ERR_UNIQOPPRIVSNEEDED=485 - # ":You're not the original channel operator" - # - # - Any MODE requiring "channel creator" privileges MUST - # return this error if the client making the attempt is not - # a chanop on the specified channel. - # - ERR_NOOPERHOST=491 - # ":No O-lines for your host" - # - # - If a client sends an OPER message and the server has - # not been configured to allow connections from the - # client's host as an operator, this error MUST be - # returned. - # - ERR_UMODEUNKNOWNFLAG=501 - # ":Unknown MODE flag" - # - # - Returned by the server to indicate that a MODE - # message was sent with a nickname parameter and that - # the a mode flag sent was not recognized. - # - ERR_USERSDONTMATCH=502 - # ":Cannot change mode for other users" - # - # - Error sent to any user trying to view or change the - # user mode for a user other than themselves. - # - # 5.3 Reserved numerics - # - # These numerics are not described above since they fall into one of - # the following categories: - # - # 1. no longer in use; - # - # 2. reserved for future planned use; - # - # 3. in current use but are part of a non-generic 'feature' of - # the current IRC server. - RPL_SERVICEINFO=231 - RPL_ENDOFSERVICES=232 - RPL_SERVICE=233 - RPL_NONE=300 - RPL_WHOISCHANOP=316 - RPL_KILLDONE=361 - RPL_CLOSING=362 - RPL_CLOSEEND=363 - RPL_INFOSTART=373 - RPL_MYPORTIS=384 - RPL_STATSCLINE=213 - RPL_STATSNLINE=214 - RPL_STATSILINE=215 - RPL_STATSKLINE=216 - RPL_STATSQLINE=217 - RPL_STATSYLINE=218 - RPL_STATSVLINE=240 - RPL_STATSLLINE=241 - RPL_STATSHLINE=244 - RPL_STATSSLINE=244 - RPL_STATSPING=246 - RPL_STATSBLINE=247 - RPL_STATSDLINE=250 - ERR_NOSERVICEHOST=492 - - # implements RFC 2812 and prior IRC RFCs. - # clients register handler proc{}s for different server events and IrcClient - # handles dispatch - class IrcClient - # create a new IrcClient instance - def initialize - @handlers = Hash.new - @users = Array.new - end - - # key:: server event to handle - # value:: proc object called when event occurs - # set a handler for a server event - # - # ==server events currently supported: - # - # PING:: server pings you (default handler returns a pong) - # NICKTAKEN:: you tried to change nick to one that's in use - # BADNICK:: you tried to change nick to one that's invalid - # TOPIC:: someone changed the topic of a channel - # TOPICINFO:: on joining a channel or asking for the topic, tells you - # who set it and when - # NAMES:: server sends list of channel members when you join - # WELCOME:: server welcome message on connect - # MOTD:: server message of the day - # PRIVMSG:: privmsg, the core of IRC, a message to you from someone - # PUBLIC:: optionally instead of getting privmsg you can hook to only - # the public ones... - # MSG:: or only the private ones, or both - # KICK:: someone got kicked from a channel - # PART:: someone left a channel - # QUIT:: someone quit IRC - # JOIN:: someone joined a channel - # CHANGETOPIC:: the topic of a channel changed - # INVITE:: you are invited to a channel - # NICK:: someone changed their nick - # MODE:: a mode change - # NOTICE:: someone sends you a notice - # UNKNOWN:: any other message not handled by the above - def []=(key, value) - @handlers[key] = value - end - - # key:: event name - # remove a handler for a server event - def deletehandler(key) - @handlers.delete(key) - end - - # takes a server string, checks for PING, PRIVMSG, NOTIFY, etc, and parses - # numeric server replies, calling the appropriate handler for each, and - # sending it a hash containing the data from the server - def process(serverstring) - data = Hash.new - data["SERVERSTRING"] = serverstring - - unless serverstring =~ /^(:(\S+)\s)?(\S+)(\s(.*))?/ - raise "Unparseable Server Message!!!: #{serverstring}" - end - - prefix, command, params = $2, $3, $5 - - if prefix != nil - data['SOURCE'] = prefix - if prefix =~ /^(\S+)!(\S+)$/ - data['SOURCENICK'] = $1 - data['SOURCEADDRESS'] = $2 - end - end - - # split parameters in an array - argv = [] - params.scan(/(?!:)(\S+)|:(.*)/) { argv << ($1 || $2) } if params - - case command - when 'PING' - data['PINGID'] = argv[0] - handle('PING', data) - when /^(\d+)$/ # numeric server message - num=command.to_i - case num - when ERR_NICKNAMEINUSE - # "* <nick> :Nickname is already in use" - data['NICK'] = argv[1] - data['MESSAGE'] = argv[2] - handle('NICKTAKEN', data) - when ERR_ERRONEUSNICKNAME - # "* <nick> :Erroneous nickname" - data['NICK'] = argv[1] - data['MESSAGE'] = argv[2] - handle('BADNICK', data) - when RPL_TOPIC - data['CHANNEL'] = argv[1] - data['TOPIC'] = argv[2] - handle('TOPIC', data) - when RPL_TOPIC_INFO - data['NICK'] = argv[0] - data['CHANNEL'] = argv[1] - data['SOURCE'] = argv[2] - data['UNIXTIME'] = argv[3] - handle('TOPICINFO', data) - when RPL_NAMREPLY - # "( "=" / "*" / "@" ) <channel> - # :[ "@" / "+" ] <nick> *( " " [ "@" / "+" ] <nick> ) - # - "@" is used for secret channels, "*" for private - # channels, and "=" for others (public channels). - argv[3].scan(/\S+/).each { |u| - if(u =~ /^([@+])?(.*)$/) - umode = $1 || "" - user = $2 - @users << [user, umode] - end - } - when RPL_ENDOFNAMES - data['CHANNEL'] = argv[1] - data['USERS'] = @users - handle('NAMES', data) - @users = Array.new - when RPL_WELCOME - # "Welcome to the Internet Relay Network - # <nick>!<user>@<host>" - case argv[1] - when /((\S+)!(\S+))/ - data['NETMASK'] = $1 - data['NICK'] = $2 - data['ADDRESS'] = $3 - when /Welcome to the Internet Relay Network\s(\S+)/ - data['NICK'] = $1 - when /Welcome.*\s+(\S+)$/ - data['NICK'] = $1 - when /^(\S+)$/ - data['NICK'] = $1 - end - handle('WELCOME', data) - when RPL_MOTDSTART - # "<nick> :- <server> Message of the Day -" - if argv[1] =~ /^-\s+(\S+)\s/ - server = $1 - @motd = "" - end - when RPL_MOTD - if(argv[1] =~ /^-\s+(.*)$/) - @motd << $1 - @motd << "\n" - end - when RPL_ENDOFMOTD - data['MOTD'] = @motd - handle('MOTD', data) - else - handle('UNKNOWN', data) - end - # end of numeric replies - when 'PRIVMSG' - # you can either bind to 'PRIVMSG', to get every one and - # parse it yourself, or you can bind to 'MSG', 'PUBLIC', - # etc and get it all nicely split up for you. - data['TARGET'] = argv[0] - data['MESSAGE'] = argv[1] - handle('PRIVMSG', data) - - # Now we split it - if(data['TARGET'] =~ /^(#|&).*/) - handle('PUBLIC', data) - else - handle('MSG', data) - end - when 'KICK' - data['CHANNEL'] = argv[0] - data['TARGET'] = argv[1] - data['MESSAGE'] = argv[2] - handle('KICK', data) - when 'PART' - data['CHANNEL'] = argv[0] - data['MESSAGE'] = argv[1] - handle('PART', data) - when 'QUIT' - data['MESSAGE'] = argv[0] - handle('QUIT', data) - when 'JOIN' - data['CHANNEL'] = argv[0] - handle('JOIN', data) - when 'TOPIC' - data['CHANNEL'] = argv[0] - data['TOPIC'] = argv[1] - handle('CHANGETOPIC', data) - when 'INVITE' - data['TARGET'] = argv[0] - data['CHANNEL'] = argv[1] - handle('INVITE', data) - when 'NICK' - data['NICK'] = argv[0] - handle('NICK', data) - when 'MODE' - data['CHANNEL'] = argv[0] - data['MODESTRING'] = argv[1] - data['TARGETS'] = argv[2] - handle('MODE', data) - when 'NOTICE' - data['TARGET'] = argv[0] - data['MESSAGE'] = argv[1] - if data['SOURCENICK'] - handle('NOTICE', data) - else - # "server notice" (not from user, noone to reply to - handle('SNOTICE', data) - end - else - handle('UNKNOWN', data) - end - end - - private - - # key:: server event name - # data:: hash containing data about the event, passed to the proc - # call client's proc for an event, if they set one as a handler - def handle(key, data) - if(@handlers.has_key?(key)) - @handlers[key].call(data) - end - end - end -end |