diff options
author | Matthew Wild <mwild1@gmail.com> | 2010-10-15 18:40:37 +0100 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2010-10-15 18:40:37 +0100 |
commit | 3b90625e4cfe9d4f83c0e213725ba1d77a0bb4bb (patch) | |
tree | 6d943dfe6ba7f0e3465740447820163a4d46ba99 /plugins/mod_offline.lua | |
parent | ad63e1f249fdd453fd93cee76a334329c1f8ccf4 (diff) | |
parent | 565c65baa1cf05abd5490aac02024e1ecabdcd3e (diff) | |
download | prosody-3b90625e4cfe9d4f83c0e213725ba1d77a0bb4bb.tar.gz prosody-3b90625e4cfe9d4f83c0e213725ba1d77a0bb4bb.zip |
Merge hoelzro->trunk
Diffstat (limited to 'plugins/mod_offline.lua')
-rw-r--r-- | plugins/mod_offline.lua | 27 |
1 files changed, 15 insertions, 12 deletions
diff --git a/plugins/mod_offline.lua b/plugins/mod_offline.lua index 24aef9ed..edd14190 100644 --- a/plugins/mod_offline.lua +++ b/plugins/mod_offline.lua @@ -34,18 +34,21 @@ end); module:hook("message/offline/broadcast", function(event) local origin = event.origin; - local node, host = origin.username, origin.host; - - local data = datamanager.list_load(node, host, "offline"); - if not data then return true; end - for _, stanza in ipairs(data) do - stanza = st.deserialize(stanza); - stanza:tag("delay", {xmlns = "urn:xmpp:delay", from = host, stamp = stanza.attr.stamp}):up(); -- XEP-0203 - stanza:tag("x", {xmlns = "jabber:x:delay", from = host, stamp = stanza.attr.stamp_legacy}):up(); -- XEP-0091 (deprecated) - stanza.attr.stamp, stanza.attr.stamp_legacy = nil, nil; - origin.send(stanza); - end - return true; + + if origin.priority >= 0 then + local node, host = origin.username, origin.host; + + local data = datamanager.list_load(node, host, "offline"); + if not data then return true; end + for _, stanza in ipairs(data) do + stanza = st.deserialize(stanza); + stanza:tag("delay", {xmlns = "urn:xmpp:delay", from = host, stamp = stanza.attr.stamp}):up(); -- XEP-0203 + stanza:tag("x", {xmlns = "jabber:x:delay", from = host, stamp = stanza.attr.stamp_legacy}):up(); -- XEP-0091 (deprecated) + stanza.attr.stamp, stanza.attr.stamp_legacy = nil, nil; + origin.send(stanza); + end + return true; + end end); module:hook("message/offline/delete", function(event) |