- if not self.conn.registered() and pieces[0] == "NOTICE":
- self.conn.register()
-
- elif pieces[1] == "001":
- self.conn.registered(True)
- for c in self.chans:
- self.join(c.name)
-
- elif pieces[1] == "PRIVMSG":
- nick = pieces[0].split('!')[0][1:]
- user = self.parent.user(nick)
- target = pieces[2]
- msg = ' '.join(pieces[3:])[1:]
- self.parsemsg(user, target, msg)
-
- elif pieces[0] == "PING":
- self.conn.send("PONG %s" % (pieces[1]))
-
- elif pieces[1] == "354": # WHOX
- qt = pieces[3]
- nick = pieces[4]
- auth = pieces[5]
- if auth != '0':
- self.parent.user(nick).authed(auth)
-
- elif pieces[1] == "JOIN":
- nick = pieces[0].split('!')[0][1:]
- chan = self.parent.channel(pieces[2])
-
- if nick == self.nick:
- self.conn.send("WHO %s %%ant,1" % (chan))
- else:
- user = self.parent.user(nick, justjoined=True)
- chan.userjoin(user)
- user.join(chan)
-
+ zero = {
+ 'NOTICE': self._gotregistered,
+ 'PING': self._gotping,
+ 'ERROR': self._goterror,
+ }
+ one = {
+ '001': self._got001,
+ 'PRIVMSG': self._gotprivmsg,
+ '354': self._got354,
+ 'JOIN': self._gotjoin,
+ 'PART': self._gotpart,
+ 'QUIT': self._gotquit,
+ 'NICK': self._gotnick,
+ 'MODE': self._gotmode,
+ }
+
+ if self.parent.hasnumhook(pieces[1]):
+ hooks = self.parent.getnumhook(pieces[1])
+ for callback in hooks:
+ callback(self, line)
+
+ if pieces[0] in zero:
+ zero[pieces[0]](pieces)
+ elif pieces[1] in one:
+ one[pieces[1]](pieces)
+
+ def _gotregistered(self, pieces):
+ if not self.conn.registered():
+ self.conn.register()
+ def _gotping(self, pieces):
+ self.conn.send("PONG %s" % (pieces[1]))
+ def _goterror(self, pieces): #TODO handle better
+ sys.exit(2)
+ os._exit(2)
+ def _got001(self, pieces):
+ self.conn.registered(True)
+ self.conn.send("MODE %s +x" % (pieces[2]))
+ if self.authname is not None and self.authpass is not None:
+ self.conn.send("AUTH %s %s" % (self.authname, self.authpass))
+ for c in self.chans:
+ self.join(c.name)
+ def _gotprivmsg(self, pieces):
+ nick = pieces[0].split('!')[0][1:]
+ user = self.parent.user(nick)
+ target = pieces[2]
+ msg = ' '.join(pieces[3:])[1:]
+ self.parsemsg(user, target, msg)
+ def _got354(self, pieces):
+ qt, nick, auth = pieces[3:6]
+ self.parent.user(nick).authed(auth)
+ def _gotjoin(self, pieces):
+ nick = pieces[0].split('!')[0][1:]
+ chan = self.parent.channel(pieces[2])
+
+ if nick == self.nick:
+ self.conn.send("WHO %s c%%ant,1" % (chan))
+ else:
+ user = self.parent.user(nick, justjoined=True)
+ chan.userjoin(user)
+ user.join(chan)
+ def _gotpart(self, pieces):
+ nick = pieces[0].split('!')[0][1:]
+ chan = self.parent.channel(pieces[2])
+
+ if nick != self.nick:
+ self.parent.user(nick).part(chan)
+ chan.userpart(self.parent.user(nick))
+ def _gotquit(self, pieces):
+ nick = pieces[0].split('!')[0][1:]
+ if nick != self.nick:
+ self.parent.user(nick).quit()
+ del self.parent.users[nick.lower()]
+ def _gotnick(self, pieces):
+ oldnick = pieces[0].split('!')[0][1:]
+ newnick = pieces[2][1:]
+ if newnick.lower() != oldnick.lower():
+ self.parent.users[newnick.lower()] = self.parent.users[oldnick.lower()]
+ del self.parent.users[oldnick.lower()]
+ self.parent.users[newnick.lower()].nickchange(newnick)
+ def _gotmode(self, pieces): #TODO parse for ops/voices (at least)
+ pass
+
+
+ def __debug_cbexception(self, *args):
+ if int(self.parent.cfg.get('debug', 'cbexc', default=0)) == 1:
+ self.conn.send("PRIVMSG DimeCadmium :%09.3f ^C4^B!!!^B^C CBEXC" % (time.time() % 100000))
+ print "%09.3f %s [!] CBEXC %r" % (time.time() % 100000, self.nick, args)
+ __import__('traceback').print_exc()
+
+