package com.sissi.pipeline.in.iq.muc.owner;
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.Forbidden;
import com.sissi.protocol.muc.ItemAffiliation;
import com.sissi.ucenter.relation.muc.MucRelation;
/**
* 岗位校验(OWNER,并且房间已激活)
*
* @author kim 2014年3月27日
*/
public class MucOwnerCheckRelationProcessor extends ProxyProcessor {
private final Error error = new ServerError().type(ProtocolType.AUTH).add(Forbidden.DETAIL);
@Override
public boolean input(JIDContext context, Protocol protocol) {
MucRelation relation = super.ourRelation(context.jid(), super.build(protocol.parent().getTo())).cast(MucRelation.class);
return relation.activate() && ItemAffiliation.OWNER.equals(relation.affiliation()) ? true : this.writeAndReturn(context, protocol);
}
private boolean writeAndReturn(JIDContext context, Protocol protocol) {
context.write(protocol.parent().reply().setError(this.error));
return false;
}
}