aboutsummaryrefslogtreecommitdiffstats
path: root/plugins
diff options
context:
space:
mode:
authorWaqas Hussain <waqas20@gmail.com>2009-10-18 18:45:41 +0500
committerWaqas Hussain <waqas20@gmail.com>2009-10-18 18:45:41 +0500
commit934db1b4047005d1b22dde67d81d41d74b329c5e (patch)
treea2d102527f4eadc0cc349a584d2e1d1f9b7e187b /plugins
parent5ea99e76f056144ada624a9ba0bcf14a909bb322 (diff)
downloadprosody-934db1b4047005d1b22dde67d81d41d74b329c5e.tar.gz
prosody-934db1b4047005d1b22dde67d81d41d74b329c5e.zip
mod_time: Updated to use events (which also fixes a few minor issues).
Diffstat (limited to 'plugins')
-rw-r--r--plugins/mod_time.lua40
1 files changed, 23 insertions, 17 deletions
diff --git a/plugins/mod_time.lua b/plugins/mod_time.lua
index 26088396..7d900ae9 100644
--- a/plugins/mod_time.lua
+++ b/plugins/mod_time.lua
@@ -6,8 +6,6 @@
-- COPYING file in the source package for more information.
--
-
-
local st = require "util.stanza";
local datetime = require "util.datetime".datetime;
local legacy = require "util.datetime".legacy;
@@ -16,23 +14,31 @@ local legacy = require "util.datetime".legacy;
module:add_feature("urn:xmpp:time");
-module:add_iq_handler({"c2s", "s2sin"}, "urn:xmpp:time",
- function(session, stanza)
- if stanza.attr.type == "get" then
- session.send(st.reply(stanza):tag("time", {xmlns="urn:xmpp:time"})
- :tag("tzo"):text("+00:00"):up() -- FIXME get the timezone in a platform independent fashion
- :tag("utc"):text(datetime()));
- end
- end);
+local function time_handler(event)
+ local origin, stanza = event.origin, event.stanza;
+ if stanza.attr.type == "get" then
+ origin.send(st.reply(stanza):tag("time", {xmlns="urn:xmpp:time"})
+ :tag("tzo"):text("+00:00"):up() -- TODO get the timezone in a platform independent fashion
+ :tag("utc"):text(datetime()));
+ return true;
+ end
+end
+
+module:hook("iq/bare/urn:xmpp:time:time", time_handler);
+module:hook("iq/host/urn:xmpp:time:time", time_handler);
-- XEP-0090: Entity Time (deprecated)
module:add_feature("jabber:iq:time");
-module:add_iq_handler({"c2s", "s2sin"}, "jabber:iq:time",
- function(session, stanza)
- if stanza.attr.type == "get" then
- session.send(st.reply(stanza):tag("query", {xmlns="jabber:iq:time"})
- :tag("utc"):text(legacy()));
- end
- end);
+local function legacy_time_handler(event)
+ local origin, stanza = event.origin, event.stanza;
+ if stanza.attr.type == "get" then
+ origin.send(st.reply(stanza):tag("query", {xmlns="jabber:iq:time"})
+ :tag("utc"):text(legacy()));
+ return true;
+ end
+end
+
+module:hook("iq/bare/jabber:iq:time:query", legacy_time_handler);
+module:hook("iq/host/jabber:iq:time:query", legacy_time_handler);