Mercurial > xmpp-account-manager
diff vcard.js @ 31:e561bdd81777
Display better vCard4 errors.
author | Emmanuel Gil Peyrot <linkmauve@linkmauve.fr> |
---|---|
date | Sun, 23 Dec 2018 18:20:17 +0100 |
parents | 9ba4f8cc32f1 |
children | b15e1581c3d4 |
line wrap: on
line diff
--- a/vcard.js +++ b/vcard.js @@ -14,17 +14,17 @@ function initVCard(connection) { .c('pubsub', {xmlns: 'http://jabber.org/protocol/pubsub'}) .c('items', {node: 'urn:xmpp:vcard4'}) .c('item', {id: 'current'}); - connection.sendIQ(iq, onVCard4, onVCard4RetrievalError.bind(null, 'PubSub query failed.')); + connection.sendIQ(iq, onVCard4, onVCard4RetrievalError); displaySpinner(spinner_img); function onVCard4(result_iq) { const item = parseXPath(result_iq, './pubsub:pubsub/pubsub:items/pubsub:item'); if (item === null) - return onVCard4RetrievalError('no item found.'); + return onVCard4RetrievalError(null, 'no item found.'); const vcard = parseXPath(item, './vcard4:vcard'); if (vcard === null) - return onVCard4RetrievalError('no vCard4 found, your PubSub node is broken.'); + return onVCard4RetrievalError(null, 'no vCard4 found, your PubSub node is broken.'); vcard_data.fn = parseXPathText(vcard, './vcard4:fn/vcard4:text'); vcard_data.email = parseXPathText(vcard, './vcard4:email/vcard4:text'); @@ -39,9 +39,14 @@ function initVCard(connection) { hideSpinner(spinner_img); } - function onVCard4RetrievalError(string) + function onVCard4RetrievalError(iq, string) { - console.log('Failed to retrieve vCard4: ' + string); + if (!string) { + const [condition, text] = parseErrorIq(iq); + const string = condition + ': ' + text; + } + string = 'Failed to retrieve vCard4: ' + string; + console.log(string); vcard_fn.disabled = false; vcard_email.disabled = false; vcard_bday.disabled = false;