# HG changeset patch # User Matthew Wild # Date 1225027149 0 # Node ID 8315cf03f304898a8bff28f66863eaf7c68ebbdd # Parent 92768120b71755475af17daae93991639125a68e# Parent 606c433955e700f95b58ce9abc502ad56617c1ab Merge presence/subscription support from waqas diff -r 606c433955e7 -r 8315cf03f304 core/s2smanager.lua --- a/core/s2smanager.lua Sun Oct 26 00:22:18 2008 +0500 +++ b/core/s2smanager.lua Sun Oct 26 13:19:09 2008 +0000 @@ -111,11 +111,6 @@ print(session, session.from_host, "incoming s2s stream opened"); send(""); send(format("", session.streamid, session.to_host)); - if session.from_host then - -- Need to perform dialback to check identity - print("to: "..tostring(attr.to).." from: "..tostring(attr.from)); - print("Need to do dialback here you know!!"); - end elseif session.direction == "outgoing" then -- If we are just using the connection for verifying dialback keys, we won't try and auth it if not session.dialback_verifying then @@ -180,7 +175,7 @@ end function destroy_session(session) - (session.log or log)("info", "Destroying session"); + (session.log or log)("info", "Destroying "..tostring(session.direction).." session "..tostring(session.from_host).."->"..tostring(session.to_host)); if session.direction == "outgoing" then hosts[session.to_host] = nil; end diff -r 606c433955e7 -r 8315cf03f304 core/stanza_router.lua --- a/core/stanza_router.lua Sun Oct 26 00:22:18 2008 +0500 +++ b/core/stanza_router.lua Sun Oct 26 13:19:09 2008 +0000 @@ -135,9 +135,12 @@ print(tostring(origin.to_host), tostring(origin.from_host)) -- FIXME: Grr, ejabberd breaks this one too?? it is black and white in XEP-220 example 34 --if attr.from ~= origin.to_host then error("invalid-from"); end - local type = "invalid"; + local type; if s2s_verify_dialback(attr.id, attr.from, attr.to, stanza[1]) then type = "valid" + else + type = "invalid" + log("warn", "Asked to verify a dialback key that was incorrect. An imposter is claiming to be %s?", attr.to); end origin.send(format("%s", attr.to, attr.from, attr.id, type, stanza[1])); elseif stanza.name == "result" and origin.type == "s2sin_unauthed" then