plugins/mod_uptime.lua

Fri, 20 Nov 2009 04:39:54 +0000

author
Matthew Wild <mwild1@gmail.com>
date
Fri, 20 Nov 2009 04:39:54 +0000
changeset 2089
fdd7280c4621
parent 2017
347799c9caa6
child 2923
b7049746bd29
permissions
-rw-r--r--

s2smanager: Queue db:verify unless we already sent a db:result (if we had then it can could a dialback deadlock). Also remove some redundant code which could cause a db:result to be sent while still negotiating features (e.g. TLS) and break things. Collectively these fix a 'random' s2s failure (usually with ejabberd for some reason) - resulting in an 'unbound prefix' XML error, or 'ssl handshake failure'. Was this commit message long enough? I think so.

-- Prosody IM
-- Copyright (C) 2008-2009 Matthew Wild
-- Copyright (C) 2008-2009 Waqas Hussain
-- 
-- This project is MIT/X11 licensed. Please see the
-- COPYING file in the source package for more information.
--

local st = require "util.stanza";

local start_time = prosody.start_time;
prosody.events.add_handler("server-started", function() start_time = prosody.start_time end);

module:add_feature("jabber:iq:last");

module:hook("iq/host/jabber:iq:last:query", function(event)
	local origin, stanza = event.origin, event.stanza;
	if stanza.attr.type == "get" then
		origin.send(st.reply(stanza):tag("query", {xmlns = "jabber:iq:last", seconds = tostring(os.difftime(os.time(), start_time))}));
		return true;
	end
end);

mercurial