package com.hqyg.disjob.rpc.client.handler;
import io.netty.channel.ChannelFuture;
import io.netty.channel.ChannelFutureListener;
import io.netty.channel.ChannelHandlerContext;
import io.netty.channel.SimpleChannelInboundHandler;
import io.netty.handler.timeout.IdleState;
import io.netty.handler.timeout.IdleStateEvent;
import io.netty.util.ReferenceCountUtil;
import java.util.concurrent.CountDownLatch;
import com.hqyg.disjob.common.util.LoggerUtil;
import com.hqyg.disjob.rpc.codec.EjobResponse;
import com.hqyg.disjob.rpc.codec.EjobRestartTaskResponse;
import com.hqyg.disjob.rpc.codec.Header;
import com.hqyg.disjob.rpc.codec.RpcRequest;
import com.hqyg.disjob.rpc.utils.PhpTaskCmd;
public class EjobRestartResponseHandler extends SimpleChannelInboundHandler<EjobResponse> {
private final boolean autoRelease;
public PhpTaskCmd cmd;
public EjobRestartTaskResponse response;
public CountDownLatch downLatch;
public EjobRestartResponseHandler(PhpTaskCmd cmd,EjobRestartTaskResponse response,CountDownLatch downLatch ) {
autoRelease = true;
this.cmd = cmd;
this.response = response;
this.downLatch = downLatch;
}
@Override
public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception {
boolean release = true;
try {
if (acceptInboundMessage(msg)) {
EjobRestartTaskResponse msgResp = (EjobRestartTaskResponse)msg;
response.setStatus(msgResp.isStatus());
downLatch.countDown();
/*EjobResponse response = null;
//kill task 后面第二版返回值要改成15
switch (cmd.getType()) {
case 15:
response = (RpcKillTaskResponse) msg;
break;
case 14:
response = (EjobRestartTaskResponse) msg;
default:
break;
}*/
//channelRead0(ctx, response);
} else {
release = false;
ctx.fireChannelRead(msg);
}
} finally {
if (autoRelease && release) {
ReferenceCountUtil.release(msg);
}
}
}
@Override
public void channelRead0(ChannelHandlerContext ctx, EjobResponse response) throws Exception {
//LoggerUtil.debug("NettyClient has response from server:"+ response.getRequestId() +",response="+response.toString());
// 将rpc返回结果投递到线程池进行处理
//RpcSpringWorkFactory.getStoreRepThreadPoolService().submit(response);
}
@Override
public void channelReadComplete(ChannelHandlerContext ctx) {
ctx.flush();
}
@Override
public void userEventTriggered(final ChannelHandlerContext ctx, Object evt) throws Exception {
if (IdleStateEvent.class.isAssignableFrom(evt.getClass())) {
IdleStateEvent event = (IdleStateEvent) evt;
if (event.state() == IdleState.ALL_IDLE) {
final RpcRequest request = new RpcRequest();
request.setHeader(new Header((byte) 0, 1, 0));
ChannelFuture writeFuture = ctx.channel().writeAndFlush(request);
writeFuture.addListener(new ChannelFutureListener() {
@Override
public void operationComplete(ChannelFuture future) throws Exception {
String channelId = "";
if (future.isSuccess()) {
LoggerUtil.debug(channelId + " , "+ctx.channel().toString()+" heartbeat request success!");
}
}
});
}
}
}
@Override
public void channelActive(ChannelHandlerContext ctx) throws Exception {
ctx.fireChannelActive();
}
@Override
public void channelInactive(ChannelHandlerContext ctx) throws Exception {
ctx.fireChannelInactive();
}
@Override
public void exceptionCaught(ChannelHandlerContext ctx, Throwable cause) throws Exception {
StackTraceElement[] test = cause.getStackTrace();
for(StackTraceElement s : test){
LoggerUtil.error("api caught exception "+ s.toString());
}
ctx.close();
}
}