Merge from waqas
[prosody.git] / core / componentmanager.lua
1 -- Prosody IM v0.1
2 -- Copyright (C) 2008 Matthew Wild
3 -- Copyright (C) 2008 Waqas Hussain
4 -- 
5 -- This program is free software; you can redistribute it and/or
6 -- modify it under the terms of the GNU General Public License
7 -- as published by the Free Software Foundation; either version 2
8 -- of the License, or (at your option) any later version.
9 -- 
10 -- This program is distributed in the hope that it will be useful,
11 -- but WITHOUT ANY WARRANTY; without even the implied warranty of
12 -- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 -- GNU General Public License for more details.
14 -- 
15 -- You should have received a copy of the GNU General Public License
16 -- along with this program; if not, write to the Free Software
17 -- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
18 --
19
20
21 \r
22 \r
23 local log = require "util.logger".init("componentmanager")\r
24 local jid_split = require "util.jid".split;\r
25 local hosts = hosts;\r
26 \r
27 local components = {};\r
28 \r
29 module "componentmanager"\r
30 \r
31 function handle_stanza(origin, stanza)\r
32         local node, host = jid_split(stanza.attr.to);\r
33         local component = components[host];\r
34         if not component then component = components[node.."@"..host]; end -- hack to allow hooking node@server\r
35         if not component then component = components[stanza.attr.to]; end -- hack to allow hooking node@server/resource and server/resource\r
36         if component then\r
37                 log("debug", "stanza being handled by component: "..host);\r
38                 component(origin, stanza, hosts[host]);\r
39         else\r
40                 log("error", "Component manager recieved a stanza for a non-existing component: " .. stanza.attr.to);\r
41         end\r
42 end\r
43 \r
44 function register_component(host, component)\r
45         if not hosts[host] then\r
46                 -- TODO check for host well-formedness\r
47                 components[host] = component;\r
48                 hosts[host] = {type = "component", host = host, connected = true, s2sout = {} };\r
49                 log("debug", "component added: "..host);\r
50                 return hosts[host];\r
51         else\r
52                 log("error", "Attempt to set component for existing host: "..host);\r
53         end\r
54 end\r
55 \r
56 return _M;\r