# HG changeset patch # User Matthew Wild # Date 1223068688 -3600 # Node ID 2c0147bbd81a62864fc633450630e10ca6f1464c # Parent 89877d61ac512a54afda5c2757e171b813b466e4 Move stream opening handling from xmlhandlers to sessionmanager diff -r 89877d61ac51 -r 2c0147bbd81a core/sessionmanager.lua --- a/core/sessionmanager.lua Fri Oct 03 22:17:20 2008 +0100 +++ b/core/sessionmanager.lua Fri Oct 03 22:18:08 2008 +0100 @@ -1,11 +1,17 @@ -local tostring = tostring; +local tonumber, tostring = tonumber, tostring; +local ipairs = ipairs; + +local m_random = math.random; +local format = string.format; local print = print; local hosts = hosts; +local modulemanager = require "core.modulemanager"; local log = require "util.logger".init("sessionmanager"); +local error = error; module "sessionmanager" @@ -54,4 +60,27 @@ return true; end +function streamopened(session, attr) + local send = session.send; + session.host = attr.to or error("Client failed to specify destination hostname"); + session.version = tonumber(attr.version) or 0; + session.streamid = m_random(1000000, 99999999); + print(session, session.host, "Client opened stream"); + send(""); + send(format("", session.streamid, session.host)); + + local features = {}; + modulemanager.fire_event("stream-features", session, features); + + send(""); + + for _, feature in ipairs(features) do + send_to_session(session, tostring(features)); + end + + send(""); + log("info", "core", "Stream opened successfully"); + session.notopen = nil; +end + return _M; \ No newline at end of file diff -r 89877d61ac51 -r 2c0147bbd81a core/xmlhandlers.lua --- a/core/xmlhandlers.lua Fri Oct 03 22:17:20 2008 +0100 +++ b/core/xmlhandlers.lua Fri Oct 03 22:18:08 2008 +0100 @@ -1,4 +1,5 @@ +local sessionmanager_streamopened = require "core.sessionmanager".streamopened; require "util.stanza" local st = stanza; @@ -27,7 +28,6 @@ local stanza function xml_handlers:StartElement(name, attr) - log("info", "xmlhandlers", "Start element: " .. name); if stanza and #chardata > 0 then -- We have some character data in the buffer stanza:text(t_concat(chardata)); @@ -37,24 +37,7 @@ if not stanza then if session.notopen then if name == "stream" then - session.host = attr.to or error("Client failed to specify destination hostname"); - session.version = attr.version or 0; - session.streamid = m_random(1000000, 99999999); - print(session, session.host, "Client opened stream"); - send(""); - send(format("", session.streamid, session.host)); - send(""); - if not session.username then - send(""); - send("PLAIN"); - send(""); - else - send(""); - end - --send [[ ]] - send(""); - log("info", "core", "Stream opened successfully"); - session.notopen = nil; + sessionmanager_streamopened(session, attr); return; end error("Client failed to open stream successfully");