aboutsummaryrefslogtreecommitdiffstats
path: root/net/server_epoll.lua
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2024-11-19 00:41:02 +0100
committerKim Alvefur <zash@zash.se>2024-11-19 00:41:02 +0100
commit61b0c0cd3ad805281ea5021278ecd6372296c9c5 (patch)
tree36f5b8b543c5e375a27ee7394a0e1fcf853fc988 /net/server_epoll.lua
parentff00c6707ffaa8f176c1675548f33f975af743e1 (diff)
downloadprosody-61b0c0cd3ad805281ea5021278ecd6372296c9c5.tar.gz
prosody-61b0c0cd3ad805281ea5021278ecd6372296c9c5.zip
net.server_epoll: Don't try to flush buffer on closed connections
Attempt to fix a bug where connections are somehow closed twice, leading to bad things happening elsewhere. With LuaSec, closed connections are generally already too closed to write anything to anyway since it does not support unidirectional shutdown.
Diffstat (limited to 'net/server_epoll.lua')
-rw-r--r--net/server_epoll.lua3
1 files changed, 2 insertions, 1 deletions
diff --git a/net/server_epoll.lua b/net/server_epoll.lua
index ce2782c1..b4477375 100644
--- a/net/server_epoll.lua
+++ b/net/server_epoll.lua
@@ -508,7 +508,8 @@ function interface:onreadable()
end
if err == "closed" and self._connected then
self:debug("Connection closed by remote");
- self:close(err);
+ self:on("disconnect", err);
+ self:destroy();
return;
elseif err ~= "timeout" then
self:debug("Read error, closing (%s)", err);