package com.ld.igds.protocol.beibo.grain;
|
|
import com.ld.igds.io.RemoteGrainService;
|
import com.ld.igds.io.constant.OrderRespEnum;
|
import com.ld.igds.io.constant.ProtocolEnum;
|
import com.ld.igds.io.request.CheckGrainRequest;
|
import com.ld.igds.io.response.GrainResponse;
|
import com.ld.igds.protocol.beibo.grain.builder.CommandBuild;
|
import com.ld.igds.protocol.beibo.grain.client.BeiboClientEngine;
|
import com.ld.igds.util.BytesUtil;
|
import com.ld.io.api.InvokeResult;
|
import lombok.extern.slf4j.Slf4j;
|
import org.springframework.stereotype.Component;
|
|
/**
|
* 贝博粮情分机协议
|
*
|
* @author czt
|
*/
|
@Slf4j
|
@Component(RemoteGrainServiceImpl.BEAN_ID)
|
public class RemoteGrainServiceImpl implements RemoteGrainService {
|
|
public static final String BEAN_ID = "beiboGrain.remoteGrainService";
|
|
@Override
|
public String getProtocol() {
|
return ProtocolEnum.TCP_BEIBO_GRAIN_V1.getCode();
|
}
|
|
@Override
|
public GrainResponse checkGrain(CheckGrainRequest request) {
|
try {
|
log.info("贝博粮情分机开始检测,分机{}的IP={},端口={}",request.getSerId(),request.getIp(),request.getPort());
|
BeiboClientEngine beibo = new BeiboClientEngine(request.getIp(),request.getPort());
|
beibo.start();
|
Thread.sleep(3000);
|
|
//生成粮情命令
|
String hexStr = CommandBuild.getInstance().getMsgCheck(request.getSerId(), request.getDepotId());
|
|
InvokeResult result = beibo.send(BytesUtil.hexStrToBytes(hexStr));
|
|
log.info("result=" +result.getMessage());
|
|
// 封装返回信息
|
if (InvokeResult.SUCCESS == result) {
|
return new GrainResponse(OrderRespEnum.ORDER_SUCCESS.getCode(),
|
"粮情粮情发送成功!");
|
} else {
|
log.error("平台------>>>>贝博粮情分机:粮情检测-失败{}", result.getMessage());
|
return new GrainResponse(OrderRespEnum.ORDER_ERROR.getCode(),
|
"命令发送异常:" + result.getMessage());
|
}
|
|
} catch (Exception e) {
|
log.error("粮情检测异常:{}", e);
|
return new GrainResponse(OrderRespEnum.ORDER_ERROR.getCode(), "后端异常:" + e.getMessage());
|
}
|
}
|
}
|