From 439b80fc6ee666302ecd7d7d50bdb9c5fa4e12cc Mon Sep 17 00:00:00 2001 From: Waqas Hussain Date: Mon, 10 Nov 2008 01:30:52 +0500 Subject: Hack to allow s2s stanzas to work until we do proper namespace handling --- core/stanza_router.lua | 1 + 1 file changed, 1 insertion(+) diff --git a/core/stanza_router.lua b/core/stanza_router.lua index 0a5ff0be..61c2dede 100644 --- a/core/stanza_router.lua +++ b/core/stanza_router.lua @@ -33,6 +33,7 @@ local print = print; function core_process_stanza(origin, stanza) log("debug", "Received["..origin.type.."]: "..tostring(st.reply(st.reply(stanza)))) + if not stanza.attr.xmlns then stanza.attr.xmlns = "jabber:client"; end -- FIXME Hack. This should be removed when we fix namespace handling. -- TODO verify validity of stanza (as well as JID validity) if stanza.name == "iq" and not(#stanza.tags == 1 and stanza.tags[1].attr.xmlns) then if stanza.attr.type == "set" or stanza.attr.type == "get" then -- cgit v1.2.3 From b2a1a80faf383663f9e67f9cc64403bf09d43df3 Mon Sep 17 00:00:00 2001 From: Waqas Hussain Date: Mon, 10 Nov 2008 01:33:37 +0500 Subject: Added mod_uptime: [XEP-0012: Last Activity] queries now work when directed at the server. --- lxmppd.cfg.dist | 1 + plugins/mod_uptime.lua | 25 +++++++++++++++++++++++++ 2 files changed, 26 insertions(+) create mode 100644 plugins/mod_uptime.lua diff --git a/lxmppd.cfg.dist b/lxmppd.cfg.dist index b523c697..59b85b97 100644 --- a/lxmppd.cfg.dist +++ b/lxmppd.cfg.dist @@ -26,5 +26,6 @@ config = { "private"; "version"; "dialback"; + "uptime"; }; } diff --git a/plugins/mod_uptime.lua b/plugins/mod_uptime.lua new file mode 100644 index 00000000..55e5f168 --- /dev/null +++ b/plugins/mod_uptime.lua @@ -0,0 +1,25 @@ + +local st = require "util.stanza" +local send = require "core.sessionmanager".send_to_session + +local jid_split = require "util.jid".split; +local t_concat = table.concat; + +local start_time = os.time(); + +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); + + -- cgit v1.2.3