MUC: Fixed: Unavilable presence was not being broadcasted for banned users in some...
[prosody.git] / plugins / mod_version.lua
index ff8f7539ac61509f8d785c8fdae65b7cfd912e7e..f3c5c1903376e5663a5b0bcdeb673a83e06ff147 100644 (file)
@@ -1,19 +1,40 @@
+-- Prosody IM
+-- Copyright (C) 2008-2010 Matthew Wild
+-- Copyright (C) 2008-2010 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 send = require "core.sessionmanager".send_to_session;
 
-local log = require "util.logger".init("mod_version");
+module:add_feature("jabber:iq:version");
 
-local xmlns_version = "jabber:iq:version"
+local version = "the best operating system ever!";
 
-local function handle_version_request(session, stanza)
-       if stanza.attr.type == "get" then
-               session.send(st.reply(stanza):query(xmlns_version)
-                       :tag("name"):text("lxmppd"):up()
-                       :tag("version"):text("pre-alpha"):up()
-                       :tag("os"):text("the best operating system ever!"));
+local query = st.stanza("query", {xmlns = "jabber:iq:version"})
+       :tag("name"):text("Prosody"):up()
+       :tag("version"):text(prosody.version):up();
+
+if not module:get_option("hide_os_type") then
+       if os.getenv("WINDIR") then
+               version = "Windows";
+       else
+               local uname = io.popen(module:get_option("os_version_command") or "uname");
+               if uname then
+                       version = uname:read("*a");
+               else
+                       version = "an OS";
+               end
        end
+       version = version:match("^%s*(.-)%s*$") or version;
+       query:tag("os"):text(version):up();
 end
 
-add_iq_handler("c2s", xmlns_version, handle_version_request);
-add_iq_handler("s2sin", xmlns_version, handle_version_request);
+module:hook("iq/host/jabber:iq:version:query", function(event)
+       local stanza = event.stanza;
+       if stanza.attr.type == "get" and stanza.attr.to == module.host then
+               event.origin.send(st.reply(stanza):add_child(query));
+               return true;
+       end
+end);