Changed the way Irc handles unresponded-to PINGs.

This commit is contained in:
Jeremy Fincher 2003-04-04 08:30:16 +00:00
parent 29effdf8cc
commit a46ce6b109

View File

@ -282,7 +282,7 @@ class Irc(object):
self.queue = IrcMsgQueue() self.queue = IrcMsgQueue()
self.fastqueue = queue() self.fastqueue = queue()
self.lastping = time.time() self.lastping = time.time()
self.lastpong = time.time()+60 self.outstandingPongs = set()
self.lastTake = 0 self.lastTake = 0
self.driver = None # The driver should set this later. self.driver = None # The driver should set this later.
self.queue.enqueue(ircmsgs.user(self.user, self.ident)) self.queue.enqueue(ircmsgs.user(self.user, self.ident))
@ -330,8 +330,8 @@ class Irc(object):
else: else:
self.lastTake = now self.lastTake = now
msg = self.queue.dequeue() msg = self.queue.dequeue()
elif self.lastping - self.lastpong > 180: elif len(self.outstandingPongs) > 2:
# Our ping hasn't be responded to. # Our pings hasn't be responded to.
if hasattr(self.driver, 'scheduleReconnect'): if hasattr(self.driver, 'scheduleReconnect'):
self.driver.scheduleReconnect() self.driver.scheduleReconnect()
self.driver.die() self.driver.die()
@ -340,6 +340,8 @@ class Irc(object):
debug.msg('Irc.takeMsg throttling.', 'verbose') debug.msg('Irc.takeMsg throttling.', 'verbose')
else: else:
self.lastping = now self.lastping = now
now = str(int(now))
self.outstandingPongs.add(now)
msg = ircmsgs.ping(str(int(now))) msg = ircmsgs.ping(str(int(now)))
if msg: if msg:
for callback in self.callbacks: for callback in self.callbacks:
@ -399,7 +401,7 @@ class Irc(object):
ircdb.users.setUser(self.nick, u) ircdb.users.setUser(self.nick, u)
atexit.register(lambda: catch(ircdb.users.delUser(self.nick))) atexit.register(lambda: catch(ircdb.users.delUser(self.nick)))
elif msg.command == 'PONG': elif msg.command == 'PONG':
self.lastpong = time.time() self.outstandingPongs.remove(msg.args[1])
elif msg.command == 'ERROR': elif msg.command == 'ERROR':
if msg.args[0].startswith('Closing Link'): if msg.args[0].startswith('Closing Link'):
if hasattr(self.driver, 'scheduleReconnect'): if hasattr(self.driver, 'scheduleReconnect'):