X-Git-Url: https://git.enpas.org/?a=blobdiff_plain;f=plugins%2Fmod_iq.lua;h=5be045335c478e256913228207d31fc76b6f3719;hb=b6dfdd3762b43b153aeb2b9274ee88d30b4fb7e6;hp=e0c9813d4e8079ddba923127d583037ab93c30df;hpb=650637ec21a12dda0ef16a125e5fc0323003f5ea;p=prosody.git diff --git a/plugins/mod_iq.lua b/plugins/mod_iq.lua index e0c9813d..5be04533 100644 --- a/plugins/mod_iq.lua +++ b/plugins/mod_iq.lua @@ -1,3 +1,15 @@ +-- Prosody IM +-- Copyright (C) 2008-2009 Matthew Wild +-- Copyright (C) 2008-2009 Waqas Hussain +-- +-- This project is MIT/X11 licensed. Please see the +-- COPYING file in the source package for more information. +-- + + +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; @@ -10,24 +22,45 @@ module:hook("iq/full", function(data) if session then -- TODO fire post processing event session.send(stanza); - return true; else -- resource not online - -- TODO error reply + if stanza.attr.type == "get" or stanza.attr.type == "set" then + origin.send(st.error_reply(stanza, "cancel", "service-unavailable")); + end end + return true; end); 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 + local to = stanza.attr.to; + if to and not bare_sessions[to] then -- quick check for account existance + local node, host = jid_split(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 - -- TODO fire event with the xmlns:tag of the child, or with the id of errors and results + if stanza.attr.type == "get" or stanza.attr.type == "set" then + return module:fire_event("iq/bare/"..stanza.tags[1].attr.xmlns..":"..stanza.tags[1].name, data); + else + module:fire_event("iq/bare/"..stanza.attr.id, data); + return true; + end end); module:hook("iq/host", function(data) -- IQ to a local host recieved local origin, stanza = data.origin, data.stanza; - -- TODO fire event with the xmlns:tag of the child, or with the id of errors and results + if stanza.attr.type == "get" or stanza.attr.type == "set" then + return module:fire_event("iq/host/"..stanza.tags[1].attr.xmlns..":"..stanza.tags[1].name, data); + else + module:fire_event("iq/host/"..stanza.attr.id, data); + return true; + end end);