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;
import org.jivesoftware.openfire.muc.cluster.UpdateHistoryStrategy;
import org.jivesoftware.openfire.muc.spi.MUCPersistenceManager;
import org.jivesoftware.util.JiveGlobals;
import org.jivesoftware.util.cache.CacheFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
......@@ -334,12 +335,20 @@ public class HistoryStrategy {
// 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
// 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.
return Message.Type.groupchat == message.getType() &&
message.getSubject() != null &&
message.getBody() == null &&
message.getThread() == null;
(!isSubjectChangeStrict() ||
(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> {
......
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