Просмотр исходного кода

巡检计划communityService-listener

mrzcc лет назад: 6
Родитель
Сommit
39f317698f

+ 101 - 0
CommunityService/src/main/java/com/java110/community/listener/inspectionPlan/AbstractInspectionPlanBusinessServiceDataFlowListener.java

@@ -0,0 +1,101 @@
+package com.java110.community.listener.inspectionPlan;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.community.dao.IInspectionPlanServiceDao;
+import com.java110.utils.constant.ResponseConstant;
+import com.java110.utils.constant.StatusConstant;
+import com.java110.utils.exception.ListenerExecuteException;
+import com.java110.entity.center.Business;
+import com.java110.event.service.AbstractBusinessServiceDataFlowListener;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 巡检计划 服务侦听 父类
+ * Created by wuxw on 2018/7/4.
+ */
+public abstract class AbstractInspectionPlanBusinessServiceDataFlowListener extends AbstractBusinessServiceDataFlowListener {
+    private static Logger logger = LoggerFactory.getLogger(AbstractInspectionPlanBusinessServiceDataFlowListener.class);
+
+
+    /**
+     * 获取 DAO工具类
+     *
+     * @return
+     */
+    public abstract IInspectionPlanServiceDao getInspectionPlanServiceDaoImpl();
+
+    /**
+     * 刷新 businessInspectionPlanInfo 数据
+     * 主要将 数据库 中字段和 接口传递字段建立关系
+     *
+     * @param businessInspectionPlanInfo
+     */
+    protected void flushBusinessInspectionPlanInfo(Map businessInspectionPlanInfo, String statusCd) {
+        businessInspectionPlanInfo.put("newBId", businessInspectionPlanInfo.get("bId"));
+        businessInspectionPlanInfo.put("inspectionPlanName", businessInspectionPlanInfo.get("inspectionPlanName"));
+        businessInspectionPlanInfo.put("inspectionRouteId", businessInspectionPlanInfo.get("inspectionRouteId"));
+        businessInspectionPlanInfo.put("inspectionPlanPeriod", businessInspectionPlanInfo.get("inspectionPlanPeriod"));
+        businessInspectionPlanInfo.put("remark", businessInspectionPlanInfo.get("remark"));
+        businessInspectionPlanInfo.put("endTime", businessInspectionPlanInfo.get("endTime"));
+        businessInspectionPlanInfo.put("operate", businessInspectionPlanInfo.get("operate"));
+        businessInspectionPlanInfo.put("staffName", businessInspectionPlanInfo.get("staffName"));
+        businessInspectionPlanInfo.put("signType", businessInspectionPlanInfo.get("signType"));
+        businessInspectionPlanInfo.put("startTime", businessInspectionPlanInfo.get("startTime"));
+        businessInspectionPlanInfo.put("createUserId", businessInspectionPlanInfo.get("createUserId"));
+        businessInspectionPlanInfo.put("createUserName", businessInspectionPlanInfo.get("createUserName"));
+        businessInspectionPlanInfo.put("inspectionPlanId", businessInspectionPlanInfo.get("inspectionPlanId"));
+        businessInspectionPlanInfo.put("state", businessInspectionPlanInfo.get("state"));
+        businessInspectionPlanInfo.put("communityId", businessInspectionPlanInfo.get("communityId"));
+        businessInspectionPlanInfo.put("staffId", businessInspectionPlanInfo.get("staffId"));
+        businessInspectionPlanInfo.put("staffName", businessInspectionPlanInfo.get("staffName"));
+        businessInspectionPlanInfo.remove("bId");
+        businessInspectionPlanInfo.put("statusCd", statusCd);
+    }
+
+
+    /**
+     * 当修改数据时,查询instance表中的数据 自动保存删除数据到business中
+     *
+     * @param businessInspectionPlan 巡检计划信息
+     */
+    protected void autoSaveDelBusinessInspectionPlan(Business business, JSONObject businessInspectionPlan) {
+//自动插入DEL
+        Map info = new HashMap();
+        info.put("inspectionPlanId", businessInspectionPlan.getString("inspectionPlanId"));
+        info.put("statusCd", StatusConstant.STATUS_CD_VALID);
+        List<Map> currentInspectionPlanInfos = getInspectionPlanServiceDaoImpl().getInspectionPlanInfo(info);
+        if (currentInspectionPlanInfos == null || currentInspectionPlanInfos.size() != 1) {
+            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR, "未找到需要修改数据信息,入参错误或数据有问题,请检查" + info);
+        }
+
+        Map currentInspectionPlanInfo = currentInspectionPlanInfos.get(0);
+
+        currentInspectionPlanInfo.put("bId", business.getbId());
+
+        currentInspectionPlanInfo.put("inspectionPlanName", businessInspectionPlan.get("inspectionPlanName"));
+        currentInspectionPlanInfo.put("inspectionRouteId", businessInspectionPlan.get("inspectionRouteId"));
+        currentInspectionPlanInfo.put("inspectionPlanPeriod", businessInspectionPlan.get("inspectionPlanPeriod"));
+        currentInspectionPlanInfo.put("remark", businessInspectionPlan.get("remark"));
+        currentInspectionPlanInfo.put("endTime", businessInspectionPlan.get("endTime"));
+        currentInspectionPlanInfo.put("operate", businessInspectionPlan.get("operate"));
+        currentInspectionPlanInfo.put("staffName", businessInspectionPlan.get("staffName"));
+        currentInspectionPlanInfo.put("signType", businessInspectionPlan.get("signType"));
+        currentInspectionPlanInfo.put("startTime", businessInspectionPlan.get("startTime"));
+        currentInspectionPlanInfo.put("createUserId", businessInspectionPlan.get("createUserId"));
+        currentInspectionPlanInfo.put("createUserName", businessInspectionPlan.get("createUserName"));
+        currentInspectionPlanInfo.put("inspectionPlanId", businessInspectionPlan.get("inspectionPlanId"));
+        currentInspectionPlanInfo.put("state", businessInspectionPlan.get("state"));
+        currentInspectionPlanInfo.put("communityId", businessInspectionPlan.get("communityId"));
+        currentInspectionPlanInfo.put("staffId", businessInspectionPlan.get("staffId"));
+        currentInspectionPlanInfo.put("staffName", businessInspectionPlan.get("staffName"));
+        currentInspectionPlanInfo.put("operate", StatusConstant.OPERATE_DEL);
+        getInspectionPlanServiceDaoImpl().saveBusinessInspectionPlanInfo(currentInspectionPlanInfo);
+    }
+
+
+}

+ 177 - 0
CommunityService/src/main/java/com/java110/community/listener/inspectionPlan/DeleteInspectionPlanInfoListener.java

@@ -0,0 +1,177 @@
+package com.java110.community.listener.inspectionPlan;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.community.dao.IInspectionPlanServiceDao;
+import com.java110.utils.constant.BusinessTypeConstant;
+import com.java110.utils.constant.ResponseConstant;
+import com.java110.utils.constant.StatusConstant;
+import com.java110.utils.exception.ListenerExecuteException;
+import com.java110.utils.util.Assert;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.entity.center.Business;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 删除巡检计划信息 侦听
+ *
+ * 处理节点
+ * 1、businessInspectionPlan:{} 巡检计划基本信息节点
+ * 2、businessInspectionPlanAttr:[{}] 巡检计划属性信息节点
+ * 3、businessInspectionPlanPhoto:[{}] 巡检计划照片信息节点
+ * 4、businessInspectionPlanCerdentials:[{}] 巡检计划证件信息节点
+ * 协议地址 :https://github.com/java110/MicroCommunity/wiki/%E5%88%A0%E9%99%A4%E5%95%86%E6%88%B7%E4%BF%A1%E6%81%AF-%E5%8D%8F%E8%AE%AE
+ * Created by wuxw on 2018/5/18.
+ */
+@Java110Listener("deleteInspectionPlanInfoListener")
+@Transactional
+public class DeleteInspectionPlanInfoListener extends AbstractInspectionPlanBusinessServiceDataFlowListener {
+
+    private final static Logger logger = LoggerFactory.getLogger(DeleteInspectionPlanInfoListener.class);
+    @Autowired
+    IInspectionPlanServiceDao inspectionPlanServiceDaoImpl;
+
+    @Override
+    public int getOrder() {
+        return 3;
+    }
+
+    @Override
+    public String getBusinessTypeCd() {
+        return BusinessTypeConstant.BUSINESS_TYPE_DELETE_INSPECTION_PLAN;
+    }
+
+    /**
+     * 根据删除信息 查出Instance表中数据 保存至business表 (状态写DEL) 方便撤单时直接更新回去
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {
+        JSONObject data = business.getDatas();
+
+        Assert.notEmpty(data,"没有datas 节点,或没有子节点需要处理");
+
+        //处理 businessInspectionPlan 节点
+        if(data.containsKey("businessInspectionPlan")){
+            //处理 businessInspectionPlan 节点
+            if(data.containsKey("businessInspectionPlan")){
+                Object _obj = data.get("businessInspectionPlan");
+                JSONArray businessInspectionPlans = null;
+                if(_obj instanceof JSONObject){
+                    businessInspectionPlans = new JSONArray();
+                    businessInspectionPlans.add(_obj);
+                }else {
+                    businessInspectionPlans = (JSONArray)_obj;
+                }
+                //JSONObject businessInspectionPlan = data.getJSONObject("businessInspectionPlan");
+                for (int _inspectionPlanIndex = 0; _inspectionPlanIndex < businessInspectionPlans.size();_inspectionPlanIndex++) {
+                    JSONObject businessInspectionPlan = businessInspectionPlans.getJSONObject(_inspectionPlanIndex);
+                    doBusinessInspectionPlan(business, businessInspectionPlan);
+                    if(_obj instanceof JSONObject) {
+                        dataFlowContext.addParamOut("inspectionPlanId", businessInspectionPlan.getString("inspectionPlanId"));
+                    }
+                }
+            }
+        }
+
+
+    }
+
+    /**
+     * 删除 instance数据
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doBusinessToInstance(DataFlowContext dataFlowContext, Business business) {
+        String bId = business.getbId();
+        //Assert.hasLength(bId,"请求报文中没有包含 bId");
+
+        //巡检计划信息
+        Map info = new HashMap();
+        info.put("bId",business.getbId());
+        info.put("operate",StatusConstant.OPERATE_DEL);
+
+        //巡检计划信息
+        List<Map> businessInspectionPlanInfos = inspectionPlanServiceDaoImpl.getBusinessInspectionPlanInfo(info);
+        if( businessInspectionPlanInfos != null && businessInspectionPlanInfos.size() >0) {
+            for (int _inspectionPlanIndex = 0; _inspectionPlanIndex < businessInspectionPlanInfos.size();_inspectionPlanIndex++) {
+                Map businessInspectionPlanInfo = businessInspectionPlanInfos.get(_inspectionPlanIndex);
+                flushBusinessInspectionPlanInfo(businessInspectionPlanInfo,StatusConstant.STATUS_CD_INVALID);
+                inspectionPlanServiceDaoImpl.updateInspectionPlanInfoInstance(businessInspectionPlanInfo);
+                dataFlowContext.addParamOut("inspectionPlanId",businessInspectionPlanInfo.get("inspection_plan_id"));
+            }
+        }
+
+    }
+
+    /**
+     * 撤单
+     * 从business表中查询到DEL的数据 将instance中的数据更新回来
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doRecover(DataFlowContext dataFlowContext, Business business) {
+        String bId = business.getbId();
+        //Assert.hasLength(bId,"请求报文中没有包含 bId");
+        Map info = new HashMap();
+        info.put("bId",bId);
+        info.put("statusCd",StatusConstant.STATUS_CD_INVALID);
+
+        Map delInfo = new HashMap();
+        delInfo.put("bId",business.getbId());
+        delInfo.put("operate",StatusConstant.OPERATE_DEL);
+        //巡检计划信息
+        List<Map> inspectionPlanInfo = inspectionPlanServiceDaoImpl.getInspectionPlanInfo(info);
+        if(inspectionPlanInfo != null && inspectionPlanInfo.size() > 0){
+
+            //巡检计划信息
+            List<Map> businessInspectionPlanInfos = inspectionPlanServiceDaoImpl.getBusinessInspectionPlanInfo(delInfo);
+            //除非程序出错了,这里不会为空
+            if(businessInspectionPlanInfos == null ||  businessInspectionPlanInfos.size() == 0){
+                throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_INNER_ERROR,"撤单失败(inspectionPlan),程序内部异常,请检查! "+delInfo);
+            }
+            for (int _inspectionPlanIndex = 0; _inspectionPlanIndex < businessInspectionPlanInfos.size();_inspectionPlanIndex++) {
+                Map businessInspectionPlanInfo = businessInspectionPlanInfos.get(_inspectionPlanIndex);
+                flushBusinessInspectionPlanInfo(businessInspectionPlanInfo,StatusConstant.STATUS_CD_VALID);
+                inspectionPlanServiceDaoImpl.updateInspectionPlanInfoInstance(businessInspectionPlanInfo);
+            }
+        }
+    }
+
+
+
+    /**
+     * 处理 businessInspectionPlan 节点
+     * @param business 总的数据节点
+     * @param businessInspectionPlan 巡检计划节点
+     */
+    private void doBusinessInspectionPlan(Business business,JSONObject businessInspectionPlan){
+
+        Assert.jsonObjectHaveKey(businessInspectionPlan,"inspectionPlanId","businessInspectionPlan 节点下没有包含 inspectionPlanId 节点");
+
+        if(businessInspectionPlan.getString("inspectionPlanId").startsWith("-")){
+            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR,"inspectionPlanId 错误,不能自动生成(必须已经存在的inspectionPlanId)"+businessInspectionPlan);
+        }
+        //自动插入DEL
+        autoSaveDelBusinessInspectionPlan(business,businessInspectionPlan);
+    }
+
+    public IInspectionPlanServiceDao getInspectionPlanServiceDaoImpl() {
+        return inspectionPlanServiceDaoImpl;
+    }
+
+    public void setInspectionPlanServiceDaoImpl(IInspectionPlanServiceDao inspectionPlanServiceDaoImpl) {
+        this.inspectionPlanServiceDaoImpl = inspectionPlanServiceDaoImpl;
+    }
+}

+ 178 - 0
CommunityService/src/main/java/com/java110/community/listener/inspectionPlan/SaveInspectionPlanInfoListener.java

@@ -0,0 +1,178 @@
+package com.java110.community.listener.inspectionPlan;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.utils.constant.BusinessTypeConstant;
+import com.java110.utils.constant.StatusConstant;
+import com.java110.utils.util.Assert;
+import com.java110.community.dao.IInspectionPlanServiceDao;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.core.factory.GenerateCodeFactory;
+import com.java110.entity.center.Business;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 保存 巡检计划信息 侦听
+ * Created by wuxw on 2018/5/18.
+ */
+@Java110Listener("saveInspectionPlanInfoListener")
+@Transactional
+public class SaveInspectionPlanInfoListener extends AbstractInspectionPlanBusinessServiceDataFlowListener{
+
+    private static Logger logger = LoggerFactory.getLogger(SaveInspectionPlanInfoListener.class);
+
+    @Autowired
+    private IInspectionPlanServiceDao inspectionPlanServiceDaoImpl;
+
+    @Override
+    public int getOrder() {
+        return 0;
+    }
+
+    @Override
+    public String getBusinessTypeCd() {
+        return BusinessTypeConstant.BUSINESS_TYPE_SAVE_INSPECTION_PLAN;
+    }
+
+    /**
+     * 保存巡检计划信息 business 表中
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {
+        JSONObject data = business.getDatas();
+        Assert.notEmpty(data,"没有datas 节点,或没有子节点需要处理");
+
+        //处理 businessInspectionPlan 节点
+        if(data.containsKey("businessInspectionPlan")){
+            Object bObj = data.get("businessInspectionPlan");
+            JSONArray businessInspectionPlans = null;
+            if(bObj instanceof JSONObject){
+                businessInspectionPlans = new JSONArray();
+                businessInspectionPlans.add(bObj);
+            }else {
+                businessInspectionPlans = (JSONArray)bObj;
+            }
+            //JSONObject businessInspectionPlan = data.getJSONObject("businessInspectionPlan");
+            for (int bInspectionPlanIndex = 0; bInspectionPlanIndex < businessInspectionPlans.size();bInspectionPlanIndex++) {
+                JSONObject businessInspectionPlan = businessInspectionPlans.getJSONObject(bInspectionPlanIndex);
+                doBusinessInspectionPlan(business, businessInspectionPlan);
+                if(bObj instanceof JSONObject) {
+                    dataFlowContext.addParamOut("inspectionPlanId", businessInspectionPlan.getString("inspectionPlanId"));
+                }
+            }
+        }
+    }
+
+    /**
+     * business 数据转移到 instance
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doBusinessToInstance(DataFlowContext dataFlowContext, Business business) {
+        JSONObject data = business.getDatas();
+
+        Map info = new HashMap();
+        info.put("bId",business.getbId());
+        info.put("operate",StatusConstant.OPERATE_ADD);
+
+        //巡检计划信息
+        List<Map> businessInspectionPlanInfo = inspectionPlanServiceDaoImpl.getBusinessInspectionPlanInfo(info);
+        if( businessInspectionPlanInfo != null && businessInspectionPlanInfo.size() >0) {
+            reFreshShareColumn(info, businessInspectionPlanInfo.get(0));
+            inspectionPlanServiceDaoImpl.saveInspectionPlanInfoInstance(info);
+            if(businessInspectionPlanInfo.size() == 1) {
+                dataFlowContext.addParamOut("inspectionPlanId", businessInspectionPlanInfo.get(0).get("inspection_plan_id"));
+            }
+        }
+    }
+
+
+    /**
+     * 刷 分片字段
+     *
+     * @param info         查询对象
+     * @param businessInfo 小区ID
+     */
+    private void reFreshShareColumn(Map info, Map businessInfo) {
+
+        if (info.containsKey("communityId")) {
+            return;
+        }
+
+        if (!businessInfo.containsKey("community_id")) {
+            return;
+        }
+
+        info.put("communityId", businessInfo.get("community_id"));
+    }
+    /**
+     * 撤单
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doRecover(DataFlowContext dataFlowContext, Business business) {
+        String bId = business.getbId();
+        //Assert.hasLength(bId,"请求报文中没有包含 bId");
+        Map info = new HashMap();
+        info.put("bId",bId);
+        info.put("statusCd",StatusConstant.STATUS_CD_VALID);
+        Map paramIn = new HashMap();
+        paramIn.put("bId",bId);
+        paramIn.put("statusCd",StatusConstant.STATUS_CD_INVALID);
+        //巡检计划信息
+        List<Map> inspectionPlanInfo = inspectionPlanServiceDaoImpl.getInspectionPlanInfo(info);
+        if(inspectionPlanInfo != null && inspectionPlanInfo.size() > 0){
+            reFreshShareColumn(paramIn, inspectionPlanInfo.get(0));
+            inspectionPlanServiceDaoImpl.updateInspectionPlanInfoInstance(paramIn);
+        }
+    }
+
+
+
+    /**
+     * 处理 businessInspectionPlan 节点
+     * @param business 总的数据节点
+     * @param businessInspectionPlan 巡检计划节点
+     */
+    private void doBusinessInspectionPlan(Business business,JSONObject businessInspectionPlan){
+
+        Assert.jsonObjectHaveKey(businessInspectionPlan,"inspectionPlanId","businessInspectionPlan 节点下没有包含 inspectionPlanId 节点");
+
+        if(businessInspectionPlan.getString("inspectionPlanId").startsWith("-")){
+            //刷新缓存
+            //flushInspectionPlanId(business.getDatas());
+
+            businessInspectionPlan.put("inspectionPlanId",GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_inspectionPlanId));
+
+        }
+
+        businessInspectionPlan.put("bId",business.getbId());
+        businessInspectionPlan.put("operate", StatusConstant.OPERATE_ADD);
+        businessInspectionPlan.put("createUserId", "111");
+        businessInspectionPlan.put("createUserName", "zcc");
+
+        //保存巡检计划信息
+        inspectionPlanServiceDaoImpl.saveBusinessInspectionPlanInfo(businessInspectionPlan);
+
+    }
+
+    public IInspectionPlanServiceDao getInspectionPlanServiceDaoImpl() {
+        return inspectionPlanServiceDaoImpl;
+    }
+
+    public void setInspectionPlanServiceDaoImpl(IInspectionPlanServiceDao inspectionPlanServiceDaoImpl) {
+        this.inspectionPlanServiceDaoImpl = inspectionPlanServiceDaoImpl;
+    }
+}

+ 190 - 0
CommunityService/src/main/java/com/java110/community/listener/inspectionPlan/UpdateInspectionPlanInfoListener.java

@@ -0,0 +1,190 @@
+package com.java110.community.listener.inspectionPlan;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.community.dao.IInspectionPlanServiceDao;
+import com.java110.utils.constant.BusinessTypeConstant;
+import com.java110.utils.constant.ResponseConstant;
+import com.java110.utils.constant.StatusConstant;
+import com.java110.utils.exception.ListenerExecuteException;
+import com.java110.utils.util.Assert;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.entity.center.Business;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 修改巡检计划信息 侦听
+ *
+ * 处理节点
+ * 1、businessInspectionPlan:{} 巡检计划基本信息节点
+ * 2、businessInspectionPlanAttr:[{}] 巡检计划属性信息节点
+ * 3、businessInspectionPlanPhoto:[{}] 巡检计划照片信息节点
+ * 4、businessInspectionPlanCerdentials:[{}] 巡检计划证件信息节点
+ * 协议地址 :https://github.com/java110/MicroCommunity/wiki/%E4%BF%AE%E6%94%B9%E5%95%86%E6%88%B7%E4%BF%A1%E6%81%AF-%E5%8D%8F%E8%AE%AE
+ * Created by wuxw on 2018/5/18.
+ */
+@Java110Listener("updateInspectionPlanInfoListener")
+@Transactional
+public class UpdateInspectionPlanInfoListener extends AbstractInspectionPlanBusinessServiceDataFlowListener {
+
+    private static Logger logger = LoggerFactory.getLogger(UpdateInspectionPlanInfoListener.class);
+    @Autowired
+    private IInspectionPlanServiceDao inspectionPlanServiceDaoImpl;
+
+    @Override
+    public int getOrder() {
+        return 2;
+    }
+
+    @Override
+    public String getBusinessTypeCd() {
+        return BusinessTypeConstant.BUSINESS_TYPE_UPDATE_INSPECTION_PLAN;
+    }
+
+    /**
+     * business过程
+     * @param dataFlowContext 上下文对象
+     * @param business 业务对象
+     */
+    @Override
+    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {
+
+        JSONObject data = business.getDatas();
+
+        Assert.notEmpty(data,"没有datas 节点,或没有子节点需要处理");
+
+        //处理 businessInspectionPlan 节点
+        if(data.containsKey("businessInspectionPlan")){
+            //处理 businessInspectionPlan 节点
+            if(data.containsKey("businessInspectionPlan")){
+                Object _obj = data.get("businessInspectionPlan");
+                JSONArray businessInspectionPlans = null;
+                if(_obj instanceof JSONObject){
+                    businessInspectionPlans = new JSONArray();
+                    businessInspectionPlans.add(_obj);
+                }else {
+                    businessInspectionPlans = (JSONArray)_obj;
+                }
+                //JSONObject businessInspectionPlan = data.getJSONObject("businessInspectionPlan");
+                for (int _inspectionPlanIndex = 0; _inspectionPlanIndex < businessInspectionPlans.size();_inspectionPlanIndex++) {
+                    JSONObject businessInspectionPlan = businessInspectionPlans.getJSONObject(_inspectionPlanIndex);
+                    doBusinessInspectionPlan(business, businessInspectionPlan);
+                    if(_obj instanceof JSONObject) {
+                        dataFlowContext.addParamOut("inspectionPlanId", businessInspectionPlan.getString("inspectionPlanId"));
+                    }
+                }
+            }
+        }
+    }
+
+
+    /**
+     * business to instance 过程
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doBusinessToInstance(DataFlowContext dataFlowContext, Business business) {
+
+        JSONObject data = business.getDatas();
+
+        Map info = new HashMap();
+        info.put("bId",business.getbId());
+        info.put("operate",StatusConstant.OPERATE_ADD);
+
+        //巡检计划信息
+        List<Map> businessInspectionPlanInfos = inspectionPlanServiceDaoImpl.getBusinessInspectionPlanInfo(info);
+        if( businessInspectionPlanInfos != null && businessInspectionPlanInfos.size() >0) {
+            for (int _inspectionPlanIndex = 0; _inspectionPlanIndex < businessInspectionPlanInfos.size();_inspectionPlanIndex++) {
+                Map businessInspectionPlanInfo = businessInspectionPlanInfos.get(_inspectionPlanIndex);
+                flushBusinessInspectionPlanInfo(businessInspectionPlanInfo,StatusConstant.STATUS_CD_VALID);
+                inspectionPlanServiceDaoImpl.updateInspectionPlanInfoInstance(businessInspectionPlanInfo);
+                if(businessInspectionPlanInfo.size() == 1) {
+                    dataFlowContext.addParamOut("inspectionPlanId", businessInspectionPlanInfo.get("inspection_plan_id"));
+                }
+            }
+        }
+
+    }
+
+    /**
+     * 撤单
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doRecover(DataFlowContext dataFlowContext, Business business) {
+
+        String bId = business.getbId();
+        //Assert.hasLength(bId,"请求报文中没有包含 bId");
+        Map info = new HashMap();
+        info.put("bId",bId);
+        info.put("statusCd",StatusConstant.STATUS_CD_VALID);
+        Map delInfo = new HashMap();
+        delInfo.put("bId",business.getbId());
+        delInfo.put("operate",StatusConstant.OPERATE_DEL);
+        //巡检计划信息
+        List<Map> inspectionPlanInfo = inspectionPlanServiceDaoImpl.getInspectionPlanInfo(info);
+        if(inspectionPlanInfo != null && inspectionPlanInfo.size() > 0){
+
+            //巡检计划信息
+            List<Map> businessInspectionPlanInfos = inspectionPlanServiceDaoImpl.getBusinessInspectionPlanInfo(delInfo);
+            //除非程序出错了,这里不会为空
+            if(businessInspectionPlanInfos == null || businessInspectionPlanInfos.size() == 0){
+                throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_INNER_ERROR,"撤单失败(inspectionPlan),程序内部异常,请检查! "+delInfo);
+            }
+            for (int _inspectionPlanIndex = 0; _inspectionPlanIndex < businessInspectionPlanInfos.size();_inspectionPlanIndex++) {
+                Map businessInspectionPlanInfo = businessInspectionPlanInfos.get(_inspectionPlanIndex);
+                flushBusinessInspectionPlanInfo(businessInspectionPlanInfo,StatusConstant.STATUS_CD_VALID);
+                inspectionPlanServiceDaoImpl.updateInspectionPlanInfoInstance(businessInspectionPlanInfo);
+            }
+        }
+
+    }
+
+
+
+    /**
+     * 处理 businessInspectionPlan 节点
+     * @param business 总的数据节点
+     * @param businessInspectionPlan 巡检计划节点
+     */
+    private void doBusinessInspectionPlan(Business business,JSONObject businessInspectionPlan){
+
+        Assert.jsonObjectHaveKey(businessInspectionPlan,"inspectionPlanId","businessInspectionPlan 节点下没有包含 inspectionPlanId 节点");
+
+        if(businessInspectionPlan.getString("inspectionPlanId").startsWith("-")){
+            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR,"inspectionPlanId 错误,不能自动生成(必须已经存在的inspectionPlanId)"+businessInspectionPlan);
+        }
+        //自动保存DEL
+        autoSaveDelBusinessInspectionPlan(business,businessInspectionPlan);
+
+        businessInspectionPlan.put("bId",business.getbId());
+        businessInspectionPlan.put("operate", StatusConstant.OPERATE_ADD);
+        //保存巡检计划信息
+        inspectionPlanServiceDaoImpl.saveBusinessInspectionPlanInfo(businessInspectionPlan);
+
+    }
+
+
+
+
+    public IInspectionPlanServiceDao getInspectionPlanServiceDaoImpl() {
+        return inspectionPlanServiceDaoImpl;
+    }
+
+    public void setInspectionPlanServiceDaoImpl(IInspectionPlanServiceDao inspectionPlanServiceDaoImpl) {
+        this.inspectionPlanServiceDaoImpl = inspectionPlanServiceDaoImpl;
+    }
+
+
+
+}