one = { #things to look for after source
'001': self._got001,
'PRIVMSG': self._gotprivmsg,
- '354': self._got354,
+ '353': self._got353, #NAMES
+ '354': self._got354, #WHO
'JOIN': self._gotjoin,
'PART': self._gotpart,
'QUIT': self._gotquit,
self.conn.register()
def _gotping(self, pieces):
self.conn.send("PONG %s" % (pieces[1]))
- def _goterror(self, pieces): #TODO handle better
+ def _goterror(self, pieces): #TODO handle more gracefully
curs = self.parent.db.cursor()
curs.execute("UPDATE bots SET connected = 0")
curs.close()
target = pieces[2]
msg = ' '.join(pieces[3:])[1:]
self.parsemsg(user, target, msg)
+ def _got353(self, pieces):
+ chan = self.parent.channel(pieces[4])
+ names = pieces[5:]
+ names[0] = names[0][1:] #remove colon
+ for n in names:
+ user = self.parent.user(n.lstrip('@+'))
+ if n[0] == '@':
+ chan.userjoin(user, 'op')
+ elif n[0] == '+':
+ chan.userjoin(user, 'voice')
+ else:
+ chan.userjoin(user)
+ user.join(chan)
def _got354(self, pieces):
- qt, nick, auth = pieces[3:6]
+ qt = int(pieces[3])
+ if qt < 3:
+ nick, auth = pieces[4:6]
+ chan = None
+ else:
+ chan, nick, auth = pieces[4:7]
+ chan = self.parent.channel(chan)
user = self.parent.user(nick)
user.authed(auth)
- if qt == "2":
+
+ if chan is not None:
+ user.join(chan)
+ chan.userjoin(user)
+
+ if qt == 2: # triggered by !auth
if user.isauthed():
if user.glevel > 0:
self.msg(nick, "You are now known as #%s (access level: %s)" % (auth, user.glevel))
chan = self.parent.channel(pieces[2])
if nick == self.nick:
- self.conn.send("WHO %s c%%ant,1" % (chan))
+ self.conn.send("WHO %s c%%cant,3" % (chan))
else:
user = self.parent.user(nick, justjoined=True)
chan.userjoin(user)
chan = self.parent.channel(pieces[2])
if nick != self.nick:
- self.parent.user(nick).part(chan)
+ gone = self.parent.user(nick).part(chan)
chan.userpart(self.parent.user(nick))
+ if gone:
+ self.parent.user(nick).quit()
+ del self.parent.users[nick.lower()]
def _gotquit(self, pieces):
nick = pieces[0].split('!')[0][1:]
if nick != self.nick:
+ for chan in self.parent.user(nick).chans:
+ chan.userpart(self.parent.user(nick))
self.parent.user(nick).quit()
del self.parent.users[nick.lower()]
def _gotnick(self, pieces):
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 _gotmode(self, pieces):
+ source = pieces[0].split('!')[0][1:]
+ chan = self.parent.channel(pieces[2])
+ mode = pieces[3]
+ args = pieces[4:]
+
+ adding = True
+ for c in mode:
+ if c == '+':
+ adding = True
+ elif c == '-':
+ adding = False
+ elif c == 'o':
+ if adding:
+ chan.userop(self.parent.user(args.pop(0)))
+ else:
+ chan.userdeop(self.parent.user(args.pop(0)))
+ elif c == 'v':
+ if adding:
+ chan.uservoice(self.parent.user(args.pop(0)))
+ else:
+ chan.userdevoice(self.parent.user(args.pop(0)))
+ else:
+ pass # don't care about other modes
def __debug_cbexception(self, source, *args, **kwargs):
if int(self.parent.cfg.get('debug', 'cbexc', default=0)) == 1: