Merge 0.9->0.10
[prosody.git] / plugins / mod_private.lua
1 -- Prosody IM
2 -- Copyright (C) 2008-2010 Matthew Wild
3 -- Copyright (C) 2008-2010 Waqas Hussain
4 --
5 -- This project is MIT/X11 licensed. Please see the
6 -- COPYING file in the source package for more information.
7 --
8
9
10 local st = require "util.stanza"
11
12 local private_storage = module:open_store();
13
14 module:add_feature("jabber:iq:private");
15
16 module:hook("iq/self/jabber:iq:private:query", function(event)
17         local origin, stanza = event.origin, event.stanza;
18         local query = stanza.tags[1];
19         if #query.tags ~= 1 then
20                 return origin.send(st.error_reply(stanza, "modify", "bad-format"));
21         end
22         local tag = query.tags[1];
23         local key = tag.name..":"..tag.attr.xmlns;
24         local data, err = private_storage:get(origin.username);
25         if err then
26                 return origin.send(st.error_reply(stanza, "wait", "internal-server-error", err));
27         end
28         if stanza.attr.type == "get" then
29                 if data and data[key] then
30                         return origin.send(st.reply(stanza):query("jabber:iq:private"):add_child(st.deserialize(data[key])));
31                 else
32                         return origin.send(st.reply(stanza):add_child(query));
33                 end
34         else -- type == set
35                 if not data then data = {}; end;
36                 if #tag == 0 then
37                         data[key] = nil;
38                 else
39                         data[key] = st.preserialize(tag);
40                 end
41                 -- TODO delete datastore if empty
42                 local ok, err = private_storage:set(origin.username, data);
43                 if not ok then
44                         return origin.send(st.error_reply(stanza, "wait", "internal-server-error", err));
45                 end
46                 return origin.send(st.reply(stanza));
47         end
48 end);