Software /
code /
verse
Diff
plugins/vcard_update.lua @ 229:279c0e89c3b3
plugins.vcard_update: Update for util.vcard changes.
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Sun, 06 Nov 2011 20:38:15 +0100 |
parent | 196:eb9d69d3f0b5 |
child | 244:6dbd61ecd5d0 |
line wrap: on
line diff
--- a/plugins/vcard_update.lua Sun Nov 06 20:04:19 2011 +0100 +++ b/plugins/vcard_update.lua Sun Nov 06 20:38:15 2011 +0100 @@ -31,13 +31,17 @@ local x_vcard_update; function update_vcard_photo(vCard) - local photo = vCard and vCard:get_child("PHOTO"); - local binval = photo and photo:get_child("BINVAL"); - local data = binval and binval:get_text(); + local data; + for i=1,#vCard do + if vCard[i].name == "PHOTO" then + data = vCard[i][1]; + break + end + end if data then local hash = sha1(unb64(data), true); x_vcard_update = verse.stanza("x", { xmlns = xmlns_vcard_update }) - :tag("photo"):text(hash); + :tag("photo"):text(hash); stream:resend_presence() else @@ -70,12 +74,8 @@ initial_vcard_fetch_started = true; -- if stream:jid_supports(nil, xmlns_vcard) then TODO this, correctly stream:get_vcard(nil, function(response) - -- FIXME Picking out the vCard element should be done in get_vcard() - if response.attr.type == "result" then - local vCard = response:get_child("vCard", xmlns_vcard); - if vCard then - update_vcard_photo(vCard); - end + if response then + update_vcard_photo(response) end stream:event("ready"); end);