working outgoing s2s \o/

This commit is contained in:
Matthew Wild 2008-10-24 03:42:26 +01:00
parent eb8e9997e0
commit 8fa7f06302
2 changed files with 12 additions and 1 deletions

View file

@ -13,6 +13,7 @@ local send_s2s = require "core.s2smanager".send_to_host;
local user_exists = require "core.usermanager".user_exists;
local s2s_verify_dialback = require "core.s2smanager".verify_dialback;
local s2s_make_authenticated = require "core.s2smanager".make_authenticated;
local format = string.format;
local tostring = tostring;
@ -109,6 +110,15 @@ function core_handle_stanza(origin, stanza)
end
origin.send(format("<db:verify from='%s' to='%s' id='%s' type='%s'>%s</db:verify>", attr.to, attr.from, attr.id, type, stanza[1]));
end
elseif origin.type == "s2sout_unauthed" then
if stanza.name == "result" and stanza.attr.xmlns == "jabber:server:dialback" then
if stanza.attr.type == "valid" then
s2s_make_authenticated(origin);
else
-- FIXME
error("dialback failed!");
end
end
else
log("warn", "Unhandled origin: %s", origin.type);
end
@ -208,6 +218,8 @@ function core_route_stanza(origin, stanza)
end
else
-- Remote host
log("debug", "sending s2s stanza: %s", tostring(stanza));
stanza.attr.xmlns = "jabber:server";
send_s2s(origin.host, host, stanza);
end
stanza.attr.to = to; -- reset

View file

@ -35,7 +35,6 @@ function init_xmlhandlers(session, streamopened)
stanza:text(t_concat(chardata));
chardata = {};
end
log("debug", "Start element: %s", tostring(name));
curr_ns,name = name:match("^(.+):([%w%-]+)$");
attr.xmlns = curr_ns;