File

plugins/ping.lua @ 240:e27bf761bea6

verse: set_log_handler(): Allow nil to be passed for log_handler to disable logging (the default).
author Matthew Wild <mwild1@gmail.com>
date Sun, 27 Nov 2011 22:50:21 +0000
parent 147:c95b84ed366b
child 250:a5ac643a7fd6
line wrap: on
line source

local xmlns_ping = "urn:xmpp:ping";

function verse.plugins.ping(stream)
	function stream:ping(jid, callback)
		local t = socket.gettime();
		stream:send_iq(verse.iq{ to = jid, type = "get" }:tag("ping", { xmlns = xmlns_ping }), 
			function (reply)
				if reply.attr.type == "error" then
					local type, condition, text = reply:get_error();
					if condition ~= "service-unavailable" and condition ~= "feature-not-implemented" then
						callback(nil, jid, { type = type, condition = condition, text = text });
						return;
					end
				end
				callback(socket.gettime()-t, jid);
			end);
	end
	return true;
end