package com.dy.rtuMw.server.rtuData.p206V2;
|
|
import com.dy.common.mw.protocol.Data;
|
import com.dy.common.mw.protocol.p206V2.DataV2;
|
import com.dy.common.mw.protocol.p206V2.upVos.DataCdC0Vo;
|
import com.dy.pipIrrGlobal.pojoPr.PrController;
|
import com.dy.pipIrrGlobal.pojoRm.RmOnHourReportHistory;
|
import com.dy.pipIrrGlobal.pojoRm.RmOnHourReportLast;
|
import com.dy.rtuMw.server.ServerProperties;
|
import com.dy.rtuMw.server.forMs.SendMsCache;
|
import com.dy.rtuMw.server.rtuData.TaskSurpport;
|
import com.dy.rtuMw.server.rtuData.dbSv.DbSv;
|
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.Logger;
|
|
/**
|
* @Author liurunyu
|
* @Date 2024/1/16 14:11
|
* @LastEditTime 2024/1/16 14:11
|
* @Description 控制器自报实时数据(功能码为C0)(定点上报)
|
*/
|
public class TkDealOnHourReportV2 extends TaskSurpport {
|
|
private static final Logger log = LogManager.getLogger(TkDealOnHourReportV2.class.getName()) ;
|
|
//类ID,一定与Tree.xml配置文件中配置一致
|
public static final String taskId = "TkDealOnHourReportV2" ;
|
|
/**
|
* 执行节点任务:控制器自报数据(功能码为C0)
|
* @param data 需要处理的数据
|
*/
|
@Override
|
public void execute(Object data) {
|
Data d = (Data) data;
|
DataV2 dV2 = (DataV2) d.getSubData();//前面任务已经判断不为null
|
Object cdObj = dV2.subData;
|
if (cdObj != null && cdObj instanceof DataCdC0Vo){
|
Object[] objs = this.getTaskResults(TkPreGenObjsV2.taskId) ;
|
DbSv sv = (DbSv)objs[0] ;
|
PrController controller = (PrController)objs[1] ;
|
try{
|
this.doDeal(sv, controller, d.getRtuAddr(), dV2, (DataCdC0Vo)cdObj);
|
}catch (Exception e){
|
log.error("保存控制器定点上报数据时发生异常", e);
|
}
|
}
|
}
|
/**
|
* 处理阀上报数据
|
* @param sv 服务
|
* @param controller 控制器对象
|
* @param rtuAddr 控制器地址
|
* @param cdData 协议数据
|
* @param cdData 功能数据
|
*/
|
private void doDeal(DbSv sv, PrController controller, String rtuAddr, DataV2 dV2, DataCdC0Vo cdData) throws Exception {
|
this.saveOrUpdateLast(sv, controller, rtuAddr, dV2, cdData);
|
this.saveHistory(sv, controller, rtuAddr, dV2, cdData);
|
}
|
/**
|
* 保存自报最新数据
|
* @param sv 服务
|
* @param controller 控制器对象
|
* @param rtuAddr 控制器地址
|
* @param cdData 自报数据对象
|
*/
|
private void saveOrUpdateLast(DbSv sv, PrController controller, String rtuAddr, DataV2 dV2, DataCdC0Vo cdData) throws Exception {
|
RmOnHourReportLast po = sv.getRmOnHourReportLast(controller.getIntakeId()) ;
|
if(po == null){
|
po = new RmOnHourReportLast();
|
po.controllerId = controller==null?null:controller.getId();
|
po.intakeId = controller==null?null:controller.getIntakeId();
|
po.rtuAddr = rtuAddr;
|
po.valueFrom(dV2, cdData);
|
sv.saveRmOnHourReportLast(po) ;
|
if(po.lossAmount >= ServerProperties.intakeAlarmLossMinValue){
|
this.sendMessage(controller, po.lossAmount);
|
}
|
}else{
|
po.controllerId = controller==null?null:controller.getId();
|
po.intakeId = controller==null?null:controller.getIntakeId();
|
po.valueFrom(dV2, cdData);
|
sv.updateRmOnHourReportLast(po);
|
if(po.lossAmount >= ServerProperties.intakeAlarmLossMinValue){
|
this.sendMessage(controller, po.lossAmount);
|
}
|
}
|
}
|
|
|
/**
|
* 保存或更新控制器该上报历史数据
|
* @param sv 服务bean
|
* @param controller 控制器对象
|
* @param rtuAddr 控制器地址
|
* @param dV2 协议数据
|
* @param cdData 功能数据
|
*/
|
private void saveHistory(DbSv sv, PrController controller, String rtuAddr, DataV2 dV2, DataCdC0Vo cdData)throws Exception {
|
RmOnHourReportHistory po = new RmOnHourReportHistory();
|
po.controllerId = controller==null?null:controller.getId();
|
po.intakeId = controller==null?null:controller.getIntakeId();
|
po.rtuAddr = rtuAddr;
|
po.valueFrom(dV2, cdData);
|
sv.saveRmOnHourReportHistory(po); ;
|
}
|
|
|
|
/**
|
* 向钉钉发送消息
|
* @param controller
|
*/
|
private void sendMessage(PrController controller, Double lossAmount){
|
String ms = "取水口“" + controller.getIntakeName() + "”漏水报警,今日漏损量" + lossAmount + "立方米";
|
try{
|
SendMsCache.cacheMs(ms);
|
}catch (Exception e){
|
log.error("缓存钉钉消息异常:", e);
|
}
|
}
|
|
}
|