X-Git-Url: https://git.enpas.org/?a=blobdiff_plain;ds=sidebyside;f=plugins%2Fmod_message.lua;h=e85da613198d2a17a52e3b5acc7c8a00e4b8aa4e;hb=5a1000e8e61beb0c9ecf56ad9342d5b7031f9b49;hp=bd4e353a64708885721d363ac960b9a6cd98b760;hpb=7739b81877ad3e76ab902c9ad199638c470cf473;p=prosody.git diff --git a/plugins/mod_message.lua b/plugins/mod_message.lua index bd4e353a..e85da613 100644 --- a/plugins/mod_message.lua +++ b/plugins/mod_message.lua @@ -7,14 +7,13 @@ -- -local full_sessions = full_sessions; -local bare_sessions = bare_sessions; +local full_sessions = prosody.full_sessions; +local bare_sessions = prosody.bare_sessions; local st = require "util.stanza"; local jid_bare = require "util.jid".bare; local jid_split = require "util.jid".split; local user_exists = require "core.usermanager".user_exists; -local t_insert = table.insert; local function process_to_bare(bare, origin, stanza) local user = bare_sessions[bare]; @@ -36,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 @@ -48,7 +50,7 @@ local function process_to_bare(bare, origin, stanza) if user_exists(node, host) then -- TODO apply the default privacy list - ok = module:fire_event('message/offline/store', { + ok = module:fire_event('message/offline/handle', { origin = origin, stanza = stanza, }); @@ -66,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);