diff options
author | Matthew Wild <mwild1@gmail.com> | 2018-05-30 21:55:09 +0100 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2018-05-30 21:55:09 +0100 |
commit | b28bd6cc8186237136429ac4efeb84ca65077a97 (patch) | |
tree | c11212fdc293b35e1989e38b7e51ded86d2ad267 /plugins/mod_c2s.lua | |
parent | 0fd614dbab5caba118f3037f94e3beb8472c1a97 (diff) | |
parent | 265672920bd17a8c1d69ef66b6485c4f5c1893de (diff) | |
download | prosody-b28bd6cc8186237136429ac4efeb84ca65077a97.tar.gz prosody-b28bd6cc8186237136429ac4efeb84ca65077a97.zip |
Merge 0.9->0.10
Diffstat (limited to 'plugins/mod_c2s.lua')
-rw-r--r-- | plugins/mod_c2s.lua | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/plugins/mod_c2s.lua b/plugins/mod_c2s.lua index 8bcce6d8..7f0d1b01 100644 --- a/plugins/mod_c2s.lua +++ b/plugins/mod_c2s.lua @@ -49,12 +49,19 @@ local stream_xmlns_attr = {xmlns='urn:ietf:params:xml:ns:xmpp-streams'}; 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); |