mirror of
https://github.com/bjc/prosody.git
synced 2025-04-03 05:07:42 +03:00
mod_s2s: Close connection on smacks timeout
This merges the mod_s2s_smacks_timeout behavior from prosody-modules This event is fired by mod_smacks when the connection has not responded to an ack-request for a period of time defaulting to 30 seconds, indicating that the connection has become stuck or non-responsive. Closing it prevents routing further messages via this connection and frees resources. A stuck connection may otherwise remain until for a time determined by the OS TCP subsystem, which can be quite long.
This commit is contained in:
parent
3fbec27699
commit
e5aa2c3385
2 changed files with 7 additions and 0 deletions
1
CHANGES
1
CHANGES
|
@ -55,6 +55,7 @@ TRUNK
|
|||
- Forwarded header from RFC 7239 supported, disabled by default
|
||||
- mod_http_file_share now uses roles framework, affecting access from e.g. components
|
||||
- Intervals of mod_cron managed periodic jobs made configurable
|
||||
- When mod_smacks is enabled, s2s connections not responding to ack requests are closed.
|
||||
|
||||
## Removed
|
||||
|
||||
|
|
|
@ -272,6 +272,12 @@ function module.add_host(module)
|
|||
end, 100);
|
||||
module:hook("s2s-authenticated", make_authenticated, -1);
|
||||
module:hook("s2s-read-timeout", keepalive, -1);
|
||||
module:hook("smacks-ack-delayed", function (event)
|
||||
if event.origin.type == "s2sin" or event.origin.type == "s2sout" then
|
||||
event.origin:close("connection-timeout");
|
||||
return true;
|
||||
end
|
||||
end, -1);
|
||||
module:hook_stanza("http://etherx.jabber.org/streams", "features", function (session, stanza) -- luacheck: ignore 212/stanza
|
||||
local limits = stanza:get_child("limits", "urn:xmpp:stream-limits:0");
|
||||
if limits then
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue