Changeset

9249:506aabdb13bc

mod_vcard_legacy: Responds to vcard-temp queries with translated vcard4 data
author Kim Alvefur <zash@zash.se>
date Tue, 21 Aug 2018 16:40:40 +0200
parents 9248:1d6a2cc389eb
children 9250:9a8006f9e983
files CHANGES plugins/mod_vcard_legacy.lua
diffstat 2 files changed, 56 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- a/CHANGES	Thu Feb 15 03:00:32 2018 +0100
+++ b/CHANGES	Tue Aug 21 16:40:40 2018 +0200
@@ -20,6 +20,7 @@
 -   Asynchronous operations
 -   Busted for tests
 -   mod\_muc\_mam (XEP-0313 in groupchats)
+-   mod\_vcard\_legacy
 
 0.10.0
 ======
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/plugins/mod_vcard_legacy.lua	Tue Aug 21 16:40:40 2018 +0200
@@ -0,0 +1,55 @@
+local st = require "util.stanza"
+local jid_split = require "util.jid".split;
+
+local mod_pep = module:depends("pep");
+
+module:add_feature("vcard-temp");
+module:add_feature("urn:xmpp:pep-vcard-conversion:0");
+
+-- Simple translations
+-- <foo><text>hey</text></foo> -> <FOO>hey</FOO>
+local simple_map = {
+	nickname = "text";
+	title = "text";
+	role = "text";
+	categories = "text";
+	note = "text";
+	url = "uri";
+	bday = "date";
+}
+
+module:hook("iq-get/bare/vcard-temp: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, vcard4_item = pep_service:get_last_item("urn:xmpp:vcard4", stanza.attr.from);
+
+	local vcard_temp = st.stanza("vCard", { xmlns = "vcard-temp" });
+	if ok and vcard4_item then
+		local vcard4 = vcard4_item.tags[1];
+
+		local fn = vcard4:get_child("fn");
+		vcard_temp:text_tag("FN", fn and fn:get_child_text("text"));
+
+		local v4n = vcard4:get_child("n");
+		vcard_temp:tag("N")
+			:text_tag("FAMILY", v4n and v4n:get_child_text("surname"))
+			:text_tag("GIVEN", v4n and v4n:get_child_text("given"))
+			:text_tag("MIDDLE", v4n and v4n:get_child_text("additional"))
+			:text_tag("PREFIX", v4n and v4n:get_child_text("prefix"))
+			:text_tag("SUFFIX", v4n and v4n:get_child_text("suffix"))
+			:up();
+
+		for tag in vcard4:childtags() do
+			local typ = simple_map[tag.name];
+			if typ then
+				local text = tag:get_child_text(typ);
+				if text then
+					vcard_temp:text_tag(tag.name:upper(), text);
+				end
+			end
+		end
+	end
+
+	origin.send(st.reply(stanza):add_child(vcard_temp));
+	return true;
+end);