summaryrefslogtreecommitdiff
path: root/lib/rbot
diff options
context:
space:
mode:
Diffstat (limited to 'lib/rbot')
-rw-r--r--lib/rbot/channel.rb10
-rw-r--r--lib/rbot/rfc2812.rb390
2 files changed, 200 insertions, 200 deletions
diff --git a/lib/rbot/channel.rb b/lib/rbot/channel.rb
index edd206bf..34804c19 100644
--- a/lib/rbot/channel.rb
+++ b/lib/rbot/channel.rb
@@ -4,23 +4,23 @@ module Irc
class IRCChannel
# name of channel
attr_reader :name
-
+
# current channel topic
attr_reader :topic
-
+
# hash containing users currently in the channel
attr_accessor :users
-
+
# if true, bot won't talk in this channel
attr_accessor :quiet
-
+
# name:: channel name
# create a new IRCChannel
def initialize(name)
@name = name
@users = Hash.new
@quiet = false
- @topic = Topic.new
+ @topic = Topic.new
end
# eg @bot.channels[chan].topic = topic
diff --git a/lib/rbot/rfc2812.rb b/lib/rbot/rfc2812.rb
index 4b19d586..8dc2016c 100644
--- a/lib/rbot/rfc2812.rb
+++ b/lib/rbot/rfc2812.rb
@@ -1,6 +1,6 @@
module Irc
# RFC 2812 Internet Relay Chat: Client Protocol
- #
+ #
RPL_WELCOME=001
# "Welcome to the Internet Relay Network
# <nick>!<user>@<host>"
@@ -11,53 +11,53 @@ module Irc
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>"
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> *( " " <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
@@ -70,7 +70,7 @@ module Irc
# "<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
@@ -85,107 +85,107 @@ module Irc
# 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
@@ -193,16 +193,16 @@ module Irc
# 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
@@ -212,81 +212,81 @@ module Irc
# 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
@@ -295,14 +295,14 @@ module Irc
# ":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>
@@ -333,7 +333,7 @@ module Irc
# "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
@@ -350,12 +350,12 @@ module Irc
# 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
@@ -367,7 +367,7 @@ module Irc
# "<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
@@ -378,45 +378,45 @@ module Irc
# 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"
@@ -429,7 +429,7 @@ module Irc
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,
@@ -438,7 +438,7 @@ module Irc
# 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
@@ -447,7 +447,7 @@ module Irc
# ":<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
@@ -458,82 +458,82 @@ module Irc
# 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
@@ -544,161 +544,161 @@ module Irc
# "<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
@@ -717,99 +717,99 @@ module Irc
# "<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_SERVICEINFO=231
RPL_ENDOFSERVICES=232
RPL_SERVICE=233
- RPL_NONE=300
+ RPL_NONE=300
RPL_WHOISCHANOP=316
- RPL_KILLDONE=361
+ RPL_KILLDONE=361
RPL_CLOSING=362
- RPL_CLOSEEND=363
+ RPL_CLOSEEND=363
RPL_INFOSTART=373
RPL_MYPORTIS=384
- RPL_STATSCLINE=213
+ RPL_STATSCLINE=213
RPL_STATSNLINE=214
- RPL_STATSILINE=215
+ RPL_STATSILINE=215
RPL_STATSKLINE=216
RPL_STATSQLINE=217
RPL_STATSYLINE=218
- RPL_STATSVLINE=240
+ RPL_STATSVLINE=240
RPL_STATSLLINE=241
- RPL_STATSHLINE=244
+ RPL_STATSHLINE=244
RPL_STATSSLINE=244
- RPL_STATSPING=246
+ RPL_STATSPING=246
RPL_STATSBLINE=247
ERR_NOSERVICEHOST=492
-
+
# implements RFC 2812 and prior IRC RFCs.
# clients register handler proc{}s for different server events and IrcClient
# handles dispatch
@@ -819,7 +819,7 @@ module Irc
@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
@@ -854,26 +854,26 @@ module Irc
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}"
+ raise "Unparseable Server Message!!!: #{serverstring}"
end
-
+
prefix, command, params = $2, $3, $5
-
+
if prefix != nil
data[:source] = prefix
if prefix =~ /^(\S+)!(\S+)$/
@@ -885,7 +885,7 @@ module Irc
# split parameters in an array
argv = []
params.scan(/(?!:)(\S+)|:(.*)/) { argv << ($1 || $2) } if params
-
+
case command
when 'PING'
data[:pingid] = argv[0]
@@ -955,7 +955,7 @@ module Irc
# TOPICLEN=450 KICKLEN=450 CHANNELLEN=30 KEYLEN=23 CHANTYPES=#
# PREFIX=(ov)@+ CASEMAPPING=ascii CAPAB IRCD=dancer :are available
# on this server"
- #
+ #
argv.each {|a|
if a =~ /^(.*)=(.*)$/
data[$1.downcase.to_sym] = $2
@@ -1041,7 +1041,7 @@ module Irc
data[:target] = argv[0]
data[:message] = argv[1]
handle(:privmsg, data)
-
+
# Now we split it
if(data[:target] =~ /^[#&!+].*/)
handle(:public, data)
@@ -1094,7 +1094,7 @@ module Irc
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