Software /
code /
prosody
Diff
net/server_epoll.lua @ 11814:f27b9319e0da
net.server_epoll: Separate handling of "closed" from other errors
The intent is to ensure 'ondisconnect' only gets called once, while
giving buffered outgoing data a last chance to be delivered via the
:close() path in case the connection was only shutdown in one direction.
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Wed, 22 Sep 2021 13:29:47 +0200 |
parent | 11813:790bffbb9047 |
child | 11839:19b50ce9ef5a |
line wrap: on
line diff
--- a/net/server_epoll.lua Wed Sep 22 11:27:55 2021 +0200 +++ b/net/server_epoll.lua Wed Sep 22 13:29:47 2021 +0200 @@ -456,14 +456,14 @@ self:onconnect(); self:onincoming(partial, err); end - if err ~= "timeout" then - if err == "closed" then - self:debug("Connection closed by remote"); - else - self:debug("Read error, closing (%s)", err); - end + if err == "closed" and self._connected then + self:debug("Connection closed by remote"); + self:close(err); + return; + elseif err ~= "timeout" then + self:debug("Read error, closing (%s)", err); self:on("disconnect", err); - self:close(); + self:destroy(); return; end end