package com.ld.igds.protocol.bhzn.grainv2; import com.ld.igds.common.CoreCommonService; 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.models.Depot; import com.ld.igds.protocol.bhzn.grainv2.msg.builder.CommandBuild; import com.ld.igds.protocol.bhzn.grainv2.server.BhznGrainV2ServerEngine; import com.ld.igds.util.BytesUtil; import com.ld.io.api.InvokeResult; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; /** * @Desc: 粮情业务接口 * @author: Andy * @update-time: 2023/5/11 */ @Slf4j @Component(RemoteGrainV2ServiceImpl.BEAN_ID) public class RemoteGrainV2ServiceImpl implements RemoteGrainService { public static final String BEAN_ID = "bhznGrainv2.remoteGrainService"; @Autowired private CoreCommonService coreCommonService; @Autowired private BhznGrainV2ServerEngine bhznGrainServerEngine; @Override public String getProtocol() { return ProtocolEnum.TCP_BHZH_GRAIN_V2.getCode(); } @Override public GrainResponse checkGrain(CheckGrainRequest request) { try { String depotId = request.getDepotId(); //判断邦海仓库编码是否配置 Depot depot = coreCommonService.getCacheDepot(request.getCompanyId(), request.getDepotId()); if(null != depot && StringUtils.isNotEmpty(depot.getBhId())){ depotId = depot.getBhId(); } // 生成粮情信息 String hexStr = CommandBuild.getInstance().getMsgCheck(request.getSerId(), depotId); // 发送命令 InvokeResult result = bhznGrainServerEngine.push(request.getIp(),request.getPort(), BytesUtil.hexStrToBytes(hexStr)); log.error("平台------>>>>控制柜:粮情检测-{}", hexStr); // 封装返回信息 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()); } } }