mod_uptime: Updated to use events (which also fixes a few minor issues).

Sun, 18 Oct 2009 19:42:45 +0500

author
Waqas Hussain <waqas20@gmail.com>
date
Sun, 18 Oct 2009 19:42:45 +0500
changeset 2015
2140c994671e
parent 2014
913c0845ef9a
child 2016
5d47cfa4b2a0

mod_uptime: Updated to use events (which also fixes a few minor issues).

plugins/mod_uptime.lua file | annotate | diff | comparison | revisions
--- a/plugins/mod_uptime.lua	Sun Oct 18 18:50:35 2009 +0500
+++ b/plugins/mod_uptime.lua	Sun Oct 18 19:42:45 2009 +0500
@@ -6,30 +6,27 @@
 -- COPYING file in the source package for more information.
 --
 
-
-
 local st = require "util.stanza"
 
 local jid_split = require "util.jid".split;
 local t_concat = table.concat;
 
 local start_time = prosody.start_time;
-
-prosody.events.add_handler("server-started", function () start_time = prosody.start_time end);
+prosody.events.add_handler("server-started", function() start_time = prosody.start_time end);
 
 module:add_feature("jabber:iq:last");
 
-module:add_iq_handler({"c2s", "s2sin"}, "jabber:iq:last", 
-	function (origin, stanza)
-		if stanza.tags[1].name == "query" then
-			if stanza.attr.type == "get" then
-				local node, host, resource = jid_split(stanza.attr.to);
-				if node or resource then
-					-- TODO
-				else
-					origin.send(st.reply(stanza):tag("query", {xmlns = "jabber:iq:last", seconds = tostring(os.difftime(os.time(), start_time))}));
-					return true;
-				end
-			end
-		end
-	end);
+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);
+
+module:hook("iq/bare/jabber:iq:last:query", function(event)
+	local origin, stanza = event.origin, event.stanza;
+	if stanza.attr.type == "get" then
+		-- TODO last activity
+	end
+end);

mercurial