package com.fzzy.protocol.fzzy.service;
|
|
import com.fzzy.api.Constant;
|
import com.fzzy.api.data.ApiCommonDevice;
|
import com.fzzy.api.data.GatewayDeviceProtocol;
|
import com.fzzy.gateway.api.GatewaySyncGranService;
|
import com.fzzy.gateway.data.BaseReqData;
|
import com.fzzy.gateway.data.BaseResp;
|
import com.fzzy.gateway.entity.GatewayDevice;
|
import com.fzzy.protocol.fzzy.builder.GrainCommandBuilder;
|
import com.fzzy.protocol.fzzy.cmd.BaseRemoteImpl;
|
import com.fzzy.protocol.fzzy.data.SendMessage;
|
import com.fzzy.protocol.fzzy.server.ServerUtils;
|
import com.ld.io.api.InvokeResult;
|
import lombok.extern.slf4j.Slf4j;
|
import org.springframework.stereotype.Component;
|
|
/**
|
* 风正致远控制柜协议
|
*/
|
@Slf4j
|
@Component
|
public class FzzyGatewayGrainService extends BaseRemoteImpl implements GatewaySyncGranService {
|
|
@Override
|
public String getGrainProtocol() {
|
return GatewayDeviceProtocol.TCP_FZZY_V3.getCode();
|
}
|
|
@Override
|
public BaseResp syncGrain(BaseReqData reqData) {
|
|
BaseResp resp = new BaseResp();
|
|
GatewayDevice device = reqData.getDevice();
|
|
//获取连接中的设备信息
|
ApiCommonDevice apiCommonDevice = Constant.getCommonDeviceCache(device.getDeviceSn());
|
|
if (null == apiCommonDevice) {
|
resp.setCode(500);
|
resp.setMsg("系统未获取到下行连接设备信息,无法执行");
|
log.error("----------------系统未获取到下行连接设备信息,无法执行---------");
|
return resp;
|
}
|
|
if (Constant.YN_N.equals(apiCommonDevice.getStatus())) {
|
resp.setCode(500);
|
resp.setMsg("下行设备不在线---无法执行----" + device.getDeviceName());
|
log.error("下行设备不在线---无法执行----" + device.getDeviceName());
|
return resp;
|
}
|
|
device.setIp(apiCommonDevice.getIp());
|
device.setPort(apiCommonDevice.getPort());
|
|
reqData.setDevice(device);
|
|
|
try {
|
|
//Step 请求信息放入内存
|
ServerUtils.addSyncReq2Map(device.getDepotId(), reqData);
|
|
// Step1 生成粮情信息
|
SendMessage message = GrainCommandBuilder.getInstance().buildMessage(device,apiCommonDevice);
|
// 发送命令
|
InvokeResult result = send(device.getIp(), device.getPort(), message.getByteMsg());
|
|
log.error("平台------>>>>控制柜:粮情检测-{}", message);
|
|
// 封装返回信息
|
if (!InvokeResult.SUCCESS.getCode().equals(result.getCode())) {
|
log.error("平台------>>>>控制柜:粮情检测-失败{}", result.getMessage());
|
resp.setCode(500);
|
resp.setMsg("平台------>>>>控制柜:粮情检测-失败:" + result.getMessage());
|
}
|
|
} catch (Exception e) {
|
log.error("粮情检测异常:{}", e);
|
resp.setCode(500);
|
resp.setMsg("粮情检测异常:" + e.getMessage());
|
return resp;
|
}
|
return resp;
|
}
|
}
|