aboutsummaryrefslogtreecommitdiffstats
path: root/core
diff options
context:
space:
mode:
authorMatthew Wild <mwild1@gmail.com>2009-07-03 04:04:27 +0100
committerMatthew Wild <mwild1@gmail.com>2009-07-03 04:04:27 +0100
commita61b473078bbaa025855b0fdc8bd2046f9bcd481 (patch)
tree3d22c874cbef8f1325f66f3eaec9b8358ebb8003 /core
parenta00feb415fee14056a606aa3b2e3bdc2f3a137fd (diff)
downloadprosody-a61b473078bbaa025855b0fdc8bd2046f9bcd481.tar.gz
prosody-a61b473078bbaa025855b0fdc8bd2046f9bcd481.zip
stanza_router: Check host.disallow_s2s before routing over s2sout. you can haz no s2s.
Diffstat (limited to 'core')
-rw-r--r--core/stanza_router.lua16
1 files changed, 10 insertions, 6 deletions
diff --git a/core/stanza_router.lua b/core/stanza_router.lua
index d3bd2445..5bf437f9 100644
--- a/core/stanza_router.lua
+++ b/core/stanza_router.lua
@@ -173,12 +173,16 @@ function core_route_stanza(origin, stanza)
core_post_stanza(origin, stanza);
elseif origin.type == "c2s" then
-- Remote host
- local xmlns = stanza.attr.xmlns;
- --stanza.attr.xmlns = "jabber:server";
- stanza.attr.xmlns = nil;
- log("debug", "sending s2s stanza: %s", tostring(stanza));
- send_s2s(origin.host, host, stanza); -- TODO handle remote routing errors
- stanza.attr.xmlns = xmlns; -- reset
+ if not hosts[from_host].disallow_s2s then
+ local xmlns = stanza.attr.xmlns;
+ --stanza.attr.xmlns = "jabber:server";
+ stanza.attr.xmlns = nil;
+ log("debug", "sending s2s stanza: %s", tostring(stanza));
+ send_s2s(origin.host, host, stanza); -- TODO handle remote routing errors
+ stanza.attr.xmlns = xmlns; -- reset
+ else
+ core_route_stanza(hosts[from_host], st.error_reply(stanza, "cancel", "not-allowed", "Communication with remote servers is not allowed"));
+ end
elseif origin.type == "component" or origin.type == "local" then
-- Route via s2s for components and modules
log("debug", "Routing outgoing stanza for %s to %s", from_host, host);