mirror of
https://github.com/bjc/prosody.git
synced 2025-04-06 22:57:38 +03:00
mod_vcard4: Allow access to the vcard4 PEP node via iq syntax
This commit is contained in:
parent
7e0d897777
commit
be40c0664b
2 changed files with 44 additions and 0 deletions
1
CHANGES
1
CHANGES
|
@ -21,6 +21,7 @@ New features
|
|||
- Busted for tests
|
||||
- mod\_muc\_mam (XEP-0313 in groupchats)
|
||||
- mod\_vcard\_legacy (XEP-0398)
|
||||
- mod\_vcard4 (XEP-0292)
|
||||
|
||||
0.10.0
|
||||
======
|
||||
|
|
43
plugins/mod_vcard4.lua
Normal file
43
plugins/mod_vcard4.lua
Normal file
|
@ -0,0 +1,43 @@
|
|||
local st = require "util.stanza"
|
||||
local jid_split = require "util.jid".split;
|
||||
|
||||
local mod_pep = module:depends("pep");
|
||||
|
||||
module:add_feature("urn:ietf:params:xml:ns:vcard-4.0");
|
||||
|
||||
module:hook("iq-get/bare/urn:ietf:params:xml:ns:vcard-4.0:vcard", function (event)
|
||||
local origin, stanza = event.origin, event.stanza;
|
||||
|
||||
local pep_service = mod_pep.get_pep_service(jid_split(stanza.attr.to) or origin.username);
|
||||
local ok, id, item = pep_service:get_last_item("urn:xmpp:vcard4", stanza.attr.from);
|
||||
if ok and item then
|
||||
origin.send(st.reply(stanza):add_child(item.tags[1]));
|
||||
elseif item == "item-not-found" or not id then
|
||||
origin.send(st.error_reply(stanza, "cancel", "item-not-found"));
|
||||
elseif item == "forbidden" then
|
||||
origin.send(st.error_reply(stanza, "auth", "forbidden"));
|
||||
else
|
||||
origin.send(st.error_reply(stanza, "modify", "undefined-condition"));
|
||||
end
|
||||
return true;
|
||||
end);
|
||||
|
||||
module:hook("iq-set/self/urn:ietf:params:xml:ns:vcard-4.0:vcard", function (event)
|
||||
local origin, stanza = event.origin, event.stanza;
|
||||
|
||||
local vcard4 = st.stanza("item", { xmlns = "http://jabber.org/protocol/pubsub", id = "current" })
|
||||
:add_child(stanza.tags[1]);
|
||||
|
||||
local pep_service = mod_pep.get_pep_service(origin.username);
|
||||
|
||||
local ok, err = pep_service:publish("urn:xmpp:vcard4", origin.full_jid, "current", vcard4);
|
||||
if ok then
|
||||
origin.send(st.reply(stanza));
|
||||
elseif err == "forbidden" then
|
||||
origin.send(st.error_reply(stanza, "auth", "forbidden"));
|
||||
else
|
||||
origin.send(st.error_reply(stanza, "modify", "undefined-condition", err));
|
||||
end
|
||||
return true;
|
||||
end);
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue