package com.dy.rtuMw.server.rtuData.p206V1; 
 | 
  
 | 
import com.dy.common.mw.protocol.Data; 
 | 
import com.dy.common.mw.protocol.p206V1.DataV1; 
 | 
import com.dy.common.mw.protocol.p206V1.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 TkDealOnHourReport extends TaskSurpport { 
 | 
  
 | 
    private static final Logger log = LogManager.getLogger(TkDealOnHourReport.class.getName()) ; 
 | 
  
 | 
    //类ID,一定与Tree.xml配置文件中配置一致 
 | 
    public static final String taskId = "TkDealOnHourReport" ; 
 | 
  
 | 
    /** 
 | 
     * 执行节点任务:控制器自报数据(功能码为C0) 
 | 
     * @param data 需要处理的数据 
 | 
     */ 
 | 
    @Override 
 | 
    public void execute(Object data) { 
 | 
        Data d = (Data) data; 
 | 
        DataV1 dV1 = (DataV1) d.getSubData();//前面任务已经判断不为null 
 | 
        Object cdObj = dV1.subData; 
 | 
        if (cdObj != null && cdObj instanceof DataCdC0Vo){ 
 | 
            Object[] objs = this.getTaskResults(TkPreGenObjs.taskId) ; 
 | 
            DbSv sv = (DbSv)objs[0] ; 
 | 
            PrController controller = (PrController)objs[1] ; 
 | 
            try{ 
 | 
                this.doDeal(sv, controller, d.getRtuAddr(), dV1, (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, DataV1 dV1, DataCdC0Vo cdData) throws Exception { 
 | 
        this.saveOrUpdateLast(sv, controller, rtuAddr, dV1, cdData); 
 | 
        this.saveHistory(sv, controller, rtuAddr, dV1, cdData); 
 | 
    } 
 | 
    /** 
 | 
     * 保存自报最新数据 
 | 
     * @param sv 服务 
 | 
     * @param controller 控制器对象 
 | 
     * @param rtuAddr 控制器地址 
 | 
     * @param cdData 自报数据对象 
 | 
     */ 
 | 
    private void saveOrUpdateLast(DbSv sv, PrController controller, String rtuAddr, DataV1 dV1, 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(dV1, 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(dV1, cdData); 
 | 
            sv.updateRmOnHourReportLast(po); 
 | 
            if(po.lossAmount >= ServerProperties.intakeAlarmLossMinValue){ 
 | 
                this.sendMessage(controller, po.lossAmount); 
 | 
            } 
 | 
        } 
 | 
    } 
 | 
  
 | 
  
 | 
    /** 
 | 
     * 保存或更新控制器该上报历史数据 
 | 
     * @param sv 服务bean 
 | 
     * @param controller 控制器对象 
 | 
     * @param rtuAddr 控制器地址 
 | 
     * @param dV1 协议数据 
 | 
     * @param cdData 功能数据 
 | 
     */ 
 | 
    private void saveHistory(DbSv sv, PrController controller, String rtuAddr, DataV1 dV1, 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(dV1, 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); 
 | 
        } 
 | 
    } 
 | 
  
 | 
} 
 |