Commit dca0472e authored by JC Brand's avatar JC Brand

For archive.query, call callback once after receiving all messages.

updates #306
parent 9abbd1e8
...@@ -552,32 +552,29 @@ ...@@ -552,32 +552,29 @@
* (XMLElement) iq - The IQ stanza returned from the XMPP server. * (XMLElement) iq - The IQ stanza returned from the XMPP server.
* (Object) options - The MAM-specific options of the query ('with', 'start' and 'end') * (Object) options - The MAM-specific options of the query ('with', 'start' and 'end')
* (String) queryid - A unique ID sent with the MAM query. * (String) queryid - A unique ID sent with the MAM query.
* (Function) callback - A function to call whenever we receive query-relevant stanza. * (Function) callback - A function to call after we've received all the archived messages.
* If should expect an array of messages and a Strophe.RSM (result set management) object.
*/ */
var messages = [];
converse.connection.addHandler( converse.connection.addHandler(
function (message) { function (message) {
var rsm, $msg = $(message); var $msg = $(message), $fin;
var $fin = $msg.find('fin[xmlns="'+Strophe.NS.MAM+'"]'); if (typeof callback == "function") {
$fin = $msg.find('fin[xmlns="'+Strophe.NS.MAM+'"]');
if ($fin.length) { if ($fin.length) {
rsm = new Strophe.RSM( callback(
_.extend({xml: $fin.find('set')[0]}, _.pick(options, MAM_ATTRIBUTES)) messages,
new Strophe.RSM(_.extend({xml: $fin.find('set')[0]}, _.pick(options, MAM_ATTRIBUTES)))
); );
callback(message, rsm);
return false; // We've received all messages, decommission this handler return false; // We've received all messages, decommission this handler
} } else if (queryid == $msg.find('result[xmlns="'+Strophe.NS.MAM+'"]').attr('queryid')) {
if (typeof callback == "function") { messages.push(message);
if (queryid == $msg.find('result[xmlns="'+Strophe.NS.MAM+'"]').attr('queryid')) {
callback(message);
} }
return true; return true;
} else { } else {
return false; // There's no callback, so no use in continuing this handler. return false; // There's no callback, so no use in continuing this handler.
} }
}, null, 'message'); }, null, 'message');
if (typeof callback == "function") {
return callback.apply(arguments);
}
}; };
this.getVCard = function (jid, callback, errback) { this.getVCard = function (jid, callback, errback) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment