package com.ld.igds.protocol.es.dlt645; import com.ld.igds.constant.RedisConst; import com.ld.igds.io.RemoteEsService; import com.ld.igds.io.constant.OrderRespEnum; import com.ld.igds.io.constant.ProtocolEnum; import com.ld.igds.io.request.BaseRequest; import com.ld.igds.io.response.BaseResponse; import com.ld.igds.io.response.GrainResponse; import com.ld.igds.protocol.es.dlt645.builder.CommandBuild; import com.ld.igds.protocol.es.dlt645.client.Dlt645ClientEngine; import com.ld.igds.util.BytesUtil; import com.ld.igds.util.RedisUtil; import com.ld.io.api.InvokeResult; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; /** * 当前协议实现,能耗协议 * * @author czt */ @Slf4j @Component(RemoteEsServiceImpl.BEAN_ID) public class RemoteEsServiceImpl implements RemoteEsService { public static final String BEAN_ID = "dlt645.remoteEsServiceImpl"; @Autowired private RedisUtil redisUtil; @Override public String getProtocol() { return ProtocolEnum.TCP_ES_DLT645_V1.getCode(); } @Override public BaseResponse checkEs(BaseRequest request) { try { log.info("DL/T645多功能电表分机开始检测,分机{}的IP={},端口={}",request.getSerId(),request.getIp(),request.getPort()); Dlt645ClientEngine clientEngine = new Dlt645ClientEngine(request.getIp(), request.getPort()); clientEngine.start(); Thread.sleep(1000); //采集命令存入缓存,解析时分辨是哪个仓的能耗,时效5分钟 String key = RedisConst.buildKey(request.getCompanyId(), "ES-DLT645", request.getSerId()); redisUtil.set(key, request.getDepotId(), 60*5); //生成命令-查询总电能的命令 String hexStr = CommandBuild.getInstance().getMsgCheck(request.getSerId()); InvokeResult result = clientEngine.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 BaseResponse(OrderRespEnum.ORDER_ERROR.getCode(), "后端异常:" + e.getMessage()); } } }