mirror of
https://github.com/Mikaela/Limnoria.git
synced 2025-01-11 12:42:34 +01:00
Changed the way Irc handles unresponded-to PINGs.
This commit is contained in:
parent
29effdf8cc
commit
a46ce6b109
@ -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'):
|
||||||
|
Loading…
Reference in New Issue
Block a user