package com.dy.rtuMw.server.rtuData.p206V202404; 
 | 
  
 | 
import com.dy.common.mw.protocol.Data; 
 | 
import com.dy.common.mw.protocol.p206V202404.DataV202404; 
 | 
import com.dy.common.mw.protocol.p206V202404.upVos.DataCd80_5BVo; 
 | 
import com.dy.pipIrrGlobal.pojoPr.PrController; 
 | 
import com.dy.pipIrrGlobal.pojoRm.RmWorkReportHistory; 
 | 
import com.dy.pipIrrGlobal.pojoRm.RmWorkReportLast; 
 | 
import com.dy.pipIrrGlobal.pojoSe.SeClient; 
 | 
import com.dy.rtuMw.server.ServerProperties; 
 | 
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; 
 | 
  
 | 
import java.util.HashMap; 
 | 
import java.util.Map; 
 | 
  
 | 
/** 
 | 
 * @Author: liurunyu 
 | 
 * @Date: 2024/6/14 9:19 
 | 
 * @Description 处理控制器工作报(功能码80) 
 | 
 */ 
 | 
public class TkDealWorkingReportV202404 extends TaskSurpport { 
 | 
  
 | 
    private static final Logger log = LogManager.getLogger(TkDealWorkingReportV202404.class.getName()); 
 | 
  
 | 
    private static final Map<String, Integer> RtuReportTimes = new HashMap<>(); 
 | 
  
 | 
    //类ID,一定与Tree.xml配置文件中配置一致 
 | 
    public static final String taskId = "TkDealWorkingReportV202404"; 
 | 
  
 | 
    /** 
 | 
     * 执行节点任务:报警及状态 
 | 
     * 
 | 
     * @param data 需要处理的数据 
 | 
     */ 
 | 
    @Override 
 | 
    public void execute(Object data) { 
 | 
        Data d = (Data)data ; 
 | 
        DataV202404 dV202404 = (DataV202404)d.getSubData() ; 
 | 
        Object cdObj = dV202404.subData ; 
 | 
        //前面任务已经判断cdObj不为null 
 | 
        if (cdObj instanceof DataCd80_5BVo) { 
 | 
            boolean deal = false ; 
 | 
            Integer times = RtuReportTimes.get(d.rtuAddr) ; 
 | 
            if(times == null){ 
 | 
                times = 1 ; 
 | 
                RtuReportTimes.put(d.rtuAddr, times) ; 
 | 
                deal = true ;//第一次 
 | 
            }else{ 
 | 
                times++ ; 
 | 
                if(times > ServerProperties.workReportDealOneByTimes){ 
 | 
                    times = 1 ;//循环第一次 
 | 
                    deal = true ; 
 | 
                } 
 | 
                RtuReportTimes.put(d.rtuAddr, times) ; 
 | 
            } 
 | 
            if(deal){ 
 | 
                try { 
 | 
                    Object[] objs = this.getTaskResults(TkPreGenObjsV202404.taskId); 
 | 
                    DbSv sv = (DbSv) objs[0]; 
 | 
                    PrController controller = (PrController) objs[1]; 
 | 
                    SeClient clientVo = (SeClient)objs[3] ;//这个值对象中只有id和name会有值 
 | 
                    this.doDeal(sv, clientVo, controller, d.getRtuAddr(), dV202404, (DataCd80_5BVo)cdObj); 
 | 
                } catch (Exception e) { 
 | 
                    log.error("处理保存控制器工作报数据时发生异常", e); 
 | 
                } 
 | 
            } 
 | 
        } 
 | 
    } 
 | 
    /** 
 | 
     * 处理阀开工作报数据 
 | 
     * @param sv 服务 
 | 
     * @param controller 控制器对象 
 | 
     * @param rtuAddr 控制器地址 
 | 
     * @param dataV202404 协议数据 
 | 
     * @param cdData 功能数据 
 | 
     */ 
 | 
    private void doDeal(DbSv sv, SeClient clientVo, PrController controller, String rtuAddr, DataV202404 dataV202404, DataCd80_5BVo cdData) throws Exception { 
 | 
        this.saveOrUpdateLast(sv, clientVo, controller, rtuAddr, dataV202404, cdData); 
 | 
        this.saveHistory(sv, clientVo, controller, rtuAddr, dataV202404, cdData); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 保存或更新控制器工作报最新数据 
 | 
     * @param sv 服务bean 
 | 
     * @param clientVo 农户对象(不为空时,只有id和name有值) 
 | 
     * @param controller 控制器对象 
 | 
     * @param rtuAddr 控制器地址 
 | 
     * @param dataV202404 协议数据 
 | 
     * @param cdData 功能数据 
 | 
     */ 
 | 
    private void saveOrUpdateLast(DbSv sv, SeClient clientVo, PrController controller, String rtuAddr, DataV202404 dataV202404, DataCd80_5BVo cdData)throws Exception { 
 | 
        RmWorkReportLast po = sv.getRmWorkReportLast(controller.getIntakeId()) ; 
 | 
        if(po == null){ 
 | 
            po = new RmWorkReportLast(); 
 | 
            po.clientId = clientVo==null?null:clientVo.getId() ; 
 | 
            po.clientName = clientVo==null?null:clientVo.getName() ; 
 | 
            po.controllerId = controller==null?null:controller.getId(); 
 | 
            po.intakeId = controller==null?null:controller.getIntakeId(); 
 | 
            po.rtuAddr = rtuAddr; 
 | 
            po.valueFrom(dataV202404, cdData); 
 | 
            sv.saveRmWorkReportLast(po) ; 
 | 
        }else{ 
 | 
            po.clientId = clientVo==null?null:clientVo.getId() ; 
 | 
            po.clientName = clientVo==null?null:clientVo.getName() ; 
 | 
            po.controllerId = controller==null?null:controller.getId(); 
 | 
            po.intakeId = controller==null?null:controller.getIntakeId(); 
 | 
            po.valueFrom(dataV202404, cdData); 
 | 
            sv.updateRmWorkReportLast(po); 
 | 
        } 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 保存控制器工作报历史数据 
 | 
     * @param sv 服务bean 
 | 
     * @param clientVo 农户对象(不为空时,只有id和name有值) 
 | 
     * @param controller 控制器对象 
 | 
     * @param rtuAddr 控制器地址 
 | 
     * @param dataV202404 协议数据 
 | 
     * @param cdData 功能数据 
 | 
     */ 
 | 
    private void saveHistory(DbSv sv, SeClient clientVo, PrController controller, String rtuAddr, DataV202404 dataV202404, DataCd80_5BVo cdData)throws Exception { 
 | 
        RmWorkReportHistory po = new RmWorkReportHistory(); 
 | 
        po.clientId = clientVo==null?null:clientVo.getId() ; 
 | 
        po.clientName = clientVo==null?null:clientVo.getName() ; 
 | 
        po.controllerId = controller==null?null:controller.getId(); 
 | 
        po.intakeId = controller==null?null:controller.getIntakeId(); 
 | 
        po.rtuAddr = rtuAddr; 
 | 
        po.valueFrom(dataV202404, cdData); 
 | 
        sv.saveRmWorkReportHistory(po); ; 
 | 
    } 
 | 
} 
 |