aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/mod_private.lua
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2015-09-22 01:31:52 +0200
committerKim Alvefur <zash@zash.se>2015-09-22 01:31:52 +0200
commit5dcb0569722d6feea8942fd5acc8af7805060f8b (patch)
treef6ad57a51df3f189d7ece7f43682e7ccd147537c /plugins/mod_private.lua
parent9b97c52790a17ea25e0e7ab96fe62280e4dbfea8 (diff)
parent366a13d95f528d6dba5e5ae05910fe6675c28df9 (diff)
downloadprosody-5dcb0569722d6feea8942fd5acc8af7805060f8b.tar.gz
prosody-5dcb0569722d6feea8942fd5acc8af7805060f8b.zip
Merge 0.10->trunk
Diffstat (limited to 'plugins/mod_private.lua')
-rw-r--r--plugins/mod_private.lua16
1 files changed, 10 insertions, 6 deletions
diff --git a/plugins/mod_private.lua b/plugins/mod_private.lua
index 05f05708..9375cf80 100644
--- a/plugins/mod_private.lua
+++ b/plugins/mod_private.lua
@@ -17,19 +17,21 @@ module:hook("iq/self/jabber:iq:private:query", function(event)
local origin, stanza = event.origin, event.stanza;
local query = stanza.tags[1];
if #query.tags ~= 1 then
- return origin.send(st.error_reply(stanza, "modify", "bad-format"));
+ origin.send(st.error_reply(stanza, "modify", "bad-format"));
+ return true;
end
local tag = query.tags[1];
local key = tag.name..":"..tag.attr.xmlns;
if stanza.attr.type == "get" then
local data, err = private_storage:get(origin.username, key);
if data then
- return origin.send(st.reply(stanza):query("jabber:iq:private"):add_child(st.deserialize(data)));
+ origin.send(st.reply(stanza):query("jabber:iq:private"):add_child(st.deserialize(data)));
elseif err then
- return origin.send(st.error_reply(stanza, "wait", "internal-server-error", err));
+ origin.send(st.error_reply(stanza, "wait", "internal-server-error", err));
else
- return origin.send(st.reply(stanza):add_child(query));
+ origin.send(st.reply(stanza):add_child(query));
end
+ return true;
else -- type == set
local data;
if #tag ~= 0 then
@@ -38,8 +40,10 @@ module:hook("iq/self/jabber:iq:private:query", function(event)
-- TODO delete datastore if empty
local ok, err = private_storage:set(origin.username, key, data);
if not ok then
- return origin.send(st.error_reply(stanza, "wait", "internal-server-error", err));
+ origin.send(st.error_reply(stanza, "wait", "internal-server-error", err));
+ return true;
end
- return origin.send(st.reply(stanza));
+ origin.send(st.reply(stanza));
+ return true;
end
end);