mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 21:27:38 +03:00
net.server_epoll: Prevent loop attempting to send last data after close
If the connection is closed by the peer, any buffered data is given a last chance to be sent (see f27b9319e0da). If the connection is Really closed, no attempt to write will occur, instead epoll will raise the error flag and :onreadable() will be invoked again, where it will try to :close() again for the same reason, thus looping until the connection somehow gets destroyed. By clearing the _connected flag, the second time it passes :onreadable() it should go directly to :destroy(), breaking the loop. Thanks Link Mauve for reporting
This commit is contained in:
parent
0bb07b9711
commit
61348c0a7d
1 changed files with 1 additions and 0 deletions
|
@ -577,6 +577,7 @@ interface.send = interface.write;
|
|||
-- Close, possibly after writing is done
|
||||
function interface:close()
|
||||
if self._connected and self.writebuffer and (self.writebuffer[1] or type(self.writebuffer) == "string") then
|
||||
self._connected = false;
|
||||
self:set(false, true); -- Flush final buffer contents
|
||||
self:setreadtimeout(false);
|
||||
self:setwritetimeout();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue