converse.js
Version:
Browser based XMPP chat client
54 lines (49 loc) • 2.23 kB
JavaScript
import _converse from '../../shared/_converse.js';
import api from '../../shared/api/index.js';
import converse from '../../shared/api/public.js';
import log from "@converse/log";
import { setLastStanzaDate } from './utils.js';
const { Strophe, $iq, u } = converse.env;
export default {
/**
* Pings the entity represented by the passed in JID by sending an IQ stanza to it.
* @method api.ping
* @param {string} [jid] - The JID of the service to ping
* If the ping is sent out to the user's bare JID and no response is received it will attempt to reconnect.
* @param {number} [timeout] - The amount of time in
* milliseconds to wait for a response. The default is 10000;
* @returns {Promise<boolean|null>}
* Whether the pinged entity responded with a non-error IQ stanza.
* If we already know we're not connected, no ping is sent out and `null` is returned.
*/
async ping (jid, timeout) {
if (!api.connection.authenticated()) {
log.debug("Not pinging when we know we're not authenticated");
return null;
}
// XXX: We could first check here if the server advertised that it supports PING.
// However, some servers don't advertise while still responding to pings
// const feature = _converse.disco_entities[_converse.domain].features.findWhere({'var': Strophe.NS.PING});
setLastStanzaDate(new Date());
const bare_jid = _converse.session.get('bare_jid');
jid = jid || Strophe.getDomainFromJid(bare_jid);
const iq = $iq({
'type': 'get',
'to': jid,
'id': u.getUniqueId('ping')
}).c('ping', {'xmlns': Strophe.NS.PING});
const result = await api.sendIQ(iq, timeout || 10000, false);
if (result === null) {
log.warn(`Timeout while pinging ${jid}`);
if (jid === Strophe.getDomainFromJid(bare_jid)) {
api.connection.reconnect();
}
return false;
} else if (u.isErrorStanza(result)) {
log.error(`Error while pinging ${jid}`);
log.error(result);
return false;
}
return true;
}
}