Commit 41ebedb8 authored by Gaston Dombiak's avatar Gaston Dombiak Committed by gato

Max buffer size is now configurable. JM-1350

git-svn-id: http://svn.igniterealtime.org/svn/repos/openfire/branches@10328 b35dd754-fafc-0310-a699-88a17e54d16e
parent 9468a309
...@@ -12,12 +12,16 @@ ...@@ -12,12 +12,16 @@
package org.jivesoftware.openfire.nio; package org.jivesoftware.openfire.nio;
import org.apache.mina.common.ByteBuffer; import org.apache.mina.common.ByteBuffer;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.Log; import org.jivesoftware.util.Log;
import org.jivesoftware.util.PropertyEventDispatcher;
import org.jivesoftware.util.PropertyEventListener;
import java.nio.CharBuffer; import java.nio.CharBuffer;
import java.nio.charset.Charset; import java.nio.charset.Charset;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Map;
/** /**
* This is a Light-Weight XML Parser. * This is a Light-Weight XML Parser.
...@@ -31,6 +35,8 @@ import java.util.List; ...@@ -31,6 +35,8 @@ import java.util.List;
* @author Gaston Dombiak * @author Gaston Dombiak
*/ */
class XMLLightweightParser { class XMLLightweightParser {
private static final String MAX_PROPERTY_NAME = "xmpp.parser.buffer.size";
private static int maxBufferSize;
// Chars that rappresent CDATA section start // Chars that rappresent CDATA section start
protected static char[] CDATA_START = {'<', '!', '[', 'C', 'D', 'A', 'T', 'A', '['}; protected static char[] CDATA_START = {'<', '!', '[', 'C', 'D', 'A', 'T', 'A', '['};
// Chars that rappresent CDATA section end // Chars that rappresent CDATA section end
...@@ -85,6 +91,13 @@ class XMLLightweightParser { ...@@ -85,6 +91,13 @@ class XMLLightweightParser {
Charset encoder; Charset encoder;
static {
// Set default max buffer size to 1MB. If limit is reached then close connection
maxBufferSize = JiveGlobals.getIntProperty(MAX_PROPERTY_NAME, 1048576);
// Listen for changes to this property
PropertyEventDispatcher.addListener(new PropertyListener());
}
public XMLLightweightParser(String charset) { public XMLLightweightParser(String charset) {
encoder = Charset.forName(charset); encoder = Charset.forName(charset);
} }
...@@ -148,7 +161,7 @@ class XMLLightweightParser { ...@@ -148,7 +161,7 @@ class XMLLightweightParser {
invalidateBuffer(); invalidateBuffer();
// Check that the buffer is not bigger than 1 Megabyte. For security reasons // Check that the buffer is not bigger than 1 Megabyte. For security reasons
// we will abort parsing when 1 Mega of queued chars was found. // we will abort parsing when 1 Mega of queued chars was found.
if (buffer.length() > 1048576) { if (buffer.length() > maxBufferSize) {
throw new Exception("Stopped parsing never ending stanza"); throw new Exception("Stopped parsing never ending stanza");
} }
CharBuffer charBuffer = encoder.decode(byteBuffer.buf()); CharBuffer charBuffer = encoder.decode(byteBuffer.buf());
...@@ -331,4 +344,30 @@ class XMLLightweightParser { ...@@ -331,4 +344,30 @@ class XMLLightweightParser {
foundMsg("</stream:stream>"); foundMsg("</stream:stream>");
} }
} }
private static class PropertyListener implements PropertyEventListener {
public void propertySet(String property, Map<String, Object> params) {
if (MAX_PROPERTY_NAME.equals(property)) { 2
String value = (String) params.get("value");
if (value != null) {
maxBufferSize = Integer.parseInt(value);
}
}
}
public void propertyDeleted(String property, Map<String, Object> params) {
if (MAX_PROPERTY_NAME.equals(property)) {
// Use default value when none was specified
maxBufferSize = 1048576;
}
}
public void xmlPropertySet(String property, Map<String, Object> params) {
// Do nothing
}
public void xmlPropertyDeleted(String property, Map<String, Object> params) {
// Do nothing
}
}
} }
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