package com.dy.rtuMw.server.rtuData.p206V1_0_0;
|
|
import com.dy.rtuMw.server.rtuData.TaskSurpport;
|
import com.dy.rtuMw.server.rtuData.dbSv.DbSv;
|
import com.dy.common.mw.protocol.Data;
|
import com.dy.common.springUtil.SpringContextUtil;
|
import com.dy.pipIrrGlobal.pojoPr.PrController;
|
import com.dy.pipIrrGlobal.pojoPr.PrControllerTramp;
|
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.Logger;
|
|
import java.text.ParseException;
|
import java.util.Date;
|
|
public class TkPreGenObjs extends TaskSurpport {
|
|
private static final Logger log = LogManager.getLogger(TkPreGenObjs.class.getName()) ;
|
|
//类ID,一定与Tree.xml配置文件中配置一致
|
public static final String taskId = "TkPreGenObjs" ;
|
|
/**
|
* 执行节点任务
|
* @param data 需要处理的数据
|
*/
|
@Override
|
public void execute(Object data) throws ParseException {
|
Data d = (Data)data ;
|
String rtuAddr = d.getRtuAddr() ;//TkRtuData里判断了rtuAddr为空
|
DbSv sv = (DbSv)SpringContextUtil.getBean(DbSv.class) ;
|
if(sv != null){
|
PrController controller = sv.getControllersByRtuAddrAndIntakeNotNull(rtuAddr) ;
|
PrControllerTramp controllerTramp = null ;
|
if(controller == null){
|
//数据库中未查询(已经绑定且控制器地址相符)到控制器(RTU实体)
|
//流浪者控制器
|
controllerTramp = sv.getPrControllerTrampByRtuAddr(rtuAddr);
|
if(controllerTramp == null){
|
controllerTramp = new PrControllerTramp(null, rtuAddr, d.getProtocol(), new Date()) ;
|
//this.taskResult = new Object[]{sv, null, rtuTramp} ;
|
//this.toNextOneTask(data, TkDealControllerTramp.taskId);
|
}
|
}
|
//不论是否为流浪控制器(RTU实体),都要进行下步工作,记录其上报的一些数据,当绑定控制器后,数据自动有了归属
|
this.taskResult = new Object[]{sv, controller, controllerTramp} ;
|
this.toNextTasks(data);
|
}else{
|
log.error("严重错误,未能得到DbSv对象");
|
}
|
}
|
}
|