mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 21:57:45 +03:00
s2s: Allow passing a custom error for bouncing queued stanzas (#770)
Since stream errors and stanza errors are different
This commit is contained in:
parent
e130b37797
commit
3aee8e24a6
2 changed files with 5 additions and 5 deletions
|
@ -84,14 +84,14 @@ local function retire_session(session, reason)
|
|||
return setmetatable(session, resting_session);
|
||||
end
|
||||
|
||||
local function destroy_session(session, reason)
|
||||
local function destroy_session(session, reason, bounce_reason)
|
||||
if session.destroyed then return; end
|
||||
local log = session.log or log;
|
||||
log("debug", "Destroying %s session %s->%s%s%s", session.direction, session.from_host, session.to_host, reason and ": " or "", reason or "");
|
||||
|
||||
if session.direction == "outgoing" then
|
||||
hosts[session.from_host].s2sout[session.to_host] = nil;
|
||||
session:bounce_sendq(reason);
|
||||
session:bounce_sendq(bounce_reason or reason);
|
||||
elseif session.direction == "incoming" then
|
||||
if session.outgoing then
|
||||
hosts[session.to_host].s2sout[session.from_host] = nil;
|
||||
|
|
|
@ -487,7 +487,7 @@ end
|
|||
|
||||
--- Session methods
|
||||
local stream_xmlns_attr = {xmlns='urn:ietf:params:xml:ns:xmpp-streams'};
|
||||
local function session_close(session, reason, remote_reason)
|
||||
local function session_close(session, reason, remote_reason, bounce_reason)
|
||||
local log = session.log or log;
|
||||
if session.conn then
|
||||
if session.notopen then
|
||||
|
@ -537,12 +537,12 @@ local function session_close(session, reason, remote_reason)
|
|||
add_task(stream_close_timeout, function ()
|
||||
if not session.destroyed then
|
||||
session.log("warn", "Failed to receive a stream close response, closing connection anyway...");
|
||||
s2s_destroy_session(session, reason);
|
||||
s2s_destroy_session(session, reason, bounce_reason);
|
||||
conn:close();
|
||||
end
|
||||
end);
|
||||
else
|
||||
s2s_destroy_session(session, reason);
|
||||
s2s_destroy_session(session, reason, bounce_reason);
|
||||
conn:close(); -- Close immediately, as this is an outgoing connection or is not authed
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue