aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthew Wild <mwild1@gmail.com>2012-07-22 16:59:55 +0100
committerMatthew Wild <mwild1@gmail.com>2012-07-22 16:59:55 +0100
commit5efb7f0824efc81a06c0d9f9d139bc41637d9fd7 (patch)
treecb7ebed0a2760f8dffd2dd87e09cc3718786cc70
parentefc4ec5efea1a4160a2651973e5cf5f5a2c3b6c3 (diff)
downloadprosody-5efb7f0824efc81a06c0d9f9d139bc41637d9fd7.tar.gz
prosody-5efb7f0824efc81a06c0d9f9d139bc41637d9fd7.zip
mod_message: Don't treat a message as delivered ok if session.send() returns false
-rw-r--r--plugins/mod_message.lua11
1 files changed, 6 insertions, 5 deletions
diff --git a/plugins/mod_message.lua b/plugins/mod_message.lua
index ebff2fe7..0b0ad8e4 100644
--- a/plugins/mod_message.lua
+++ b/plugins/mod_message.lua
@@ -35,10 +35,13 @@ local function process_to_bare(bare, origin, stanza)
if user then -- some resources are connected
local recipients = user.top_resources;
if recipients then
+ local sent;
for i=1,#recipients do
- recipients[i].send(stanza);
+ sent = recipients[i].send(stanza) or sent;
+ end
+ if sent then
+ return true;
end
- return true;
end
end
-- no resources are online
@@ -65,9 +68,7 @@ module:hook("message/full", function(data)
local origin, stanza = data.origin, data.stanza;
local session = full_sessions[stanza.attr.to];
- if session then
- -- TODO fire post processing event
- session.send(stanza);
+ if session and session.send(stanza) then
return true;
else -- resource not online
return process_to_bare(jid_bare(stanza.attr.to), origin, stanza);