mirror of
https://github.com/bjc/prosody.git
synced 2025-04-05 14:17:37 +03:00
prosody, mod_c2s, mod_s2s: Move closing of c2s and s2s sessions to respective plugins
This commit is contained in:
parent
de47f7e836
commit
3e2a8fbe1c
3 changed files with 18 additions and 37 deletions
|
@ -265,6 +265,15 @@ function listener.associate_session(conn, session)
|
|||
sessions[conn] = session;
|
||||
end
|
||||
|
||||
module:hook("server-stopping", function(event)
|
||||
local reason = event.reason;
|
||||
for _, session in pairs(sessions) do
|
||||
session:close{ condition = "system-shutdown", text = reason };
|
||||
end
|
||||
end, 1000);
|
||||
|
||||
|
||||
|
||||
module:provides("net", {
|
||||
name = "c2s";
|
||||
listener = listener;
|
||||
|
|
|
@ -506,6 +506,15 @@ end
|
|||
|
||||
s2sout.set_listener(listener);
|
||||
|
||||
module:hook("server-stopping", function(event)
|
||||
local reason = event.reason;
|
||||
for _, session in pairs(sessions) do
|
||||
session:close{ condition = "system-shutdown", text = reason };
|
||||
end
|
||||
end,500);
|
||||
|
||||
|
||||
|
||||
module:provides("net", {
|
||||
name = "s2s";
|
||||
listener = listener;
|
||||
|
|
37
prosody
37
prosody
|
@ -374,43 +374,6 @@ end
|
|||
function cleanup()
|
||||
log("info", "Shutdown status: Cleaning up");
|
||||
prosody.events.fire_event("server-cleanup");
|
||||
|
||||
-- Ok, we're quitting I know, but we
|
||||
-- need to do some tidying before we go :)
|
||||
server.setquitting(false);
|
||||
|
||||
log("info", "Shutdown status: Closing all active sessions");
|
||||
for hostname, host in pairs(hosts) do
|
||||
log("debug", "Shutdown status: Closing client connections for %s", hostname)
|
||||
if host.sessions then
|
||||
local reason = { condition = "system-shutdown", text = "Server is shutting down" };
|
||||
if prosody.shutdown_reason then
|
||||
reason.text = reason.text..": "..prosody.shutdown_reason;
|
||||
end
|
||||
for username, user in pairs(host.sessions) do
|
||||
for resource, session in pairs(user.sessions) do
|
||||
log("debug", "Closing connection for %s@%s/%s", username, hostname, resource);
|
||||
session:close(reason);
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
log("debug", "Shutdown status: Closing outgoing s2s connections from %s", hostname);
|
||||
if host.s2sout then
|
||||
for remotehost, session in pairs(host.s2sout) do
|
||||
if session.close then
|
||||
session:close("system-shutdown");
|
||||
else
|
||||
log("warn", "Unable to close outgoing s2s session to %s, no session:close()?!", remotehost);
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
log("info", "Shutdown status: Closing all server connections");
|
||||
server.closeall();
|
||||
|
||||
server.setquitting(true);
|
||||
end
|
||||
|
||||
-- Are you ready? :)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue