From 40c0526f7c3b8b8ed1a9ea30f3a2826d01427863 Mon Sep 17 00:00:00 2001 From: Waqas Hussain Date: Mon, 1 Jun 2009 10:44:05 +0500 Subject: mod_iq: Immediately return an error for IQs to non-existing bare JIDs --- plugins/mod_iq.lua | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) (limited to 'plugins') diff --git a/plugins/mod_iq.lua b/plugins/mod_iq.lua index c1e9df6a..046bebd6 100644 --- a/plugins/mod_iq.lua +++ b/plugins/mod_iq.lua @@ -1,5 +1,7 @@ local st = require "util.stanza"; +local jid_split = require "util.jid".split; +local user_exists = require "core.usermanager".user_exists; local full_sessions = full_sessions; local bare_sessions = bare_sessions; @@ -24,7 +26,15 @@ module:hook("iq/bare", function(data) -- IQ to bare JID recieved local origin, stanza = data.origin, data.stanza; - -- TODO if not user exists, return an error + if not bare_sessions[stanza.attr.to] then -- quick check for account existance + local node, host = jid_split(stanza.attr.to); + if not user_exists(node, host) then -- full check for account existance + if stanza.attr.type == "get" or stanza.attr.type == "set" then + origin.send(st.error_reply(stanza, "cancel", "service-unavailable")); + end + return true; + end + end -- TODO fire post processing events if #stanza.tags == 1 then return module:fire_event("iq/bare/"..stanza.tags[1].attr.xmlns..":"..stanza.tags[1].name, data); -- cgit v1.2.3