mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 21:57:45 +03:00
mod_c2s: Do not allow the stream 'to' to change across stream restarts (fixes #1147)
This commit is contained in:
parent
b7b2a4f9e4
commit
32b507c866
1 changed files with 9 additions and 2 deletions
|
@ -40,12 +40,19 @@ local default_stream_attr = { ["xmlns:stream"] = "http://etherx.jabber.org/strea
|
|||
|
||||
function stream_callbacks.streamopened(session, attr)
|
||||
local send = session.send;
|
||||
session.host = nameprep(attr.to);
|
||||
if not session.host then
|
||||
local host = nameprep(attr.to);
|
||||
if not host then
|
||||
session:close{ condition = "improper-addressing",
|
||||
text = "A valid 'to' attribute is required on stream headers" };
|
||||
return;
|
||||
end
|
||||
if not session.host then
|
||||
session.host = host;
|
||||
elseif session.host ~= host then
|
||||
session:close{ condition = "not-authorized",
|
||||
text = "The 'to' attribute must remain the same across stream restarts" };
|
||||
return;
|
||||
end
|
||||
session.version = tonumber(attr.version) or 0;
|
||||
session.streamid = uuid_generate();
|
||||
(session.log or session)("debug", "Client sent opening <stream:stream> to %s", session.host);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue