package com.sissi.pipeline.in.iq.muc.admin.role; import com.sissi.context.JIDContext; import com.sissi.pipeline.in.ProxyProcessor; import com.sissi.protocol.Error; import com.sissi.protocol.Protocol; import com.sissi.protocol.ProtocolType; import com.sissi.protocol.error.ServerError; import com.sissi.protocol.error.detail.Conflict; import com.sissi.protocol.muc.XMucAdmin; /** * 禁止Item列表存在当前MUC JID昵称校验 * * @author kim 2014年3月14日 */ public class MucCheckRoleLoopProcessor extends ProxyProcessor { private final Error error = new ServerError().type(ProtocolType.AUTH).add(Conflict.DETAIL_ELEMENT); @Override public boolean input(JIDContext context, Protocol protocol) { return protocol.cast(XMucAdmin.class).loop(super.ourRelation(context.jid(), super.build(protocol.parent().getTo())).name()) ? this.writeAndReturn(context, protocol) : true; } private boolean writeAndReturn(JIDContext context, Protocol protocol) { context.write(protocol.parent().reply().setError(this.error)); return false; } }