X-Git-Url: https://git.enpas.org/?a=blobdiff_plain;f=plugins%2Fmod_version.lua;h=f3c5c1903376e5663a5b0bcdeb673a83e06ff147;hb=3ea4e9da6700b0032e4002f6804040f501581da2;hp=2f68fa07d51a4fb61f82ea6a4a057989ce0189de;hpb=b9c54461bf031f807fa67f9730a3f1e04eb052a0;p=prosody.git diff --git a/plugins/mod_version.lua b/plugins/mod_version.lua index 2f68fa07..f3c5c190 100644 --- a/plugins/mod_version.lua +++ b/plugins/mod_version.lua @@ -1,20 +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 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!"; -require "core.discomanager".set("version", xmlns_version); +local query = st.stanza("query", {xmlns = "jabber:iq:version"}) + :tag("name"):text("Prosody"):up() + :tag("version"):text(prosody.version):up(); -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!")); +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);