Mercurial > prosody-modules
changeset 4981:f0fe95f9e21c
mod_s2s_smacks_timeout: Use mod_smacks to close stale s2s connections
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Wed, 03 Aug 2022 03:14:17 +0200 (2022-08-03) |
parents | da151f9af861 |
children | 8a4b17e2e984 |
files | mod_s2s_smacks_timeout/README.md mod_s2s_smacks_timeout/mod_s2s_smacks_timeout.lua |
diffstat | 2 files changed, 28 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mod_s2s_smacks_timeout/README.md Wed Aug 03 03:14:17 2022 +0200 @@ -0,0 +1,20 @@ +# Introduction + +This module closes s2s connections when +[mod_smacks][doc:modules:mod_smacks] reports that a connection has not +received a timely acknowledgement as requested, indicating that the +connection is broken or the remote server is not responding. + +With the connection closed, the next stanza to be directed to that +server will trigger Prosody to establish a new connection, instead of +queueing it on the potentially broken connection. + +This should prevent messages from being stuck in a queue for a +potentially long time before being bounced back to the sender as +delivery failure reports. + +Normally the amount of time it takes for a broken connection to time out +is determined by TCP. + +If this is deemed sensible behavior then it will likely be merged into +Prosody itself somewhere.
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mod_s2s_smacks_timeout/mod_s2s_smacks_timeout.lua Wed Aug 03 03:14:17 2022 +0200 @@ -0,0 +1,8 @@ +module:depends("smacks"); + +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);