Commit b7a2e6e9 authored by guus's avatar guus

OF-479: Now includes OS info in jabber:iq:version responses (security settings permitting).

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/trunk@12838 b35dd754-fafc-0310-a699-88a17e54d16e
parent 55d8c08f
...@@ -52,8 +52,7 @@ public class IQVersionHandler extends IQHandler implements ServerFeaturesProvide ...@@ -52,8 +52,7 @@ public class IQVersionHandler extends IQHandler implements ServerFeaturesProvide
if (bodyElement == null) { if (bodyElement == null) {
bodyElement = DocumentHelper.createElement(QName.get("query", "jabber:iq:version")); bodyElement = DocumentHelper.createElement(QName.get("query", "jabber:iq:version"));
bodyElement.addElement("name").setText(AdminConsole.getAppName()); bodyElement.addElement("name").setText(AdminConsole.getAppName());
bodyElement.addElement("os").setText("Java " + System.getProperty("java.version")); bodyElement.addElement("version").setText(AdminConsole.getVersionString());
bodyElement.addElement("version");
} }
} }
...@@ -62,13 +61,22 @@ public class IQVersionHandler extends IQHandler implements ServerFeaturesProvide ...@@ -62,13 +61,22 @@ public class IQVersionHandler extends IQHandler implements ServerFeaturesProvide
if (IQ.Type.get == packet.getType()) { if (IQ.Type.get == packet.getType()) {
// Could cache this information for every server we see // Could cache this information for every server we see
Element answerElement = bodyElement.createCopy(); Element answerElement = bodyElement.createCopy();
answerElement.element("name").setText(AdminConsole.getAppName()); try {
answerElement.element("version").setText(AdminConsole.getVersionString()); // Try to retrieve this for every request - security settings
// might be changed runtime!
final String os = System.getProperty("os.name") + ' '
+ System.getProperty("os.version") + " ("
+ System.getProperty("os.arch") + ')';
final String java = "Java " + System.getProperty("java.version");
answerElement.addElement("os").setText(os + " - " + java);
} catch (SecurityException ex) {
// Security settings don't allow the OS to be read. We'll honor
// this and simply not report it.
}
IQ result = IQ.createResultIQ(packet); IQ result = IQ.createResultIQ(packet);
result.setChildElement(answerElement); result.setChildElement(answerElement);
return result; return result;
} } else if (IQ.Type.set == packet.getType()) {
else if (IQ.Type.set == packet.getType()) {
// Answer an not-acceptable error since IQ should be of type GET // Answer an not-acceptable error since IQ should be of type GET
IQ result = IQ.createResultIQ(packet); IQ result = IQ.createResultIQ(packet);
result.setError(PacketError.Condition.not_acceptable); result.setError(PacketError.Condition.not_acceptable);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment