diff options
author | Waqas Hussain <waqas20@gmail.com> | 2009-10-18 19:42:45 +0500 |
---|---|---|
committer | Waqas Hussain <waqas20@gmail.com> | 2009-10-18 19:42:45 +0500 |
commit | 8d0f16c431c0557cf2de3bb2aa8e08d99da1df53 (patch) | |
tree | c0fc9187b52e45b21ffea3d64b82420543b73630 /plugins/mod_uptime.lua | |
parent | 23ff2cf40e39193700e4e0424ba5d482a6f095af (diff) | |
download | prosody-8d0f16c431c0557cf2de3bb2aa8e08d99da1df53.tar.gz prosody-8d0f16c431c0557cf2de3bb2aa8e08d99da1df53.zip |
mod_uptime: Updated to use events (which also fixes a few minor issues).
Diffstat (limited to 'plugins/mod_uptime.lua')
-rw-r--r-- | plugins/mod_uptime.lua | 33 |
1 files changed, 15 insertions, 18 deletions
diff --git a/plugins/mod_uptime.lua b/plugins/mod_uptime.lua index eb0ca7cc..2737a9f2 100644 --- a/plugins/mod_uptime.lua +++ b/plugins/mod_uptime.lua @@ -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); |