aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthew Wild <mwild1@gmail.com>2010-10-15 18:40:37 +0100
committerMatthew Wild <mwild1@gmail.com>2010-10-15 18:40:37 +0100
commit3b90625e4cfe9d4f83c0e213725ba1d77a0bb4bb (patch)
tree6d943dfe6ba7f0e3465740447820163a4d46ba99
parentad63e1f249fdd453fd93cee76a334329c1f8ccf4 (diff)
parent565c65baa1cf05abd5490aac02024e1ecabdcd3e (diff)
downloadprosody-3b90625e4cfe9d4f83c0e213725ba1d77a0bb4bb.tar.gz
prosody-3b90625e4cfe9d4f83c0e213725ba1d77a0bb4bb.zip
Merge hoelzro->trunk
-rw-r--r--plugins/mod_offline.lua27
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)