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,31 +52,39 @@ public class IQVersionHandler extends IQHandler implements ServerFeaturesProvide ...@@ -52,31 +52,39 @@ 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");
} }
} }
@Override @Override
public IQ handleIQ(IQ packet) throws PacketException { public IQ handleIQ(IQ packet) throws PacketException {
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
IQ result = IQ.createResultIQ(packet); // might be changed runtime!
result.setChildElement(answerElement); final String os = System.getProperty("os.name") + ' '
return result; + System.getProperty("os.version") + " ("
} + System.getProperty("os.arch") + ')';
else if (IQ.Type.set == packet.getType()) { final String java = "Java " + System.getProperty("java.version");
// Answer an not-acceptable error since IQ should be of type GET answerElement.addElement("os").setText(os + " - " + java);
IQ result = IQ.createResultIQ(packet); } catch (SecurityException ex) {
result.setError(PacketError.Condition.not_acceptable); // Security settings don't allow the OS to be read. We'll honor
return result; // this and simply not report it.
} }
// Ignore any other type of packet IQ result = IQ.createResultIQ(packet);
return null; result.setChildElement(answerElement);
} return result;
} else if (IQ.Type.set == packet.getType()) {
// Answer an not-acceptable error since IQ should be of type GET
IQ result = IQ.createResultIQ(packet);
result.setError(PacketError.Condition.not_acceptable);
return result;
}
// Ignore any other type of packet
return null;
}
@Override @Override
public IQHandlerInfo getInfo() { public IQHandlerInfo getInfo() {
......
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