Commit bc5faf4b authored by Tom Evans's avatar Tom Evans

OF-122: MUC subject change policy

Default to lenient policy, allowing override to strict (conforming)
policy. Tested using Pidgin, Psi, and Exodus. Refer to details in
OF-122.
parent 80386d5f
...@@ -29,6 +29,7 @@ import java.util.concurrent.ConcurrentLinkedQueue; ...@@ -29,6 +29,7 @@ import java.util.concurrent.ConcurrentLinkedQueue;
import org.jivesoftware.openfire.muc.cluster.UpdateHistoryStrategy; import org.jivesoftware.openfire.muc.cluster.UpdateHistoryStrategy;
import org.jivesoftware.openfire.muc.spi.MUCPersistenceManager; import org.jivesoftware.openfire.muc.spi.MUCPersistenceManager;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.cache.CacheFactory; import org.jivesoftware.util.cache.CacheFactory;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
...@@ -334,12 +335,20 @@ public class HistoryStrategy { ...@@ -334,12 +335,20 @@ public class HistoryStrategy {
// The subject is changed by sending a message of type "groupchat" to the <room@service>, // The subject is changed by sending a message of type "groupchat" to the <room@service>,
// where the <message/> MUST contain a <subject/> element that specifies the new subject // where the <message/> MUST contain a <subject/> element that specifies the new subject
// but MUST NOT contain a <body/> element (or a <thread/> element). // but MUST NOT contain a <body/> element (or a <thread/> element).
// Unfortunately, many clients do not follow these strict guidelines from the specs, so we
// implement a lenient policy for detecting subject change requests by default. This can
// be overridden by setting the "xmpp.muc.subject.change.strict" property to true.
// An empty <subject/> value means that the room subject should be removed. // An empty <subject/> value means that the room subject should be removed.
return Message.Type.groupchat == message.getType() && return Message.Type.groupchat == message.getType() &&
message.getSubject() != null && message.getSubject() != null &&
message.getBody() == null && (!isSubjectChangeStrict() ||
message.getThread() == null; (message.getBody() == null &&
message.getThread() == null));
}
private boolean isSubjectChangeStrict() {
return JiveGlobals.getBooleanProperty("xmpp.muc.subject.change.strict", false);
} }
private static class MessageComparator implements Comparator<Message> { private static class MessageComparator implements Comparator<Message> {
......
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