From 75a4fe601018e84510f1526faa9d155a9299e528 Mon Sep 17 00:00:00 2001 From: Matthew Wild Date: Thu, 29 Jan 2009 02:14:16 +0000 Subject: mod_muc: Add support for being a component --- plugins/mod_muc.lua | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/plugins/mod_muc.lua b/plugins/mod_muc.lua index f1b46eed..0b610835 100644 --- a/plugins/mod_muc.lua +++ b/plugins/mod_muc.lua @@ -8,7 +8,12 @@ local st = require "util.stanza"; local log = require "util.logger".init("mod_muc"); local multitable_new = require "util.multitable".new; -local muc_domain = "conference."..module:get_host(); +if module:get_host_type() ~= "component" then + error("MUC should be loaded as a component, please see http://prosody.im/doc/components", 0); +end + +local muc_domain = module:get_host(); + local muc_name = "MUCMUCMUC!!!"; -- room_name -> room @@ -256,7 +261,7 @@ function handle_to_domain(origin, stanza) end end -component = register_component(muc_domain, function(origin, stanza) +function handle_stanza(origin, stanza) local to_node, to_host, to_resource = jid_split(stanza.attr.to); if stanza.name == "presence" and stanza.attr.type ~= nil and stanza.attr.type ~= "unavailable" then if type == "error" or type == "result" then return; end @@ -272,7 +277,11 @@ component = register_component(muc_domain, function(origin, stanza) if type == "error" or type == "result" then return; end handle_to_domain(origin, stanza); end -end); +end + +module.load_component = function() + return handle_stanza; -- Return the function that we want to handle incoming stanzas +end module.unload = function() deregister_component(muc_domain); -- cgit v1.2.3