# HG changeset patch # User Matthew Wild # Date 1324051319 0 # Node ID a813a130cede27a9038d2f5ee654989b5cd693d7 # Parent 2ccc386b9913049073a6945a43705fbcb90119f6 hostmanager: Add send() method to hosts diff -r 2ccc386b9913 -r a813a130cede core/hostmanager.lua --- a/core/hostmanager.lua Wed Dec 14 07:19:58 2011 +0500 +++ b/core/hostmanager.lua Fri Dec 16 16:01:59 2011 +0000 @@ -53,6 +53,17 @@ prosody_events.add_handler("server-starting", load_enabled_hosts); +local function host_send(stanza) + local name, type = stanza.name, stanza.attr.type; + if type == "error" or (name == "iq" and type == "result") then + local dest_host_name = select(2, jid_split(stanza.attr.to)); + local dest_host = hosts[dest_host_name] or { type = "unknown" }; + log("warn", "Unhandled response sent to %s host %s: %s", dest_host.type, dest_host_name, tostring(stanza)); + return; + end + core_route_stanza(nil, stanza); +end + function activate(host, host_config) if hosts[host] then return nil, "The host "..host.." is already activated"; end host_config = host_config or configmanager.getconfig()[host]; @@ -63,6 +74,7 @@ events = events_new(); dialback_secret = configmanager.get(host, "core", "dialback_secret") or uuid_gen(); disallow_s2s = configmanager.get(host, "core", "disallow_s2s"); + send = host_send; }; if not host_config.core.component_module then -- host host_session.type = "local";