More error replies for offline and non-existing users
[prosody.git] / util / discohelper.lua
index 4d3bc3f63c6e04532c7f24f3ef842d20cfde1839..56dfd5d0ca38e8d359fbe9f210d17204b0be57fa 100644 (file)
@@ -1,4 +1,4 @@
--- Prosody IM v0.1
+-- Prosody IM v0.2
 -- Copyright (C) 2008 Matthew Wild
 -- Copyright (C) 2008 Waqas Hussain
 -- 
@@ -57,20 +57,8 @@ local function handle(self, stanza)
                elseif query.attr.xmlns == "http://jabber.org/protocol/disco#items" then\r
                        handlers = self.item_handlers;\r
                end\r
-               local handler = handlers[to]; -- get the handler\r
-               if not handler then -- if not found then use default handler\r
-                       if to_node then\r
-                               handler = handlers["*defaultnode"];\r
-                       else\r
-                               handler = handlers["*defaulthost"];\r
-                       end\r
-               end\r
-               local found; -- to keep track of any handlers found\r
-               if handler then\r
-                       for _, h in ipairs(handler) do\r
-                               if h(reply, to, from, node) then found = true; end\r
-                       end\r
-               end\r
+               local handler;
+               local found; -- to keep track of any handlers found
                if to_node then -- handlers which get called always\r
                        handler = handlers["*node"];\r
                else\r
@@ -81,6 +69,19 @@ local function handle(self, stanza)
                                if h(reply, to, from, node) then found = true; end\r
                        end\r
                end\r
+               handler = handlers[to]; -- get the handler
+               if not handler then -- if not found then use default handler
+                       if to_node then
+                               handler = handlers["*defaultnode"];
+                       else
+                               handler = handlers["*defaulthost"];
+                       end
+               end
+               if handler then
+                       for _, h in ipairs(handler) do
+                               if h(reply, to, from, node) then found = true; end
+                       end
+               end
                if found then return reply; end -- return the reply if there was one\r
                return st.error_reply(stanza, "cancel", "service-unavailable");\r
        end\r