diff options
author | Kim Alvefur <zash@zash.se> | 2015-09-22 01:31:52 +0200 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2015-09-22 01:31:52 +0200 |
commit | 5dcb0569722d6feea8942fd5acc8af7805060f8b (patch) | |
tree | f6ad57a51df3f189d7ece7f43682e7ccd147537c /plugins/mod_private.lua | |
parent | 9b97c52790a17ea25e0e7ab96fe62280e4dbfea8 (diff) | |
parent | 366a13d95f528d6dba5e5ae05910fe6675c28df9 (diff) | |
download | prosody-5dcb0569722d6feea8942fd5acc8af7805060f8b.tar.gz prosody-5dcb0569722d6feea8942fd5acc8af7805060f8b.zip |
Merge 0.10->trunk
Diffstat (limited to 'plugins/mod_private.lua')
-rw-r--r-- | plugins/mod_private.lua | 16 |
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); |