Procházet zdrojové kódy

加入业主属性功能

java110 před 5 roky
rodič
revize
dfef90df81
24 změnil soubory, kde provedl 2322 přidání a 33 odebrání
  1. 175 0
      docs/document/services/ownerAttr/DeleteOwnerAttrInfo.md
  2. 175 0
      docs/document/services/ownerAttr/SaveOwnerAttrInfo.md
  3. 188 0
      docs/document/services/ownerAttr/UpdateOwnerAttrInfo.md
  4. 86 0
      java110-bean/src/main/java/com/java110/dto/owner/OwnerAttrDto.java
  5. 54 0
      java110-bean/src/main/java/com/java110/po/owner/OwnerAttrPo.java
  6. 41 0
      java110-core/src/main/java/com/java110/core/smo/user/IOwnerAttrInnerServiceSMO.java
  7. 186 0
      java110-db/src/main/resources/mapper/user/OwnerAttrServiceDaoImplMapper.xml
  8. 28 33
      java110-generator/src/main/resources/back/template_1.json
  9. 48 0
      java110-generator/src/main/resources/back/template_repairTypeUser.json
  10. 17 0
      java110-utils/src/main/java/com/java110/utils/constant/BusinessTypeConstant.java
  11. 31 0
      java110-utils/src/main/java/com/java110/utils/constant/ServiceCodeOwnerAttrConstant.java
  12. 38 0
      service-api/src/main/java/com/java110/api/bmo/ownerAttr/IOwnerAttrBMO.java
  13. 61 0
      service-api/src/main/java/com/java110/api/bmo/ownerAttr/impl/OwnerAttrBMOImpl.java
  14. 49 0
      service-api/src/main/java/com/java110/api/listener/owner/DeleteOwnerAttrListener.java
  15. 82 0
      service-api/src/main/java/com/java110/api/listener/owner/ListOwnerAttrsListener.java
  16. 49 0
      service-api/src/main/java/com/java110/api/listener/owner/SaveOwnerAttrListener.java
  17. 50 0
      service-api/src/main/java/com/java110/api/listener/owner/UpdateOwnerAttrListener.java
  18. 81 0
      service-user/src/main/java/com/java110/user/dao/IOwnerAttrServiceDao.java
  19. 130 0
      service-user/src/main/java/com/java110/user/dao/impl/OwnerAttrServiceDaoImpl.java
  20. 90 0
      service-user/src/main/java/com/java110/user/listener/ownerAttr/AbstractOwnerAttrBusinessServiceDataFlowListener.java
  21. 180 0
      service-user/src/main/java/com/java110/user/listener/ownerAttr/DeleteOwnerAttrInfoListener.java
  22. 181 0
      service-user/src/main/java/com/java110/user/listener/ownerAttr/SaveOwnerAttrInfoListener.java
  23. 190 0
      service-user/src/main/java/com/java110/user/listener/ownerAttr/UpdateOwnerAttrInfoListener.java
  24. 112 0
      service-user/src/main/java/com/java110/user/smo/impl/OwnerAttrInnerServiceSMOImpl.java

+ 175 - 0
docs/document/services/ownerAttr/DeleteOwnerAttrInfo.md

@@ -0,0 +1,175 @@
+package com.java110.user.listener.ownerAttr;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+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 com.java110.user.dao.IOwnerAttrServiceDao;
+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、businessOwnerAttr:{} 业主属性基本信息节点
+ * 2、businessOwnerAttrAttr:[{}] 业主属性属性信息节点
+ * 3、businessOwnerAttrPhoto:[{}] 业主属性照片信息节点
+ * 4、businessOwnerAttrCerdentials:[{}] 业主属性证件信息节点
+ * 协议地址 :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("deleteOwnerAttrInfoListener")
+@Transactional
+public class DeleteOwnerAttrInfoListener extends AbstractOwnerAttrBusinessServiceDataFlowListener {
+
+    private final static Logger logger = LoggerFactory.getLogger(DeleteOwnerAttrInfoListener.class);
+    @Autowired
+    IOwnerAttrServiceDao ownerAttrServiceDaoImpl;
+
+    @Override
+    public int getOrder() {
+        return 3;
+    }
+
+    @Override
+    public String getBusinessTypeCd() {
+        return BusinessTypeConstant.BUSINESS_TYPE_DELETE_OWNER_ATTR_INFO;
+    }
+
+    /**
+     * 根据删除信息 查出Instance表中数据 保存至business表 (状态写DEL) 方便撤单时直接更新回去
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {
+        JSONObject data = business.getDatas();
+
+        Assert.notEmpty(data,"没有datas 节点,或没有子节点需要处理");
+
+            //处理 businessOwnerAttr 节点
+            if(data.containsKey(OwnerAttrPo.class.getSimpleName())){
+                Object _obj = data.get(OwnerAttrPo.class.getSimpleName());
+                JSONArray businessOwnerAttrs = null;
+                if(_obj instanceof JSONObject){
+                    businessOwnerAttrs = new JSONArray();
+                    businessOwnerAttrs.add(_obj);
+                }else {
+                    businessOwnerAttrs = (JSONArray)_obj;
+                }
+                //JSONObject businessOwnerAttr = data.getJSONObject(OwnerAttrPo.class.getSimpleName());
+                for (int _ownerAttrIndex = 0; _ownerAttrIndex < businessOwnerAttrs.size();_ownerAttrIndex++) {
+                    JSONObject businessOwnerAttr = businessOwnerAttrs.getJSONObject(_ownerAttrIndex);
+                    doBusinessOwnerAttr(business, businessOwnerAttr);
+                    if(_obj instanceof JSONObject) {
+                        dataFlowContext.addParamOut("attrId", businessOwnerAttr.getString("attrId"));
+                    }
+                }
+
+        }
+
+
+    }
+
+    /**
+     * 删除 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> businessOwnerAttrInfos = ownerAttrServiceDaoImpl.getBusinessOwnerAttrInfo(info);
+        if( businessOwnerAttrInfos != null && businessOwnerAttrInfos.size() >0) {
+            for (int _ownerAttrIndex = 0; _ownerAttrIndex < businessOwnerAttrInfos.size();_ownerAttrIndex++) {
+                Map businessOwnerAttrInfo = businessOwnerAttrInfos.get(_ownerAttrIndex);
+                flushBusinessOwnerAttrInfo(businessOwnerAttrInfo,StatusConstant.STATUS_CD_INVALID);
+                ownerAttrServiceDaoImpl.updateOwnerAttrInfoInstance(businessOwnerAttrInfo);
+                dataFlowContext.addParamOut("attrId",businessOwnerAttrInfo.get("attr_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> ownerAttrInfo = ownerAttrServiceDaoImpl.getOwnerAttrInfo(info);
+        if(ownerAttrInfo != null && ownerAttrInfo.size() > 0){
+
+            //业主属性信息
+            List<Map> businessOwnerAttrInfos = ownerAttrServiceDaoImpl.getBusinessOwnerAttrInfo(delInfo);
+            //除非程序出错了,这里不会为空
+            if(businessOwnerAttrInfos == null ||  businessOwnerAttrInfos.size() == 0){
+                throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_INNER_ERROR,"撤单失败(ownerAttr),程序内部异常,请检查! "+delInfo);
+            }
+            for (int _ownerAttrIndex = 0; _ownerAttrIndex < businessOwnerAttrInfos.size();_ownerAttrIndex++) {
+                Map businessOwnerAttrInfo = businessOwnerAttrInfos.get(_ownerAttrIndex);
+                flushBusinessOwnerAttrInfo(businessOwnerAttrInfo,StatusConstant.STATUS_CD_VALID);
+                ownerAttrServiceDaoImpl.updateOwnerAttrInfoInstance(businessOwnerAttrInfo);
+            }
+        }
+    }
+
+
+
+    /**
+     * 处理 businessOwnerAttr 节点
+     * @param business 总的数据节点
+     * @param businessOwnerAttr 业主属性节点
+     */
+    private void doBusinessOwnerAttr(Business business,JSONObject businessOwnerAttr){
+
+        Assert.jsonObjectHaveKey(businessOwnerAttr,"attrId","businessOwnerAttr 节点下没有包含 attrId 节点");
+
+        if(businessOwnerAttr.getString("attrId").startsWith("-")){
+            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR,"attrId 错误,不能自动生成(必须已经存在的attrId)"+businessOwnerAttr);
+        }
+        //自动插入DEL
+        autoSaveDelBusinessOwnerAttr(business,businessOwnerAttr);
+    }
+    @Override
+    public IOwnerAttrServiceDao getOwnerAttrServiceDaoImpl() {
+        return ownerAttrServiceDaoImpl;
+    }
+
+    public void setOwnerAttrServiceDaoImpl(IOwnerAttrServiceDao ownerAttrServiceDaoImpl) {
+        this.ownerAttrServiceDaoImpl = ownerAttrServiceDaoImpl;
+    }
+}

+ 175 - 0
docs/document/services/ownerAttr/SaveOwnerAttrInfo.md

@@ -0,0 +1,175 @@
+package com.java110.user.listener.ownerAttr;
+
+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.user.dao.IOwnerAttrServiceDao;
+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("saveOwnerAttrInfoListener")
+@Transactional
+public class SaveOwnerAttrInfoListener extends AbstractOwnerAttrBusinessServiceDataFlowListener{
+
+    private static Logger logger = LoggerFactory.getLogger(SaveOwnerAttrInfoListener.class);
+
+    @Autowired
+    private IOwnerAttrServiceDao ownerAttrServiceDaoImpl;
+
+    @Override
+    public int getOrder() {
+        return 0;
+    }
+
+    @Override
+    public String getBusinessTypeCd() {
+        return BusinessTypeConstant.BUSINESS_TYPE_SAVE_OWNER_ATTR_INFO;
+    }
+
+    /**
+     * 保存业主属性信息 business 表中
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {
+        JSONObject data = business.getDatas();
+        Assert.notEmpty(data,"没有datas 节点,或没有子节点需要处理");
+
+        //处理 businessOwnerAttr 节点
+        if(data.containsKey(OwnerAttrPo.class.getSimpleName())){
+            Object bObj = data.get(OwnerAttrPo.class.getSimpleName());
+            JSONArray businessOwnerAttrs = null;
+            if(bObj instanceof JSONObject){
+                businessOwnerAttrs = new JSONArray();
+                businessOwnerAttrs.add(bObj);
+            }else {
+                businessOwnerAttrs = (JSONArray)bObj;
+            }
+            //JSONObject businessOwnerAttr = data.getJSONObject(OwnerAttrPo.class.getSimpleName());
+            for (int bOwnerAttrIndex = 0; bOwnerAttrIndex < businessOwnerAttrs.size();bOwnerAttrIndex++) {
+                JSONObject businessOwnerAttr = businessOwnerAttrs.getJSONObject(bOwnerAttrIndex);
+                doBusinessOwnerAttr(business, businessOwnerAttr);
+                if(bObj instanceof JSONObject) {
+                    dataFlowContext.addParamOut("attrId", businessOwnerAttr.getString("attrId"));
+                }
+            }
+        }
+    }
+
+    /**
+     * 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> businessOwnerAttrInfo = ownerAttrServiceDaoImpl.getBusinessOwnerAttrInfo(info);
+        if( businessOwnerAttrInfo != null && businessOwnerAttrInfo.size() >0) {
+            reFreshShareColumn(info, businessOwnerAttrInfo.get(0));
+            ownerAttrServiceDaoImpl.saveOwnerAttrInfoInstance(info);
+            if(businessOwnerAttrInfo.size() == 1) {
+                dataFlowContext.addParamOut("attrId", businessOwnerAttrInfo.get(0).get("attr_id"));
+            }
+        }
+    }
+
+
+    /**
+     * 刷 分片字段
+     *
+     * @param info         查询对象
+     * @param businessInfo 小区ID
+     */
+    private void reFreshShareColumn(Map info, Map businessInfo) {
+
+        if (info.containsKey("community_id")) {
+            return;
+        }
+
+        if (!businessInfo.containsKey("communityId")) {
+            return;
+        }
+
+        info.put("community_id", businessInfo.get("communityId"));
+    }
+    /**
+     * 撤单
+     * @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> ownerAttrInfo = ownerAttrServiceDaoImpl.getOwnerAttrInfo(info);
+        if(ownerAttrInfo != null && ownerAttrInfo.size() > 0){
+            reFreshShareColumn(paramIn, ownerAttrInfo.get(0));
+            ownerAttrServiceDaoImpl.updateOwnerAttrInfoInstance(paramIn);
+        }
+    }
+
+
+
+    /**
+     * 处理 businessOwnerAttr 节点
+     * @param business 总的数据节点
+     * @param businessOwnerAttr 业主属性节点
+     */
+    private void doBusinessOwnerAttr(Business business,JSONObject businessOwnerAttr){
+
+        Assert.jsonObjectHaveKey(businessOwnerAttr,"attrId","businessOwnerAttr 节点下没有包含 attrId 节点");
+
+        if(businessOwnerAttr.getString("attrId").startsWith("-")){
+            //刷新缓存
+            //flushOwnerAttrId(business.getDatas());
+
+            businessOwnerAttr.put("attrId",GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_attrId));
+
+        }
+
+        businessOwnerAttr.put("bId",business.getbId());
+        businessOwnerAttr.put("operate", StatusConstant.OPERATE_ADD);
+        //保存业主属性信息
+        ownerAttrServiceDaoImpl.saveBusinessOwnerAttrInfo(businessOwnerAttr);
+
+    }
+    @Override
+    public IOwnerAttrServiceDao getOwnerAttrServiceDaoImpl() {
+        return ownerAttrServiceDaoImpl;
+    }
+
+    public void setOwnerAttrServiceDaoImpl(IOwnerAttrServiceDao ownerAttrServiceDaoImpl) {
+        this.ownerAttrServiceDaoImpl = ownerAttrServiceDaoImpl;
+    }
+}

+ 188 - 0
docs/document/services/ownerAttr/UpdateOwnerAttrInfo.md

@@ -0,0 +1,188 @@
+package com.java110.user.listener.ownerAttr;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+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 com.java110.user.dao.IOwnerAttrServiceDao;
+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、businessOwnerAttr:{} 业主属性基本信息节点
+ * 2、businessOwnerAttrAttr:[{}] 业主属性属性信息节点
+ * 3、businessOwnerAttrPhoto:[{}] 业主属性照片信息节点
+ * 4、businessOwnerAttrCerdentials:[{}] 业主属性证件信息节点
+ * 协议地址 :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("updateOwnerAttrInfoListener")
+@Transactional
+public class UpdateOwnerAttrInfoListener extends AbstractOwnerAttrBusinessServiceDataFlowListener {
+
+    private static Logger logger = LoggerFactory.getLogger(UpdateOwnerAttrInfoListener.class);
+    @Autowired
+    private IOwnerAttrServiceDao ownerAttrServiceDaoImpl;
+
+    @Override
+    public int getOrder() {
+        return 2;
+    }
+
+    @Override
+    public String getBusinessTypeCd() {
+        return BusinessTypeConstant.BUSINESS_TYPE_UPDATE_OWNER_ATTR_INFO;
+    }
+
+    /**
+     * business过程
+     * @param dataFlowContext 上下文对象
+     * @param business 业务对象
+     */
+    @Override
+    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {
+
+        JSONObject data = business.getDatas();
+
+        Assert.notEmpty(data,"没有datas 节点,或没有子节点需要处理");
+
+
+            //处理 businessOwnerAttr 节点
+            if(data.containsKey(OwnerAttrPo.class.getSimpleName())){
+                Object _obj = data.get(OwnerAttrPo.class.getSimpleName());
+                JSONArray businessOwnerAttrs = null;
+                if(_obj instanceof JSONObject){
+                    businessOwnerAttrs = new JSONArray();
+                    businessOwnerAttrs.add(_obj);
+                }else {
+                    businessOwnerAttrs = (JSONArray)_obj;
+                }
+                //JSONObject businessOwnerAttr = data.getJSONObject(OwnerAttrPo.class.getSimpleName());
+                for (int _ownerAttrIndex = 0; _ownerAttrIndex < businessOwnerAttrs.size();_ownerAttrIndex++) {
+                    JSONObject businessOwnerAttr = businessOwnerAttrs.getJSONObject(_ownerAttrIndex);
+                    doBusinessOwnerAttr(business, businessOwnerAttr);
+                    if(_obj instanceof JSONObject) {
+                        dataFlowContext.addParamOut("attrId", businessOwnerAttr.getString("attrId"));
+                    }
+                }
+            }
+    }
+
+
+    /**
+     * 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> businessOwnerAttrInfos = ownerAttrServiceDaoImpl.getBusinessOwnerAttrInfo(info);
+        if( businessOwnerAttrInfos != null && businessOwnerAttrInfos.size() >0) {
+            for (int _ownerAttrIndex = 0; _ownerAttrIndex < businessOwnerAttrInfos.size();_ownerAttrIndex++) {
+                Map businessOwnerAttrInfo = businessOwnerAttrInfos.get(_ownerAttrIndex);
+                flushBusinessOwnerAttrInfo(businessOwnerAttrInfo,StatusConstant.STATUS_CD_VALID);
+                ownerAttrServiceDaoImpl.updateOwnerAttrInfoInstance(businessOwnerAttrInfo);
+                if(businessOwnerAttrInfo.size() == 1) {
+                    dataFlowContext.addParamOut("attrId", businessOwnerAttrInfo.get("attr_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> ownerAttrInfo = ownerAttrServiceDaoImpl.getOwnerAttrInfo(info);
+        if(ownerAttrInfo != null && ownerAttrInfo.size() > 0){
+
+            //业主属性信息
+            List<Map> businessOwnerAttrInfos = ownerAttrServiceDaoImpl.getBusinessOwnerAttrInfo(delInfo);
+            //除非程序出错了,这里不会为空
+            if(businessOwnerAttrInfos == null || businessOwnerAttrInfos.size() == 0){
+                throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_INNER_ERROR,"撤单失败(ownerAttr),程序内部异常,请检查! "+delInfo);
+            }
+            for (int _ownerAttrIndex = 0; _ownerAttrIndex < businessOwnerAttrInfos.size();_ownerAttrIndex++) {
+                Map businessOwnerAttrInfo = businessOwnerAttrInfos.get(_ownerAttrIndex);
+                flushBusinessOwnerAttrInfo(businessOwnerAttrInfo,StatusConstant.STATUS_CD_VALID);
+                ownerAttrServiceDaoImpl.updateOwnerAttrInfoInstance(businessOwnerAttrInfo);
+            }
+        }
+
+    }
+
+
+
+    /**
+     * 处理 businessOwnerAttr 节点
+     * @param business 总的数据节点
+     * @param businessOwnerAttr 业主属性节点
+     */
+    private void doBusinessOwnerAttr(Business business,JSONObject businessOwnerAttr){
+
+        Assert.jsonObjectHaveKey(businessOwnerAttr,"attrId","businessOwnerAttr 节点下没有包含 attrId 节点");
+
+        if(businessOwnerAttr.getString("attrId").startsWith("-")){
+            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR,"attrId 错误,不能自动生成(必须已经存在的attrId)"+businessOwnerAttr);
+        }
+        //自动保存DEL
+        autoSaveDelBusinessOwnerAttr(business,businessOwnerAttr);
+
+        businessOwnerAttr.put("bId",business.getbId());
+        businessOwnerAttr.put("operate", StatusConstant.OPERATE_ADD);
+        //保存业主属性信息
+        ownerAttrServiceDaoImpl.saveBusinessOwnerAttrInfo(businessOwnerAttr);
+
+    }
+
+
+
+    @Override
+    public IOwnerAttrServiceDao getOwnerAttrServiceDaoImpl() {
+        return ownerAttrServiceDaoImpl;
+    }
+
+    public void setOwnerAttrServiceDaoImpl(IOwnerAttrServiceDao ownerAttrServiceDaoImpl) {
+        this.ownerAttrServiceDaoImpl = ownerAttrServiceDaoImpl;
+    }
+
+
+
+}

+ 86 - 0
java110-bean/src/main/java/com/java110/dto/owner/OwnerAttrDto.java

@@ -0,0 +1,86 @@
+package com.java110.dto.owner;
+
+import com.java110.dto.PageDto;
+
+import java.io.Serializable;
+import java.util.Date;
+
+/**
+ * @ClassName FloorDto
+ * @Description 业主属性数据层封装
+ * @Author wuxw
+ * @Date 2019/4/24 8:52
+ * @Version 1.0
+ * add by wuxw 2019/4/24
+ **/
+public class OwnerAttrDto extends PageDto implements Serializable {
+
+    private String attrId;
+    private String specCd;
+    private String communityId;
+    private String value;
+    private String memberId;
+
+
+    private Date createTime;
+
+    private String statusCd = "0";
+
+
+    public String getAttrId() {
+        return attrId;
+    }
+
+    public void setAttrId(String attrId) {
+        this.attrId = attrId;
+    }
+
+    public String getSpecCd() {
+        return specCd;
+    }
+
+    public void setSpecCd(String specCd) {
+        this.specCd = specCd;
+    }
+
+    public String getCommunityId() {
+        return communityId;
+    }
+
+    public void setCommunityId(String communityId) {
+        this.communityId = communityId;
+    }
+
+    public String getValue() {
+        return value;
+    }
+
+    public void setValue(String value) {
+        this.value = value;
+    }
+
+    public String getMemberId() {
+        return memberId;
+    }
+
+    public void setMemberId(String memberId) {
+        this.memberId = memberId;
+    }
+
+
+    public Date getCreateTime() {
+        return createTime;
+    }
+
+    public void setCreateTime(Date createTime) {
+        this.createTime = createTime;
+    }
+
+    public String getStatusCd() {
+        return statusCd;
+    }
+
+    public void setStatusCd(String statusCd) {
+        this.statusCd = statusCd;
+    }
+}

+ 54 - 0
java110-bean/src/main/java/com/java110/po/owner/OwnerAttrPo.java

@@ -0,0 +1,54 @@
+package com.java110.po.owner;
+
+import java.io.Serializable;
+
+public class OwnerAttrPo implements Serializable {
+
+    private String attrId;
+    private String specCd;
+    private String communityId;
+    private String value;
+    private String memberId;
+
+    public String getAttrId() {
+        return attrId;
+    }
+
+    public void setAttrId(String attrId) {
+        this.attrId = attrId;
+    }
+
+    public String getSpecCd() {
+        return specCd;
+    }
+
+    public void setSpecCd(String specCd) {
+        this.specCd = specCd;
+    }
+
+    public String getCommunityId() {
+        return communityId;
+    }
+
+    public void setCommunityId(String communityId) {
+        this.communityId = communityId;
+    }
+
+    public String getValue() {
+        return value;
+    }
+
+    public void setValue(String value) {
+        this.value = value;
+    }
+
+    public String getMemberId() {
+        return memberId;
+    }
+
+    public void setMemberId(String memberId) {
+        this.memberId = memberId;
+    }
+
+
+}

+ 41 - 0
java110-core/src/main/java/com/java110/core/smo/user/IOwnerAttrInnerServiceSMO.java

@@ -0,0 +1,41 @@
+package com.java110.core.smo.user;
+
+import com.java110.config.feign.FeignConfiguration;
+import com.java110.dto.owner.OwnerAttrDto;
+import org.springframework.cloud.openfeign.FeignClient;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestMethod;
+
+import java.util.List;
+
+/**
+ * @ClassName IOwnerAttrInnerServiceSMO
+ * @Description 业主属性接口类
+ * @Author wuxw
+ * @Date 2019/4/24 9:04
+ * @Version 1.0
+ * add by wuxw 2019/4/24
+ **/
+@FeignClient(name = "user-service", configuration = {FeignConfiguration.class})
+@RequestMapping("/ownerAttrApi")
+public interface IOwnerAttrInnerServiceSMO {
+
+    /**
+     * <p>查询小区楼信息</p>
+     *
+     * @param ownerAttrDto 数据对象分享
+     * @return OwnerAttrDto 对象数据
+     */
+    @RequestMapping(value = "/queryOwnerAttrs", method = RequestMethod.POST)
+    List<OwnerAttrDto> queryOwnerAttrs(@RequestBody OwnerAttrDto ownerAttrDto);
+
+    /**
+     * 查询<p>小区楼</p>总记录数
+     *
+     * @param ownerAttrDto 数据对象分享
+     * @return 小区下的小区楼记录数
+     */
+    @RequestMapping(value = "/queryOwnerAttrsCount", method = RequestMethod.POST)
+    int queryOwnerAttrsCount(@RequestBody OwnerAttrDto ownerAttrDto);
+}

+ 186 - 0
java110-db/src/main/resources/mapper/user/OwnerAttrServiceDaoImplMapper.xml

@@ -0,0 +1,186 @@
+<?xml version="1.0" encoding="UTF-8" ?>
+<!DOCTYPE mapper
+        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
+        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="ownerAttrServiceDaoImpl">
+
+    <!-- 保存业主属性信息 add by wuxw 2018-07-03 -->
+    <insert id="saveBusinessOwnerAttrInfo" parameterType="Map">
+        insert into business_building_owner_attr(
+        attr_id,operate,create_time,spec_cd,b_id,community_id,value,member_id
+        ) values (
+        #{attrId},#{operate},#{createTime},#{specCd},#{bId},#{communityId},#{value},#{memberId}
+        )
+    </insert>
+
+
+    <!-- 查询业主属性信息(Business) add by wuxw 2018-07-03 -->
+    <select id="getBusinessOwnerAttrInfo" parameterType="Map" resultType="Map">
+        select t.attr_id,t.attr_id attrId,t.operate,t.create_time,t.create_time createTime,t.spec_cd,t.spec_cd
+        specCd,t.b_id,t.b_id bId,t.community_id,t.community_id communityId,t.value,t.member_id,t.member_id memberId
+        from business_building_owner_attr t
+        where 1 =1
+        <if test="attrId !=null and attrId != ''">
+            and t.attr_id= #{attrId}
+        </if>
+        <if test="operate !=null and operate != ''">
+            and t.operate= #{operate}
+        </if>
+        <if test="createTime !=null and createTime != ''">
+            and t.create_time= #{createTime}
+        </if>
+        <if test="specCd !=null and specCd != ''">
+            and t.spec_cd= #{specCd}
+        </if>
+        <if test="bId !=null and bId != ''">
+            and t.b_id= #{bId}
+        </if>
+        <if test="communityId !=null and communityId != ''">
+            and t.community_id= #{communityId}
+        </if>
+        <if test="value !=null and value != ''">
+            and t.value= #{value}
+        </if>
+        <if test="memberId !=null and memberId != ''">
+            and t.member_id= #{memberId}
+        </if>
+
+    </select>
+
+
+    <!-- 保存业主属性信息至 instance表中 add by wuxw 2018-07-03 -->
+    <insert id="saveOwnerAttrInfoInstance" parameterType="Map">
+        insert into building_owner_attr(
+        attr_id,create_time,spec_cd,status_cd,b_id,community_id,value,member_id
+        ) select t.attr_id,t.create_time,t.spec_cd,'0',t.b_id,t.community_id,t.value,t.member_id from
+        business_building_owner_attr t where 1=1
+        <if test="attrId !=null and attrId != ''">
+            and t.attr_id= #{attrId}
+        </if>
+        and t.operate= 'ADD'
+        <if test="createTime !=null and createTime != ''">
+            and t.create_time= #{createTime}
+        </if>
+        <if test="specCd !=null and specCd != ''">
+            and t.spec_cd= #{specCd}
+        </if>
+        <if test="bId !=null and bId != ''">
+            and t.b_id= #{bId}
+        </if>
+        <if test="communityId !=null and communityId != ''">
+            and t.community_id= #{communityId}
+        </if>
+        <if test="value !=null and value != ''">
+            and t.value= #{value}
+        </if>
+        <if test="memberId !=null and memberId != ''">
+            and t.member_id= #{memberId}
+        </if>
+
+    </insert>
+
+
+    <!-- 查询业主属性信息 add by wuxw 2018-07-03 -->
+    <select id="getOwnerAttrInfo" parameterType="Map" resultType="Map">
+        select t.attr_id,t.attr_id attrId,t.create_time,t.create_time createTime,t.spec_cd,t.spec_cd
+        specCd,t.status_cd,t.status_cd statusCd,t.b_id,t.b_id bId,t.community_id,t.community_id
+        communityId,t.value,t.member_id,t.member_id memberId
+        from building_owner_attr t
+        where 1 =1
+        <if test="attrId !=null and attrId != ''">
+            and t.attr_id= #{attrId}
+        </if>
+        <if test="createTime !=null and createTime != ''">
+            and t.create_time= #{createTime}
+        </if>
+        <if test="specCd !=null and specCd != ''">
+            and t.spec_cd= #{specCd}
+        </if>
+        <if test="statusCd !=null and statusCd != ''">
+            and t.status_cd= #{statusCd}
+        </if>
+        <if test="bId !=null and bId != ''">
+            and t.b_id= #{bId}
+        </if>
+        <if test="communityId !=null and communityId != ''">
+            and t.community_id= #{communityId}
+        </if>
+        <if test="value !=null and value != ''">
+            and t.value= #{value}
+        </if>
+        <if test="memberId !=null and memberId != ''">
+            and t.member_id= #{memberId}
+        </if>
+        order by t.create_time desc
+        <if test="page != -1 and page != null ">
+            limit #{page}, #{row}
+        </if>
+
+    </select>
+
+
+    <!-- 修改业主属性信息 add by wuxw 2018-07-03 -->
+    <update id="updateOwnerAttrInfoInstance" parameterType="Map">
+        update building_owner_attr t set t.status_cd = #{statusCd}
+        <if test="newBId != null and newBId != ''">
+            ,t.b_id = #{newBId}
+        </if>
+        <if test="createTime !=null and createTime != ''">
+            , t.create_time= #{createTime}
+        </if>
+        <if test="specCd !=null and specCd != ''">
+            , t.spec_cd= #{specCd}
+        </if>
+        <if test="communityId !=null and communityId != ''">
+            , t.community_id= #{communityId}
+        </if>
+        <if test="value !=null and value != ''">
+            , t.value= #{value}
+        </if>
+        <if test="memberId !=null and memberId != ''">
+            , t.member_id= #{memberId}
+        </if>
+        where 1=1
+        <if test="attrId !=null and attrId != ''">
+            and t.attr_id= #{attrId}
+        </if>
+        <if test="bId !=null and bId != ''">
+            and t.b_id= #{bId}
+        </if>
+
+    </update>
+
+    <!-- 查询业主属性数量 add by wuxw 2018-07-03 -->
+    <select id="queryOwnerAttrsCount" parameterType="Map" resultType="Map">
+        select count(1) count
+        from building_owner_attr t
+        where 1 =1
+        <if test="attrId !=null and attrId != ''">
+            and t.attr_id= #{attrId}
+        </if>
+        <if test="createTime !=null and createTime != ''">
+            and t.create_time= #{createTime}
+        </if>
+        <if test="specCd !=null and specCd != ''">
+            and t.spec_cd= #{specCd}
+        </if>
+        <if test="statusCd !=null and statusCd != ''">
+            and t.status_cd= #{statusCd}
+        </if>
+        <if test="bId !=null and bId != ''">
+            and t.b_id= #{bId}
+        </if>
+        <if test="communityId !=null and communityId != ''">
+            and t.community_id= #{communityId}
+        </if>
+        <if test="value !=null and value != ''">
+            and t.value= #{value}
+        </if>
+        <if test="memberId !=null and memberId != ''">
+            and t.member_id= #{memberId}
+        </if>
+
+
+    </select>
+
+</mapper>

+ 28 - 33
java110-generator/src/main/resources/back/template_1.json

@@ -1,48 +1,43 @@
 {
   "autoMove": true,
-  "id": "typeUserId",
-  "name": "repairTypeUser",
-  "desc": "报修设置",
-  "shareParam": "communityId",
-  "shareColumn": "community_id",
-  "shareName": "community",
-  "newBusinessTypeCd": "BUSINESS_TYPE_SAVE_REPAIR_TYPE_USER",
-  "updateBusinessTypeCd": "BUSINESS_TYPE_UPDATE_REPAIR_TYPE_USER",
-  "deleteBusinessTypeCd": "BUSINESS_TYPE_DELETE_REPAIR_TYPE_USER",
-  "newBusinessTypeCdValue": "132100030001",
-  "updateBusinessTypeCdValue": "132100040001",
-  "deleteBusinessTypeCdValue": "132100050001",
-  "businessTableName": "business_repair_type_user",
-  "tableName": "r_repair_type_user",
+  "id": "attrId",
+  "name": "ownerAttr",
+  "desc": "业主属性",
+  "shareParam": "community_id",
+  "shareColumn": "communityId",
+  "shareName": "user",
+  "newBusinessTypeCd": "BUSINESS_TYPE_SAVE_OWNER_ATTR_INFO",
+  "updateBusinessTypeCd": "BUSINESS_TYPE_UPDATE_OWNER_ATTR_INFO",
+  "deleteBusinessTypeCd": "BUSINESS_TYPE_DELETE_OWNER_ATTR_INFO",
+  "newBusinessTypeCdValue": "110200030001",
+  "updateBusinessTypeCdValue": "110200040001",
+  "deleteBusinessTypeCdValue": "110200050001",
+  "businessTableName": "business_building_owner_attr",
+  "tableName": "building_owner_attr",
   "param": {
-    "typeUserId": "type_user_id",
-    "userId": "user_id",
-    "userName": "user_name",
+    "attrId": "attr_id",
     "bId": "b_id",
-    "repairType": "repair_type",
-    "remark": "remark",
-    "state": "state",
-    "communityId": "community_id",
+    "memberId": "member_id",
+    "specCd": "spec_cd",
+    "value": "value",
     "statusCd": "status_cd",
+    "createTime": "create_time",
+    "communityId": "community_id",
     "operate": "operate"
   },
   "required": [
     {
-      "code": "userId",
-      "msg": "用户不能为空"
-    },
-    {
-      "code": "userName",
-      "msg": "用户名称不能为空"
+
+      "code": "memberId",
+      "msg": "业主ID不能为空"
     },
     {
-      "code": "repairType",
-      "msg": "报修类型不能为空"
+      "code": "specCd",
+      "msg": "任务属性不能为空"
     },
     {
-      "code": "communityId",
-      "msg": "小区不能为空"
+      "code": "value",
+      "msg": "任务属性值不能为空"
     }
   ]
-}
-
+}

+ 48 - 0
java110-generator/src/main/resources/back/template_repairTypeUser.json

@@ -0,0 +1,48 @@
+{
+  "autoMove": true,
+  "id": "typeUserId",
+  "name": "repairTypeUser",
+  "desc": "报修设置",
+  "shareParam": "communityId",
+  "shareColumn": "community_id",
+  "shareName": "community",
+  "newBusinessTypeCd": "BUSINESS_TYPE_SAVE_REPAIR_TYPE_USER",
+  "updateBusinessTypeCd": "BUSINESS_TYPE_UPDATE_REPAIR_TYPE_USER",
+  "deleteBusinessTypeCd": "BUSINESS_TYPE_DELETE_REPAIR_TYPE_USER",
+  "newBusinessTypeCdValue": "132100030001",
+  "updateBusinessTypeCdValue": "132100040001",
+  "deleteBusinessTypeCdValue": "132100050001",
+  "businessTableName": "business_repair_type_user",
+  "tableName": "r_repair_type_user",
+  "param": {
+    "typeUserId": "type_user_id",
+    "userId": "user_id",
+    "userName": "user_name",
+    "bId": "b_id",
+    "repairType": "repair_type",
+    "remark": "remark",
+    "state": "state",
+    "communityId": "community_id",
+    "statusCd": "status_cd",
+    "operate": "operate"
+  },
+  "required": [
+    {
+      "code": "userId",
+      "msg": "用户不能为空"
+    },
+    {
+      "code": "userName",
+      "msg": "用户名称不能为空"
+    },
+    {
+      "code": "repairType",
+      "msg": "报修类型不能为空"
+    },
+    {
+      "code": "communityId",
+      "msg": "小区不能为空"
+    }
+  ]
+}
+

+ 17 - 0
java110-utils/src/main/java/com/java110/utils/constant/BusinessTypeConstant.java

@@ -89,6 +89,23 @@ public class BusinessTypeConstant {
     public static final String BUSINESS_TYPE_DELETE_OWNER_INFO = "110100050001";
 
 
+    /**
+     * 增加业主
+     */
+    public static final String BUSINESS_TYPE_SAVE_OWNER_ATTR_INFO = "110200030001";
+
+    /**tia
+     * 修改业主
+     */
+    public static final String BUSINESS_TYPE_UPDATE_OWNER_ATTR_INFO = "110200040001";
+
+
+    /**
+     * 删除业主
+     */
+    public static final String BUSINESS_TYPE_DELETE_OWNER_ATTR_INFO = "110200050001";
+
+
     /**
      * 房屋购买
      */

+ 31 - 0
java110-utils/src/main/java/com/java110/utils/constant/ServiceCodeOwnerAttrConstant.java

@@ -0,0 +1,31 @@
+package com.java110.utils.constant;
+
+/**
+ * 业主属性常量类
+ * Created by wuxw on 2017/5/20.
+ */
+public class ServiceCodeOwnerAttrConstant {
+
+    /**
+     * 添加 业主属性
+     */
+    public static final String ADD_OWNERATTR = "owner.saveOwnerAttr";
+
+
+    /**
+     * 修改 业主属性
+     */
+    public static final String UPDATE_OWNERATTR = "owner.updateOwnerAttr";
+    /**
+     * 删除 业主属性
+     */
+    public static final String DELETE_OWNERATTR = "owner.deleteOwnerAttr";
+
+
+    /**
+     * 查询 业主属性
+     */
+    public static final String LIST_OWNERATTRS = "owner.listOwnerAttrs";
+
+
+}

+ 38 - 0
service-api/src/main/java/com/java110/api/bmo/ownerAttr/IOwnerAttrBMO.java

@@ -0,0 +1,38 @@
+package com.java110.api.bmo.ownerAttr;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.api.bmo.IApiBaseBMO;
+import com.java110.core.context.DataFlowContext;
+
+public interface IOwnerAttrBMO extends IApiBaseBMO {
+
+
+    /**
+     * 添加业主属性
+     * @param paramInJson
+     * @param dataFlowContext
+     * @return
+     */
+     void addOwnerAttr(JSONObject paramInJson, DataFlowContext dataFlowContext);
+
+    /**
+     * 添加业主属性信息
+     *
+     * @param paramInJson     接口调用放传入入参
+     * @param dataFlowContext 数据上下文
+     * @return 订单服务能够接受的报文
+     */
+     void updateOwnerAttr(JSONObject paramInJson, DataFlowContext dataFlowContext);
+
+    /**
+     * 删除业主属性
+     *
+     * @param paramInJson     接口调用放传入入参
+     * @param dataFlowContext 数据上下文
+     * @return 订单服务能够接受的报文
+     */
+     void deleteOwnerAttr(JSONObject paramInJson, DataFlowContext dataFlowContext);
+
+
+
+}

+ 61 - 0
service-api/src/main/java/com/java110/api/bmo/ownerAttr/impl/OwnerAttrBMOImpl.java

@@ -0,0 +1,61 @@
+package com.java110.api.bmo.ownerAttr.impl;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.api.bmo.ApiBaseBMO;
+import com.java110.api.bmo.ownerAttr.IOwnerAttrBMO;
+import com.java110.core.context.DataFlowContext;
+import com.java110.core.smo.user.IOwnerAttrInnerServiceSMO;
+import com.java110.po.owner.OwnerAttrPo;
+import com.java110.utils.constant.BusinessTypeConstant;
+import com.java110.utils.util.BeanConvertUtil;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+
+@Service("ownerAttrBMOImpl")
+public class OwnerAttrBMOImpl extends ApiBaseBMO implements IOwnerAttrBMO {
+
+    @Autowired
+    private IOwnerAttrInnerServiceSMO ownerAttrInnerServiceSMOImpl;
+
+    /**
+     * 添加小区信息
+     *
+     * @param paramInJson     接口调用放传入入参
+     * @param dataFlowContext 数据上下文
+     * @return 订单服务能够接受的报文
+     */
+    public void addOwnerAttr(JSONObject paramInJson, DataFlowContext dataFlowContext) {
+
+        paramInJson.put("attrId", "-1");
+        OwnerAttrPo ownerAttrPo = BeanConvertUtil.covertBean(paramInJson, OwnerAttrPo.class);
+        super.insert(dataFlowContext, ownerAttrPo, BusinessTypeConstant.BUSINESS_TYPE_SAVE_OWNER_ATTR_INFO);
+    }
+
+
+    /**
+     * 添加活动信息
+     *
+     * @param paramInJson     接口调用放传入入参
+     * @param dataFlowContext 数据上下文
+     * @return 订单服务能够接受的报文
+     */
+    public void updateOwnerAttr(JSONObject paramInJson, DataFlowContext dataFlowContext) {
+        OwnerAttrPo ownerAttrPo = BeanConvertUtil.covertBean(paramInJson, OwnerAttrPo.class);
+        super.update(dataFlowContext, ownerAttrPo, BusinessTypeConstant.BUSINESS_TYPE_UPDATE_OWNER_ATTR_INFO);
+    }
+
+
+    /**
+     * 添加小区信息
+     *
+     * @param paramInJson     接口调用放传入入参
+     * @param dataFlowContext 数据上下文
+     * @return 订单服务能够接受的报文
+     */
+    public void deleteOwnerAttr(JSONObject paramInJson, DataFlowContext dataFlowContext) {
+
+        OwnerAttrPo ownerAttrPo = BeanConvertUtil.covertBean(paramInJson, OwnerAttrPo.class);
+        super.update(dataFlowContext, ownerAttrPo, BusinessTypeConstant.BUSINESS_TYPE_DELETE_OWNER_ATTR_INFO);
+    }
+
+}

+ 49 - 0
service-api/src/main/java/com/java110/api/listener/owner/DeleteOwnerAttrListener.java

@@ -0,0 +1,49 @@
+package com.java110.api.listener.owner;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.api.bmo.ownerAttr.IOwnerAttrBMO;
+import com.java110.api.listener.AbstractServiceApiPlusListener;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.core.event.service.api.ServiceDataFlowEvent;
+import com.java110.utils.constant.ServiceCodeOwnerAttrConstant;
+import com.java110.utils.util.Assert;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.HttpMethod;
+
+
+/**
+ * 保存小区侦听
+ * add by wuxw 2019-06-30
+ */
+@Java110Listener("deleteOwnerAttrListener")
+public class DeleteOwnerAttrListener extends AbstractServiceApiPlusListener {
+
+    @Autowired
+    private IOwnerAttrBMO ownerAttrBMOImpl;
+
+    @Override
+    protected void validate(ServiceDataFlowEvent event, JSONObject reqJson) {
+        //Assert.hasKeyAndValue(reqJson, "xxx", "xxx");
+
+        Assert.hasKeyAndValue(reqJson, "attrId", "attrId不能为空");
+
+    }
+
+    @Override
+    protected void doSoService(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson) {
+
+        ownerAttrBMOImpl.deleteOwnerAttr(reqJson, context);
+    }
+
+    @Override
+    public String getServiceCode() {
+        return ServiceCodeOwnerAttrConstant.DELETE_OWNERATTR;
+    }
+
+    @Override
+    public HttpMethod getHttpMethod() {
+        return HttpMethod.POST;
+    }
+
+}

+ 82 - 0
service-api/src/main/java/com/java110/api/listener/owner/ListOwnerAttrsListener.java

@@ -0,0 +1,82 @@
+package com.java110.api.listener.owner;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.api.listener.AbstractServiceApiListener;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.core.event.service.api.ServiceDataFlowEvent;
+import com.java110.core.smo.user.IOwnerAttrInnerServiceSMO;
+import com.java110.dto.owner.OwnerAttrDto;
+import com.java110.utils.constant.ServiceCodeOwnerAttrConstant;
+import com.java110.utils.util.BeanConvertUtil;
+import com.java110.vo.ResultVo;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.HttpMethod;
+import org.springframework.http.HttpStatus;
+import org.springframework.http.ResponseEntity;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * 查询小区侦听类
+ */
+@Java110Listener("listOwnerAttrsListener")
+public class ListOwnerAttrsListener extends AbstractServiceApiListener {
+
+    @Autowired
+    private IOwnerAttrInnerServiceSMO ownerAttrInnerServiceSMOImpl;
+
+    @Override
+    public String getServiceCode() {
+        return ServiceCodeOwnerAttrConstant.LIST_OWNERATTRS;
+    }
+
+    @Override
+    public HttpMethod getHttpMethod() {
+        return HttpMethod.GET;
+    }
+
+
+    @Override
+    public int getOrder() {
+        return DEFAULT_ORDER;
+    }
+
+
+    public IOwnerAttrInnerServiceSMO getOwnerAttrInnerServiceSMOImpl() {
+        return ownerAttrInnerServiceSMOImpl;
+    }
+
+    public void setOwnerAttrInnerServiceSMOImpl(IOwnerAttrInnerServiceSMO ownerAttrInnerServiceSMOImpl) {
+        this.ownerAttrInnerServiceSMOImpl = ownerAttrInnerServiceSMOImpl;
+    }
+
+    @Override
+    protected void validate(ServiceDataFlowEvent event, JSONObject reqJson) {
+        super.validatePageInfo(reqJson);
+    }
+
+    @Override
+    protected void doSoService(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson) {
+
+        OwnerAttrDto ownerAttrDto = BeanConvertUtil.covertBean(reqJson, OwnerAttrDto.class);
+
+        int count = ownerAttrInnerServiceSMOImpl.queryOwnerAttrsCount(ownerAttrDto);
+
+        List<OwnerAttrDto> ownerAttrDtos = null;
+
+        if (count > 0) {
+            ownerAttrDtos = ownerAttrInnerServiceSMOImpl.queryOwnerAttrs(ownerAttrDto);
+        } else {
+            ownerAttrDtos = new ArrayList<>();
+        }
+
+        ResultVo resultVo = new ResultVo((int) Math.ceil((double) count / (double) reqJson.getInteger("row")), count, ownerAttrDtos);
+
+        ResponseEntity<String> responseEntity = new ResponseEntity<String>(resultVo.toString(), HttpStatus.OK);
+
+        context.setResponseEntity(responseEntity);
+
+    }
+}

+ 49 - 0
service-api/src/main/java/com/java110/api/listener/owner/SaveOwnerAttrListener.java

@@ -0,0 +1,49 @@
+package com.java110.api.listener.owner;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.api.bmo.ownerAttr.IOwnerAttrBMO;
+import com.java110.api.listener.AbstractServiceApiPlusListener;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.core.event.service.api.ServiceDataFlowEvent;
+import com.java110.utils.constant.ServiceCodeOwnerAttrConstant;
+import com.java110.utils.util.Assert;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.HttpMethod;
+
+/**
+ * 保存商户侦听
+ * add by wuxw 2019-06-30
+ */
+@Java110Listener("saveOwnerAttrListener")
+public class SaveOwnerAttrListener extends AbstractServiceApiPlusListener {
+
+    @Autowired
+    private IOwnerAttrBMO ownerAttrBMOImpl;
+
+    @Override
+    protected void validate(ServiceDataFlowEvent event, JSONObject reqJson) {
+        //Assert.hasKeyAndValue(reqJson, "xxx", "xxx");
+
+        Assert.hasKeyAndValue(reqJson, "memberId", "请求报文中未包含memberId");
+        Assert.hasKeyAndValue(reqJson, "specCd", "请求报文中未包含specCd");
+        Assert.hasKeyAndValue(reqJson, "value", "请求报文中未包含value");
+
+    }
+
+    @Override
+    protected void doSoService(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson) {
+        ownerAttrBMOImpl.addOwnerAttr(reqJson, context);
+    }
+
+    @Override
+    public String getServiceCode() {
+        return ServiceCodeOwnerAttrConstant.ADD_OWNERATTR;
+    }
+
+    @Override
+    public HttpMethod getHttpMethod() {
+        return HttpMethod.POST;
+    }
+
+}

+ 50 - 0
service-api/src/main/java/com/java110/api/listener/owner/UpdateOwnerAttrListener.java

@@ -0,0 +1,50 @@
+package com.java110.api.listener.owner;
+
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.api.bmo.ownerAttr.IOwnerAttrBMO;
+import com.java110.api.listener.AbstractServiceApiPlusListener;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.core.event.service.api.ServiceDataFlowEvent;
+import com.java110.utils.constant.ServiceCodeOwnerAttrConstant;
+import com.java110.utils.util.Assert;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.HttpMethod;
+
+/**
+ * 保存业主属性侦听
+ * add by wuxw 2019-06-30
+ */
+@Java110Listener("updateOwnerAttrListener")
+public class UpdateOwnerAttrListener extends AbstractServiceApiPlusListener {
+
+    @Autowired
+    private IOwnerAttrBMO ownerAttrBMOImpl;
+
+    @Override
+    protected void validate(ServiceDataFlowEvent event, JSONObject reqJson) {
+
+        Assert.hasKeyAndValue(reqJson, "attrId", "attrId不能为空");
+        Assert.hasKeyAndValue(reqJson, "memberId", "请求报文中未包含memberId");
+        Assert.hasKeyAndValue(reqJson, "specCd", "请求报文中未包含specCd");
+        Assert.hasKeyAndValue(reqJson, "value", "请求报文中未包含value");
+
+    }
+
+    @Override
+    protected void doSoService(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson) {
+
+        ownerAttrBMOImpl.updateOwnerAttr(reqJson, context);
+    }
+
+    @Override
+    public String getServiceCode() {
+        return ServiceCodeOwnerAttrConstant.UPDATE_OWNERATTR;
+    }
+
+    @Override
+    public HttpMethod getHttpMethod() {
+        return HttpMethod.POST;
+    }
+}

+ 81 - 0
service-user/src/main/java/com/java110/user/dao/IOwnerAttrServiceDao.java

@@ -0,0 +1,81 @@
+package com.java110.user.dao;
+
+
+import com.java110.utils.exception.DAOException;
+import com.java110.entity.merchant.BoMerchant;
+import com.java110.entity.merchant.BoMerchantAttr;
+import com.java110.entity.merchant.Merchant;
+import com.java110.entity.merchant.MerchantAttr;
+
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 业主属性组件内部之间使用,没有给外围系统提供服务能力
+ * 业主属性服务接口类,要求全部以字符串传输,方便微服务化
+ * 新建客户,修改客户,删除客户,查询客户等功能
+ *
+ * Created by wuxw on 2016/12/27.
+ */
+public interface IOwnerAttrServiceDao {
+
+    /**
+     * 保存 业主属性信息
+     * @param businessOwnerAttrInfo 业主属性信息 封装
+     * @throws DAOException 操作数据库异常
+     */
+    void saveBusinessOwnerAttrInfo(Map businessOwnerAttrInfo) throws DAOException;
+
+
+
+    /**
+     * 查询业主属性信息(business过程)
+     * 根据bId 查询业主属性信息
+     * @param info bId 信息
+     * @return 业主属性信息
+     * @throws DAOException DAO异常
+     */
+    List<Map> getBusinessOwnerAttrInfo(Map info) throws DAOException;
+
+
+
+
+    /**
+     * 保存 业主属性信息 Business数据到 Instance中
+     * @param info
+     * @throws DAOException DAO异常
+     */
+    void saveOwnerAttrInfoInstance(Map info) throws DAOException;
+
+
+
+
+    /**
+     * 查询业主属性信息(instance过程)
+     * 根据bId 查询业主属性信息
+     * @param info bId 信息
+     * @return 业主属性信息
+     * @throws DAOException DAO异常
+     */
+    List<Map> getOwnerAttrInfo(Map info) throws DAOException;
+
+
+
+    /**
+     * 修改业主属性信息
+     * @param info 修改信息
+     * @throws DAOException DAO异常
+     */
+    void updateOwnerAttrInfoInstance(Map info) throws DAOException;
+
+
+    /**
+     * 查询业主属性总数
+     *
+     * @param info 业主属性信息
+     * @return 业主属性数量
+     */
+    int queryOwnerAttrsCount(Map info);
+
+}

+ 130 - 0
service-user/src/main/java/com/java110/user/dao/impl/OwnerAttrServiceDaoImpl.java

@@ -0,0 +1,130 @@
+package com.java110.user.dao.impl;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.utils.constant.ResponseConstant;
+import com.java110.utils.exception.DAOException;
+import com.java110.utils.util.DateUtil;
+import com.java110.core.base.dao.BaseServiceDao;
+import com.java110.user.dao.IOwnerAttrServiceDao;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 业主属性服务 与数据库交互
+ * Created by wuxw on 2017/4/5.
+ */
+@Service("ownerAttrServiceDaoImpl")
+//@Transactional
+public class OwnerAttrServiceDaoImpl extends BaseServiceDao implements IOwnerAttrServiceDao {
+
+    private static Logger logger = LoggerFactory.getLogger(OwnerAttrServiceDaoImpl.class);
+
+    /**
+     * 业主属性信息封装
+     * @param businessOwnerAttrInfo 业主属性信息 封装
+     * @throws DAOException DAO异常
+     */
+    @Override
+    public void saveBusinessOwnerAttrInfo(Map businessOwnerAttrInfo) throws DAOException {
+        businessOwnerAttrInfo.put("month", DateUtil.getCurrentMonth());
+        // 查询business_user 数据是否已经存在
+        logger.debug("保存业主属性信息 入参 businessOwnerAttrInfo : {}",businessOwnerAttrInfo);
+        int saveFlag = sqlSessionTemplate.insert("ownerAttrServiceDaoImpl.saveBusinessOwnerAttrInfo",businessOwnerAttrInfo);
+
+        if(saveFlag < 1){
+            throw new DAOException(ResponseConstant.RESULT_PARAM_ERROR,"保存业主属性数据失败:"+ JSONObject.toJSONString(businessOwnerAttrInfo));
+        }
+    }
+
+
+    /**
+     * 查询业主属性信息
+     * @param info bId 信息
+     * @return 业主属性信息
+     * @throws DAOException DAO异常
+     */
+    @Override
+    public List<Map> getBusinessOwnerAttrInfo(Map info) throws DAOException {
+
+        logger.debug("查询业主属性信息 入参 info : {}",info);
+
+        List<Map> businessOwnerAttrInfos = sqlSessionTemplate.selectList("ownerAttrServiceDaoImpl.getBusinessOwnerAttrInfo",info);
+
+        return businessOwnerAttrInfos;
+    }
+
+
+
+    /**
+     * 保存业主属性信息 到 instance
+     * @param info   bId 信息
+     * @throws DAOException DAO异常
+     */
+    @Override
+    public void saveOwnerAttrInfoInstance(Map info) throws DAOException {
+        logger.debug("保存业主属性信息Instance 入参 info : {}",info);
+
+        int saveFlag = sqlSessionTemplate.insert("ownerAttrServiceDaoImpl.saveOwnerAttrInfoInstance",info);
+
+        if(saveFlag < 1){
+            throw new DAOException(ResponseConstant.RESULT_PARAM_ERROR,"保存业主属性信息Instance数据失败:"+ JSONObject.toJSONString(info));
+        }
+    }
+
+
+    /**
+     * 查询业主属性信息(instance)
+     * @param info bId 信息
+     * @return List<Map>
+     * @throws DAOException DAO异常
+     */
+    @Override
+    public List<Map> getOwnerAttrInfo(Map info) throws DAOException {
+        logger.debug("查询业主属性信息 入参 info : {}",info);
+
+        List<Map> businessOwnerAttrInfos = sqlSessionTemplate.selectList("ownerAttrServiceDaoImpl.getOwnerAttrInfo",info);
+
+        return businessOwnerAttrInfos;
+    }
+
+
+    /**
+     * 修改业主属性信息
+     * @param info 修改信息
+     * @throws DAOException DAO异常
+     */
+    @Override
+    public void updateOwnerAttrInfoInstance(Map info) throws DAOException {
+        logger.debug("修改业主属性信息Instance 入参 info : {}",info);
+
+        int saveFlag = sqlSessionTemplate.update("ownerAttrServiceDaoImpl.updateOwnerAttrInfoInstance",info);
+
+        if(saveFlag < 1){
+            throw new DAOException(ResponseConstant.RESULT_PARAM_ERROR,"修改业主属性信息Instance数据失败:"+ JSONObject.toJSONString(info));
+        }
+    }
+
+     /**
+     * 查询业主属性数量
+     * @param info 业主属性信息
+     * @return 业主属性数量
+     */
+    @Override
+    public int queryOwnerAttrsCount(Map info) {
+        logger.debug("查询业主属性数据 入参 info : {}",info);
+
+        List<Map> businessOwnerAttrInfos = sqlSessionTemplate.selectList("ownerAttrServiceDaoImpl.queryOwnerAttrsCount", info);
+        if (businessOwnerAttrInfos.size() < 1) {
+            return 0;
+        }
+
+        return Integer.parseInt(businessOwnerAttrInfos.get(0).get("count").toString());
+    }
+
+
+}

+ 90 - 0
service-user/src/main/java/com/java110/user/listener/ownerAttr/AbstractOwnerAttrBusinessServiceDataFlowListener.java

@@ -0,0 +1,90 @@
+package com.java110.user.listener.ownerAttr;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.event.service.AbstractBusinessServiceDataFlowListener;
+import com.java110.entity.center.Business;
+import com.java110.user.dao.IOwnerAttrServiceDao;
+import com.java110.utils.constant.ResponseConstant;
+import com.java110.utils.constant.StatusConstant;
+import com.java110.utils.exception.ListenerExecuteException;
+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 AbstractOwnerAttrBusinessServiceDataFlowListener extends AbstractBusinessServiceDataFlowListener {
+    private static Logger logger = LoggerFactory.getLogger(AbstractOwnerAttrBusinessServiceDataFlowListener.class);
+
+
+    /**
+     * 获取 DAO工具类
+     *
+     * @return
+     */
+    public abstract IOwnerAttrServiceDao getOwnerAttrServiceDaoImpl();
+
+    /**
+     * 刷新 businessOwnerAttrInfo 数据
+     * 主要将 数据库 中字段和 接口传递字段建立关系
+     *
+     * @param businessOwnerAttrInfo
+     */
+    protected void flushBusinessOwnerAttrInfo(Map businessOwnerAttrInfo, String statusCd) {
+        businessOwnerAttrInfo.put("newBId", businessOwnerAttrInfo.get("b_id"));
+        businessOwnerAttrInfo.put("attrId", businessOwnerAttrInfo.get("attr_id"));
+        businessOwnerAttrInfo.put("operate", businessOwnerAttrInfo.get("operate"));
+        businessOwnerAttrInfo.put("createTime", businessOwnerAttrInfo.get("create_time"));
+        businessOwnerAttrInfo.put("specCd", businessOwnerAttrInfo.get("spec_cd"));
+        businessOwnerAttrInfo.put("communityId", businessOwnerAttrInfo.get("community_id"));
+        businessOwnerAttrInfo.put("value", businessOwnerAttrInfo.get("value"));
+        businessOwnerAttrInfo.put("memberId", businessOwnerAttrInfo.get("member_id"));
+        businessOwnerAttrInfo.remove("bId");
+        businessOwnerAttrInfo.put("statusCd", statusCd);
+    }
+
+
+    /**
+     * 当修改数据时,查询instance表中的数据 自动保存删除数据到business中
+     *
+     * @param businessOwnerAttr 业主属性信息
+     */
+    protected void autoSaveDelBusinessOwnerAttr(Business business, JSONObject businessOwnerAttr) {
+//自动插入DEL
+        Map info = new HashMap();
+        info.put("attrId", businessOwnerAttr.getString("attrId"));
+        info.put("statusCd", StatusConstant.STATUS_CD_VALID);
+        List<Map> currentOwnerAttrInfos = getOwnerAttrServiceDaoImpl().getOwnerAttrInfo(info);
+        if (currentOwnerAttrInfos == null || currentOwnerAttrInfos.size() != 1) {
+            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR, "未找到需要修改数据信息,入参错误或数据有问题,请检查" + info);
+        }
+
+        Map currentOwnerAttrInfo = currentOwnerAttrInfos.get(0);
+
+        currentOwnerAttrInfo.put("bId", business.getbId());
+
+        currentOwnerAttrInfo.put("attrId", currentOwnerAttrInfo.get("attr_id"));
+        currentOwnerAttrInfo.put("operate", currentOwnerAttrInfo.get("operate"));
+        currentOwnerAttrInfo.put("createTime", currentOwnerAttrInfo.get("create_time"));
+        currentOwnerAttrInfo.put("specCd", currentOwnerAttrInfo.get("spec_cd"));
+        currentOwnerAttrInfo.put("communityId", currentOwnerAttrInfo.get("community_id"));
+        currentOwnerAttrInfo.put("value", currentOwnerAttrInfo.get("value"));
+        currentOwnerAttrInfo.put("memberId", currentOwnerAttrInfo.get("member_id"));
+
+
+        currentOwnerAttrInfo.put("operate", StatusConstant.OPERATE_DEL);
+        getOwnerAttrServiceDaoImpl().saveBusinessOwnerAttrInfo(currentOwnerAttrInfo);
+        for (Object key : currentOwnerAttrInfo.keySet()) {
+            if (businessOwnerAttr.get(key) == null) {
+                businessOwnerAttr.put(key.toString(), currentOwnerAttrInfo.get(key));
+            }
+        }
+    }
+
+
+}

+ 180 - 0
service-user/src/main/java/com/java110/user/listener/ownerAttr/DeleteOwnerAttrInfoListener.java

@@ -0,0 +1,180 @@
+package com.java110.user.listener.ownerAttr;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.entity.center.Business;
+import com.java110.po.owner.OwnerAttrPo;
+import com.java110.user.dao.IOwnerAttrServiceDao;
+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 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;
+
+/**
+ * 删除业主属性信息 侦听
+ * <p>
+ * 处理节点
+ * 1、businessOwnerAttr:{} 业主属性基本信息节点
+ * 2、businessOwnerAttrAttr:[{}] 业主属性属性信息节点
+ * 3、businessOwnerAttrPhoto:[{}] 业主属性照片信息节点
+ * 4、businessOwnerAttrCerdentials:[{}] 业主属性证件信息节点
+ * 协议地址 :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("deleteOwnerAttrInfoListener")
+@Transactional
+public class DeleteOwnerAttrInfoListener extends AbstractOwnerAttrBusinessServiceDataFlowListener {
+
+    private final static Logger logger = LoggerFactory.getLogger(DeleteOwnerAttrInfoListener.class);
+    @Autowired
+    IOwnerAttrServiceDao ownerAttrServiceDaoImpl;
+
+    @Override
+    public int getOrder() {
+        return 3;
+    }
+
+    @Override
+    public String getBusinessTypeCd() {
+        return BusinessTypeConstant.BUSINESS_TYPE_DELETE_OWNER_ATTR_INFO;
+    }
+
+    /**
+     * 根据删除信息 查出Instance表中数据 保存至business表 (状态写DEL) 方便撤单时直接更新回去
+     *
+     * @param dataFlowContext 数据对象
+     * @param business        当前业务对象
+     */
+    @Override
+    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {
+        JSONObject data = business.getDatas();
+
+        Assert.notEmpty(data, "没有datas 节点,或没有子节点需要处理");
+
+        //处理 businessOwnerAttr 节点
+        if (data.containsKey(OwnerAttrPo.class.getSimpleName())) {
+            Object _obj = data.get(OwnerAttrPo.class.getSimpleName());
+            JSONArray businessOwnerAttrs = null;
+            if (_obj instanceof JSONObject) {
+                businessOwnerAttrs = new JSONArray();
+                businessOwnerAttrs.add(_obj);
+            } else {
+                businessOwnerAttrs = (JSONArray) _obj;
+            }
+            //JSONObject businessOwnerAttr = data.getJSONObject(OwnerAttrPo.class.getSimpleName());
+            for (int _ownerAttrIndex = 0; _ownerAttrIndex < businessOwnerAttrs.size(); _ownerAttrIndex++) {
+                JSONObject businessOwnerAttr = businessOwnerAttrs.getJSONObject(_ownerAttrIndex);
+                doBusinessOwnerAttr(business, businessOwnerAttr);
+                if (_obj instanceof JSONObject) {
+                    dataFlowContext.addParamOut("attrId", businessOwnerAttr.getString("attrId"));
+                }
+            }
+
+        }
+
+
+    }
+
+    /**
+     * 删除 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> businessOwnerAttrInfos = ownerAttrServiceDaoImpl.getBusinessOwnerAttrInfo(info);
+        if (businessOwnerAttrInfos != null && businessOwnerAttrInfos.size() > 0) {
+            for (int _ownerAttrIndex = 0; _ownerAttrIndex < businessOwnerAttrInfos.size(); _ownerAttrIndex++) {
+                Map businessOwnerAttrInfo = businessOwnerAttrInfos.get(_ownerAttrIndex);
+                flushBusinessOwnerAttrInfo(businessOwnerAttrInfo, StatusConstant.STATUS_CD_INVALID);
+                ownerAttrServiceDaoImpl.updateOwnerAttrInfoInstance(businessOwnerAttrInfo);
+                dataFlowContext.addParamOut("attrId", businessOwnerAttrInfo.get("attr_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> ownerAttrInfo = ownerAttrServiceDaoImpl.getOwnerAttrInfo(info);
+        if (ownerAttrInfo != null && ownerAttrInfo.size() > 0) {
+
+            //业主属性信息
+            List<Map> businessOwnerAttrInfos = ownerAttrServiceDaoImpl.getBusinessOwnerAttrInfo(delInfo);
+            //除非程序出错了,这里不会为空
+            if (businessOwnerAttrInfos == null || businessOwnerAttrInfos.size() == 0) {
+                throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_INNER_ERROR, "撤单失败(ownerAttr),程序内部异常,请检查! " + delInfo);
+            }
+            for (int _ownerAttrIndex = 0; _ownerAttrIndex < businessOwnerAttrInfos.size(); _ownerAttrIndex++) {
+                Map businessOwnerAttrInfo = businessOwnerAttrInfos.get(_ownerAttrIndex);
+                flushBusinessOwnerAttrInfo(businessOwnerAttrInfo, StatusConstant.STATUS_CD_VALID);
+                ownerAttrServiceDaoImpl.updateOwnerAttrInfoInstance(businessOwnerAttrInfo);
+            }
+        }
+    }
+
+
+    /**
+     * 处理 businessOwnerAttr 节点
+     *
+     * @param business          总的数据节点
+     * @param businessOwnerAttr 业主属性节点
+     */
+    private void doBusinessOwnerAttr(Business business, JSONObject businessOwnerAttr) {
+
+        Assert.jsonObjectHaveKey(businessOwnerAttr, "attrId", "businessOwnerAttr 节点下没有包含 attrId 节点");
+
+        if (businessOwnerAttr.getString("attrId").startsWith("-")) {
+            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR, "attrId 错误,不能自动生成(必须已经存在的attrId)" + businessOwnerAttr);
+        }
+        //自动插入DEL
+        autoSaveDelBusinessOwnerAttr(business, businessOwnerAttr);
+    }
+
+    @Override
+    public IOwnerAttrServiceDao getOwnerAttrServiceDaoImpl() {
+        return ownerAttrServiceDaoImpl;
+    }
+
+    public void setOwnerAttrServiceDaoImpl(IOwnerAttrServiceDao ownerAttrServiceDaoImpl) {
+        this.ownerAttrServiceDaoImpl = ownerAttrServiceDaoImpl;
+    }
+}

+ 181 - 0
service-user/src/main/java/com/java110/user/listener/ownerAttr/SaveOwnerAttrInfoListener.java

@@ -0,0 +1,181 @@
+package com.java110.user.listener.ownerAttr;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+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 com.java110.po.owner.OwnerAttrPo;
+import com.java110.user.dao.IOwnerAttrServiceDao;
+import com.java110.utils.constant.BusinessTypeConstant;
+import com.java110.utils.constant.StatusConstant;
+import com.java110.utils.util.Assert;
+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("saveOwnerAttrInfoListener")
+@Transactional
+public class SaveOwnerAttrInfoListener extends AbstractOwnerAttrBusinessServiceDataFlowListener {
+
+    private static Logger logger = LoggerFactory.getLogger(SaveOwnerAttrInfoListener.class);
+
+    @Autowired
+    private IOwnerAttrServiceDao ownerAttrServiceDaoImpl;
+
+    @Override
+    public int getOrder() {
+        return 0;
+    }
+
+    @Override
+    public String getBusinessTypeCd() {
+        return BusinessTypeConstant.BUSINESS_TYPE_SAVE_OWNER_ATTR_INFO;
+    }
+
+    /**
+     * 保存业主属性信息 business 表中
+     *
+     * @param dataFlowContext 数据对象
+     * @param business        当前业务对象
+     */
+    @Override
+    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {
+        JSONObject data = business.getDatas();
+        Assert.notEmpty(data, "没有datas 节点,或没有子节点需要处理");
+
+        //处理 businessOwnerAttr 节点
+        if (data.containsKey(OwnerAttrPo.class.getSimpleName())) {
+            Object bObj = data.get(OwnerAttrPo.class.getSimpleName());
+            JSONArray businessOwnerAttrs = null;
+            if (bObj instanceof JSONObject) {
+                businessOwnerAttrs = new JSONArray();
+                businessOwnerAttrs.add(bObj);
+            } else {
+                businessOwnerAttrs = (JSONArray) bObj;
+            }
+            //JSONObject businessOwnerAttr = data.getJSONObject(OwnerAttrPo.class.getSimpleName());
+            for (int bOwnerAttrIndex = 0; bOwnerAttrIndex < businessOwnerAttrs.size(); bOwnerAttrIndex++) {
+                JSONObject businessOwnerAttr = businessOwnerAttrs.getJSONObject(bOwnerAttrIndex);
+                doBusinessOwnerAttr(business, businessOwnerAttr);
+                if (bObj instanceof JSONObject) {
+                    dataFlowContext.addParamOut("attrId", businessOwnerAttr.getString("attrId"));
+                }
+            }
+        }
+    }
+
+    /**
+     * 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> businessOwnerAttrInfo = ownerAttrServiceDaoImpl.getBusinessOwnerAttrInfo(info);
+        if (businessOwnerAttrInfo != null && businessOwnerAttrInfo.size() > 0) {
+            reFreshShareColumn(info, businessOwnerAttrInfo.get(0));
+            ownerAttrServiceDaoImpl.saveOwnerAttrInfoInstance(info);
+            if (businessOwnerAttrInfo.size() == 1) {
+                dataFlowContext.addParamOut("attrId", businessOwnerAttrInfo.get(0).get("attr_id"));
+            }
+        }
+    }
+
+
+    /**
+     * 刷 分片字段
+     *
+     * @param info         查询对象
+     * @param businessInfo 小区ID
+     */
+    private void reFreshShareColumn(Map info, Map businessInfo) {
+
+        if (info.containsKey("community_id")) {
+            return;
+        }
+
+        if (!businessInfo.containsKey("communityId")) {
+            return;
+        }
+
+        info.put("community_id", businessInfo.get("communityId"));
+    }
+
+    /**
+     * 撤单
+     *
+     * @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> ownerAttrInfo = ownerAttrServiceDaoImpl.getOwnerAttrInfo(info);
+        if (ownerAttrInfo != null && ownerAttrInfo.size() > 0) {
+            reFreshShareColumn(paramIn, ownerAttrInfo.get(0));
+            ownerAttrServiceDaoImpl.updateOwnerAttrInfoInstance(paramIn);
+        }
+    }
+
+
+    /**
+     * 处理 businessOwnerAttr 节点
+     *
+     * @param business          总的数据节点
+     * @param businessOwnerAttr 业主属性节点
+     */
+    private void doBusinessOwnerAttr(Business business, JSONObject businessOwnerAttr) {
+
+        Assert.jsonObjectHaveKey(businessOwnerAttr, "attrId", "businessOwnerAttr 节点下没有包含 attrId 节点");
+
+        if (businessOwnerAttr.getString("attrId").startsWith("-")) {
+            //刷新缓存
+            //flushOwnerAttrId(business.getDatas());
+
+            businessOwnerAttr.put("attrId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_attrId));
+
+        }
+
+        businessOwnerAttr.put("bId", business.getbId());
+        businessOwnerAttr.put("operate", StatusConstant.OPERATE_ADD);
+        //保存业主属性信息
+        ownerAttrServiceDaoImpl.saveBusinessOwnerAttrInfo(businessOwnerAttr);
+
+    }
+
+    @Override
+    public IOwnerAttrServiceDao getOwnerAttrServiceDaoImpl() {
+        return ownerAttrServiceDaoImpl;
+    }
+
+    public void setOwnerAttrServiceDaoImpl(IOwnerAttrServiceDao ownerAttrServiceDaoImpl) {
+        this.ownerAttrServiceDaoImpl = ownerAttrServiceDaoImpl;
+    }
+}

+ 190 - 0
service-user/src/main/java/com/java110/user/listener/ownerAttr/UpdateOwnerAttrInfoListener.java

@@ -0,0 +1,190 @@
+package com.java110.user.listener.ownerAttr;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.entity.center.Business;
+import com.java110.po.owner.OwnerAttrPo;
+import com.java110.user.dao.IOwnerAttrServiceDao;
+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 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;
+
+/**
+ * 修改业主属性信息 侦听
+ * <p>
+ * 处理节点
+ * 1、businessOwnerAttr:{} 业主属性基本信息节点
+ * 2、businessOwnerAttrAttr:[{}] 业主属性属性信息节点
+ * 3、businessOwnerAttrPhoto:[{}] 业主属性照片信息节点
+ * 4、businessOwnerAttrCerdentials:[{}] 业主属性证件信息节点
+ * 协议地址 :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("updateOwnerAttrInfoListener")
+@Transactional
+public class UpdateOwnerAttrInfoListener extends AbstractOwnerAttrBusinessServiceDataFlowListener {
+
+    private static Logger logger = LoggerFactory.getLogger(UpdateOwnerAttrInfoListener.class);
+    @Autowired
+    private IOwnerAttrServiceDao ownerAttrServiceDaoImpl;
+
+    @Override
+    public int getOrder() {
+        return 2;
+    }
+
+    @Override
+    public String getBusinessTypeCd() {
+        return BusinessTypeConstant.BUSINESS_TYPE_UPDATE_OWNER_ATTR_INFO;
+    }
+
+    /**
+     * business过程
+     *
+     * @param dataFlowContext 上下文对象
+     * @param business        业务对象
+     */
+    @Override
+    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {
+
+        JSONObject data = business.getDatas();
+
+        Assert.notEmpty(data, "没有datas 节点,或没有子节点需要处理");
+
+
+        //处理 businessOwnerAttr 节点
+        if (data.containsKey(OwnerAttrPo.class.getSimpleName())) {
+            Object _obj = data.get(OwnerAttrPo.class.getSimpleName());
+            JSONArray businessOwnerAttrs = null;
+            if (_obj instanceof JSONObject) {
+                businessOwnerAttrs = new JSONArray();
+                businessOwnerAttrs.add(_obj);
+            } else {
+                businessOwnerAttrs = (JSONArray) _obj;
+            }
+            //JSONObject businessOwnerAttr = data.getJSONObject(OwnerAttrPo.class.getSimpleName());
+            for (int _ownerAttrIndex = 0; _ownerAttrIndex < businessOwnerAttrs.size(); _ownerAttrIndex++) {
+                JSONObject businessOwnerAttr = businessOwnerAttrs.getJSONObject(_ownerAttrIndex);
+                doBusinessOwnerAttr(business, businessOwnerAttr);
+                if (_obj instanceof JSONObject) {
+                    dataFlowContext.addParamOut("attrId", businessOwnerAttr.getString("attrId"));
+                }
+            }
+        }
+    }
+
+
+    /**
+     * 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> businessOwnerAttrInfos = ownerAttrServiceDaoImpl.getBusinessOwnerAttrInfo(info);
+        if (businessOwnerAttrInfos != null && businessOwnerAttrInfos.size() > 0) {
+            for (int _ownerAttrIndex = 0; _ownerAttrIndex < businessOwnerAttrInfos.size(); _ownerAttrIndex++) {
+                Map businessOwnerAttrInfo = businessOwnerAttrInfos.get(_ownerAttrIndex);
+                flushBusinessOwnerAttrInfo(businessOwnerAttrInfo, StatusConstant.STATUS_CD_VALID);
+                ownerAttrServiceDaoImpl.updateOwnerAttrInfoInstance(businessOwnerAttrInfo);
+                if (businessOwnerAttrInfo.size() == 1) {
+                    dataFlowContext.addParamOut("attrId", businessOwnerAttrInfo.get("attr_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> ownerAttrInfo = ownerAttrServiceDaoImpl.getOwnerAttrInfo(info);
+        if (ownerAttrInfo != null && ownerAttrInfo.size() > 0) {
+
+            //业主属性信息
+            List<Map> businessOwnerAttrInfos = ownerAttrServiceDaoImpl.getBusinessOwnerAttrInfo(delInfo);
+            //除非程序出错了,这里不会为空
+            if (businessOwnerAttrInfos == null || businessOwnerAttrInfos.size() == 0) {
+                throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_INNER_ERROR, "撤单失败(ownerAttr),程序内部异常,请检查! " + delInfo);
+            }
+            for (int _ownerAttrIndex = 0; _ownerAttrIndex < businessOwnerAttrInfos.size(); _ownerAttrIndex++) {
+                Map businessOwnerAttrInfo = businessOwnerAttrInfos.get(_ownerAttrIndex);
+                flushBusinessOwnerAttrInfo(businessOwnerAttrInfo, StatusConstant.STATUS_CD_VALID);
+                ownerAttrServiceDaoImpl.updateOwnerAttrInfoInstance(businessOwnerAttrInfo);
+            }
+        }
+
+    }
+
+
+    /**
+     * 处理 businessOwnerAttr 节点
+     *
+     * @param business          总的数据节点
+     * @param businessOwnerAttr 业主属性节点
+     */
+    private void doBusinessOwnerAttr(Business business, JSONObject businessOwnerAttr) {
+
+        Assert.jsonObjectHaveKey(businessOwnerAttr, "attrId", "businessOwnerAttr 节点下没有包含 attrId 节点");
+
+        if (businessOwnerAttr.getString("attrId").startsWith("-")) {
+            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR, "attrId 错误,不能自动生成(必须已经存在的attrId)" + businessOwnerAttr);
+        }
+        //自动保存DEL
+        autoSaveDelBusinessOwnerAttr(business, businessOwnerAttr);
+
+        businessOwnerAttr.put("bId", business.getbId());
+        businessOwnerAttr.put("operate", StatusConstant.OPERATE_ADD);
+        //保存业主属性信息
+        ownerAttrServiceDaoImpl.saveBusinessOwnerAttrInfo(businessOwnerAttr);
+
+    }
+
+
+    @Override
+    public IOwnerAttrServiceDao getOwnerAttrServiceDaoImpl() {
+        return ownerAttrServiceDaoImpl;
+    }
+
+    public void setOwnerAttrServiceDaoImpl(IOwnerAttrServiceDao ownerAttrServiceDaoImpl) {
+        this.ownerAttrServiceDaoImpl = ownerAttrServiceDaoImpl;
+    }
+
+
+}

+ 112 - 0
service-user/src/main/java/com/java110/user/smo/impl/OwnerAttrInnerServiceSMOImpl.java

@@ -0,0 +1,112 @@
+package com.java110.user.smo.impl;
+
+
+import com.java110.core.base.smo.BaseServiceSMO;
+import com.java110.core.smo.user.IOwnerAttrInnerServiceSMO;
+import com.java110.dto.PageDto;
+import com.java110.dto.owner.OwnerAttrDto;
+import com.java110.dto.user.UserDto;
+import com.java110.intf.user.IUserInnerServiceSMO;
+import com.java110.user.dao.IOwnerAttrServiceDao;
+import com.java110.utils.util.BeanConvertUtil;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.RequestBody;
+import org.springframework.web.bind.annotation.RestController;
+
+import java.util.ArrayList;
+import java.util.List;
+
+/**
+ * @ClassName FloorInnerServiceSMOImpl
+ * @Description 业主属性内部服务实现类
+ * @Author wuxw
+ * @Date 2019/4/24 9:20
+ * @Version 1.0
+ * add by wuxw 2019/4/24
+ **/
+@RestController
+public class OwnerAttrInnerServiceSMOImpl extends BaseServiceSMO implements IOwnerAttrInnerServiceSMO {
+
+    @Autowired
+    private IOwnerAttrServiceDao ownerAttrServiceDaoImpl;
+
+    @Autowired
+    private IUserInnerServiceSMO userInnerServiceSMOImpl;
+
+    @Override
+    public List<OwnerAttrDto> queryOwnerAttrs(@RequestBody OwnerAttrDto ownerAttrDto) {
+
+        //校验是否传了 分页信息
+
+        int page = ownerAttrDto.getPage();
+
+        if (page != PageDto.DEFAULT_PAGE) {
+            ownerAttrDto.setPage((page - 1) * ownerAttrDto.getRow());
+        }
+
+        List<OwnerAttrDto> ownerAttrs = BeanConvertUtil.covertBeanList(ownerAttrServiceDaoImpl.getOwnerAttrInfo(BeanConvertUtil.beanCovertMap(ownerAttrDto)), OwnerAttrDto.class);
+
+        if (ownerAttrs == null || ownerAttrs.size() == 0) {
+            return ownerAttrs;
+        }
+
+        String[] userIds = getUserIds(ownerAttrs);
+        //根据 userId 查询用户信息
+        List<UserDto> users = userInnerServiceSMOImpl.getUserInfo(userIds);
+
+        for (OwnerAttrDto ownerAttr : ownerAttrs) {
+            refreshOwnerAttr(ownerAttr, users);
+        }
+        return ownerAttrs;
+    }
+
+    /**
+     * 从用户列表中查询用户,将用户中的信息 刷新到 floor对象中
+     *
+     * @param ownerAttr 小区业主属性信息
+     * @param users     用户列表
+     */
+    private void refreshOwnerAttr(OwnerAttrDto ownerAttr, List<UserDto> users) {
+        for (UserDto user : users) {
+            if (ownerAttr.getAttrId().equals(user.getUserId())) {
+                BeanConvertUtil.covertBean(user, ownerAttr);
+            }
+        }
+    }
+
+    /**
+     * 获取批量userId
+     *
+     * @param ownerAttrs 小区楼信息
+     * @return 批量userIds 信息
+     */
+    private String[] getUserIds(List<OwnerAttrDto> ownerAttrs) {
+        List<String> userIds = new ArrayList<String>();
+        for (OwnerAttrDto ownerAttr : ownerAttrs) {
+            userIds.add(ownerAttr.getAttrId());
+        }
+
+        return userIds.toArray(new String[userIds.size()]);
+    }
+
+    @Override
+    public int queryOwnerAttrsCount(@RequestBody OwnerAttrDto ownerAttrDto) {
+        return ownerAttrServiceDaoImpl.queryOwnerAttrsCount(BeanConvertUtil.beanCovertMap(ownerAttrDto));
+    }
+
+    public IOwnerAttrServiceDao getOwnerAttrServiceDaoImpl() {
+        return ownerAttrServiceDaoImpl;
+    }
+
+    public void setOwnerAttrServiceDaoImpl(IOwnerAttrServiceDao ownerAttrServiceDaoImpl) {
+        this.ownerAttrServiceDaoImpl = ownerAttrServiceDaoImpl;
+    }
+
+    public IUserInnerServiceSMO getUserInnerServiceSMOImpl() {
+        return userInnerServiceSMOImpl;
+    }
+
+    public void setUserInnerServiceSMOImpl(IUserInnerServiceSMO userInnerServiceSMOImpl) {
+        this.userInnerServiceSMOImpl = userInnerServiceSMOImpl;
+    }
+}