Software /
code /
prosody
File
core/componentmanager.lua @ 259:1485d272400d
Some more logging fixes
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Fri, 14 Nov 2008 02:41:37 +0000 |
parent | 217:d522f3a25dda |
child | 261:790cf21e2af7 |
line wrap: on
line source
local log = require "util.logger".init("componentmanager") local jid_split = require "util.jid".split; local hosts = hosts; local components = {}; module "componentmanager" function handle_stanza(origin, stanza) local node, host = jid_split(stanza.attr.to); local component = components[host]; if not component then component = components[node.."@"..host]; end -- hack to allow hooking node@server if not component then component = components[stanza.attr.to]; end -- hack to allow hooking node@server/resource and server/resource if component then log("debug", "stanza being handled by component: "..host); component(origin, stanza, hosts[host]); else log("error", "Component manager recieved a stanza for a non-existing component: " .. stanza.attr.to); end end function register_component(host, component) if not hosts[host] then -- TODO check for host well-formedness components[host] = component; hosts[host] = {type = "component", host = host, connected = true}; log("debug", "component added: "..host); else log("error", "Attempt to set component for existing host: "..host); end end return _M;