shiyj лет назад: 6
Родитель
Сommit
e641c55e94
27 измененных файлов с 2451 добавлено и 0 удалено
  1. 87 0
      Api/src/main/java/com/java110/api/listener/demo/QueryDemoConfigListener.java
  2. 81 0
      StoreService/src/main/java/com/java110/store/dao/IDemoServiceDao.java
  3. 130 0
      StoreService/src/main/java/com/java110/store/dao/impl/demo/DemoServiceDaoImpl.java
  4. 85 0
      StoreService/src/main/java/com/java110/store/listener/demo/AbstractDemoBusinessServiceDataFlowListener.java
  5. 177 0
      StoreService/src/main/java/com/java110/store/listener/demo/DeleteDemoInfoListener.java
  6. 175 0
      StoreService/src/main/java/com/java110/store/listener/demo/SaveDemoInfoListener.java
  7. 190 0
      StoreService/src/main/java/com/java110/store/listener/demo/UpdateDemoInfoListener.java
  8. 112 0
      StoreService/src/main/java/com/java110/store/smo/impl/demo/DemoInnerServiceSMOImpl.java
  9. 26 0
      WebService/src/main/java/com/java110/web/components/demo/ListDemoComponent.java
  10. 43 0
      WebService/src/main/java/com/java110/web/smo/IDemoServiceSMO.java
  11. 273 0
      WebService/src/main/java/com/java110/web/smo/impl/DemoServiceSMOImpl.java
  12. 31 0
      WebService/src/main/resources/components/add-demo/addDemo.html
  13. 103 0
      WebService/src/main/resources/components/add-demo/addDemo.js
  14. 75 0
      WebService/src/main/resources/components/list-demo/listDemo.html
  15. 64 0
      WebService/src/main/resources/components/list-demo/listDemo.js
  16. 33 0
      WebService/src/main/resources/views/demoFlow.html
  17. 114 0
      docs/services/demo/DeleteDemoInfo.md
  18. 122 0
      docs/services/demo/SaveDemoInfo.md
  19. 122 0
      docs/services/demo/UpdateDemoInfo.md
  20. 77 0
      java110-bean/src/main/java/com/java110/dto/demo/DemoDto.java
  21. 81 0
      java110-code-generator/src/main/java/com/java110/DemoGeneratorApplication.java
  22. 13 0
      java110-common/src/main/java/com/java110/common/constant/BusinessTypeConstant.java
  23. 3 0
      java110-common/src/main/java/com/java110/common/constant/ServiceCodeConstant.java
  24. 2 0
      java110-core/src/main/java/com/java110/core/factory/GenerateCodeFactory.java
  25. 42 0
      java110-core/src/main/java/com/java110/core/smo/demo/IDemoInnerServiceSMO.java
  26. 25 0
      java110-db/db/DemoService/create.sql
  27. 165 0
      java110-db/src/main/resources/mapper/demo/DemoServiceDaoImplMapper.xml

+ 87 - 0
Api/src/main/java/com/java110/api/listener/demo/QueryDemoConfigListener.java

@@ -0,0 +1,87 @@
+package com.java110.api.listener.demo;
+
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.api.listener.AbstractServiceApiDataFlowListener;
+import com.java110.common.constant.ServiceCodeConstant;
+import com.java110.common.util.Assert;
+import com.java110.common.util.BeanConvertUtil;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.core.smo.demo.IDemoInnerServiceSMO;
+import com.java110.dto.demo.DemoDto;
+import com.java110.event.service.api.ServiceDataFlowEvent;
+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.List;
+
+/**
+ * @ClassName FloorDto
+ * @Description 用例数据层侦听类
+ * @Author wuxw
+ * @Date 2019/4/24 8:52
+ * @Version 1.0
+ * add by wuxw 2019/4/24
+ **/
+@Java110Listener("queryDemoConfig")
+public class QueryDemoConfigListener extends AbstractServiceApiDataFlowListener {
+
+    @Autowired
+    private IDemoInnerServiceSMO demoInnerServiceSMOImpl;
+
+    @Override
+    public String getServiceCode() {
+        return ServiceCodeConstant.SERVICE_CODE_QUERY_DEMO_CONFIG;
+    }
+
+    @Override
+    public HttpMethod getHttpMethod() {
+        return HttpMethod.GET;
+    }
+
+    /**
+     * 业务层数据处理
+     *
+     * @param event 时间对象
+     */
+    @Override
+    public void soService(ServiceDataFlowEvent event) {
+        DataFlowContext dataFlowContext = event.getDataFlowContext();
+        //获取请求数据
+        JSONObject reqJson = dataFlowContext.getReqJson();
+        validateDemoConfigData(reqJson);
+
+        List<DemoDto> DemoDtos = demoInnerServiceSMOImpl.queryDemos(BeanConvertUtil.covertBean(reqJson, DemoDto.class));
+        ResponseEntity<String> responseEntity = new ResponseEntity<String>(JSONObject.toJSONString(DemoDtos), HttpStatus.OK);
+
+        dataFlowContext.setResponseEntity(responseEntity);
+    }
+
+    /**
+     * 校验查询条件是否满足条件
+     *
+     * @param reqJson 包含查询条件
+     */
+    private void validateDemoConfigData(JSONObject reqJson) {
+        Assert.jsonObjectHaveKey(reqJson, "demoName", "请求中未包含demoName信息");
+        Assert.jsonObjectHaveKey(reqJson, "demoValue", "请求中未包含demoValue信息");
+
+
+    }
+
+    @Override
+    public int getOrder() {
+        return super.DEFAULT_ORDER;
+    }
+
+    public IDemoInnerServiceSMO getDemoInnerServiceSMOImpl() {
+        return demoInnerServiceSMOImpl;
+    }
+
+    public void setDemoInnerServiceSMOImpl(IDemoInnerServiceSMO demoInnerServiceSMOImpl) {
+        this.demoInnerServiceSMOImpl = demoInnerServiceSMOImpl;
+    }
+}

+ 81 - 0
StoreService/src/main/java/com/java110/store/dao/IDemoServiceDao.java

@@ -0,0 +1,81 @@
+package com.java110.store.dao;
+
+
+import com.java110.common.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;
+
+/**
+ * demo组件内部之间使用,没有给外围系统提供服务能力
+ * demo服务接口类,要求全部以字符串传输,方便微服务化
+ * 新建客户,修改客户,删除客户,查询客户等功能
+ *
+ * Created by wuxw on 2016/12/27.
+ */
+public interface IDemoServiceDao {
+
+    /**
+     * 保存 demo信息
+     * @param businessDemoInfo demo信息 封装
+     * @throws DAOException 操作数据库异常
+     */
+    void saveBusinessDemoInfo(Map businessDemoInfo) throws DAOException;
+
+
+
+    /**
+     * 查询demo信息(business过程)
+     * 根据bId 查询demo信息
+     * @param info bId 信息
+     * @return demo信息
+     * @throws DAOException DAO异常
+     */
+    List<Map> getBusinessDemoInfo(Map info) throws DAOException;
+
+
+
+
+    /**
+     * 保存 demo信息 Business数据到 Instance中
+     * @param info
+     * @throws DAOException DAO异常
+     */
+    void saveDemoInfoInstance(Map info) throws DAOException;
+
+
+
+
+    /**
+     * 查询demo信息(instance过程)
+     * 根据bId 查询demo信息
+     * @param info bId 信息
+     * @return demo信息
+     * @throws DAOException DAO异常
+     */
+    List<Map> getDemoInfo(Map info) throws DAOException;
+
+
+
+    /**
+     * 修改demo信息
+     * @param info 修改信息
+     * @throws DAOException DAO异常
+     */
+    void updateDemoInfoInstance(Map info) throws DAOException;
+
+
+    /**
+     * 查询demo总数
+     *
+     * @param info demo信息
+     * @return demo数量
+     */
+    int queryDemosCount(Map info);
+
+}

+ 130 - 0
StoreService/src/main/java/com/java110/store/dao/impl/demo/DemoServiceDaoImpl.java

@@ -0,0 +1,130 @@
+package com.java110.store.dao.impl.demo;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.common.constant.ResponseConstant;
+import com.java110.common.exception.DAOException;
+import com.java110.common.util.DateUtil;
+import com.java110.core.base.dao.BaseServiceDao;
+import com.java110.store.dao.IDemoServiceDao;
+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;
+
+/**
+ * demo服务 与数据库交互
+ * Created by wuxw on 2017/4/5.
+ */
+@Service("demoServiceDaoImpl")
+//@Transactional
+public class DemoServiceDaoImpl extends BaseServiceDao implements IDemoServiceDao {
+
+    private static Logger logger = LoggerFactory.getLogger(DemoServiceDaoImpl.class);
+
+    /**
+     * demo信息封装
+     * @param businessDemoInfo demo信息 封装
+     * @throws DAOException DAO异常
+     */
+    @Override
+    public void saveBusinessDemoInfo(Map businessDemoInfo) throws DAOException {
+        businessDemoInfo.put("month", DateUtil.getCurrentMonth());
+        // 查询business_user 数据是否已经存在
+        logger.debug("保存demo信息 入参 businessDemoInfo : {}",businessDemoInfo);
+        int saveFlag = sqlSessionTemplate.insert("demoServiceDaoImpl.saveBusinessDemoInfo",businessDemoInfo);
+
+        if(saveFlag < 1){
+            throw new DAOException(ResponseConstant.RESULT_PARAM_ERROR,"保存demo数据失败:"+ JSONObject.toJSONString(businessDemoInfo));
+        }
+    }
+
+
+    /**
+     * 查询demo信息
+     * @param info bId 信息
+     * @return demo信息
+     * @throws DAOException DAO异常
+     */
+    @Override
+    public List<Map> getBusinessDemoInfo(Map info) throws DAOException {
+
+        logger.debug("查询demo信息 入参 info : {}",info);
+
+        List<Map> businessDemoInfos = sqlSessionTemplate.selectList("demoServiceDaoImpl.getBusinessDemoInfo",info);
+
+        return businessDemoInfos;
+    }
+
+
+
+    /**
+     * 保存demo信息 到 instance
+     * @param info   bId 信息
+     * @throws DAOException DAO异常
+     */
+    @Override
+    public void saveDemoInfoInstance(Map info) throws DAOException {
+        logger.debug("保存demo信息Instance 入参 info : {}",info);
+
+        int saveFlag = sqlSessionTemplate.insert("demoServiceDaoImpl.saveDemoInfoInstance",info);
+
+        if(saveFlag < 1){
+            throw new DAOException(ResponseConstant.RESULT_PARAM_ERROR,"保存demo信息Instance数据失败:"+ JSONObject.toJSONString(info));
+        }
+    }
+
+
+    /**
+     * 查询demo信息(instance)
+     * @param info bId 信息
+     * @return List<Map>
+     * @throws DAOException DAO异常
+     */
+    @Override
+    public List<Map> getDemoInfo(Map info) throws DAOException {
+        logger.debug("查询demo信息 入参 info : {}",info);
+
+        List<Map> businessDemoInfos = sqlSessionTemplate.selectList("demoServiceDaoImpl.getDemoInfo",info);
+
+        return businessDemoInfos;
+    }
+
+
+    /**
+     * 修改demo信息
+     * @param info 修改信息
+     * @throws DAOException DAO异常
+     */
+    @Override
+    public void updateDemoInfoInstance(Map info) throws DAOException {
+        logger.debug("修改demo信息Instance 入参 info : {}",info);
+
+        int saveFlag = sqlSessionTemplate.update("demoServiceDaoImpl.updateDemoInfoInstance",info);
+
+        if(saveFlag < 1){
+            throw new DAOException(ResponseConstant.RESULT_PARAM_ERROR,"修改demo信息Instance数据失败:"+ JSONObject.toJSONString(info));
+        }
+    }
+
+     /**
+     * 查询demo数量
+     * @param info demo信息
+     * @return demo数量
+     */
+    @Override
+    public int queryDemosCount(Map info) {
+        logger.debug("查询demo数据 入参 info : {}",info);
+
+        List<Map> businessDemoInfos = sqlSessionTemplate.selectList("demoServiceDaoImpl.queryDemosCount", info);
+        if (businessDemoInfos.size() < 1) {
+            return 0;
+        }
+
+        return Integer.parseInt(businessDemoInfos.get(0).get("count").toString());
+    }
+
+
+}

+ 85 - 0
StoreService/src/main/java/com/java110/store/listener/demo/AbstractDemoBusinessServiceDataFlowListener.java

@@ -0,0 +1,85 @@
+package com.java110.store.listener.demo;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.common.constant.ResponseConstant;
+import com.java110.common.constant.StatusConstant;
+import com.java110.common.exception.ListenerExecuteException;
+import com.java110.core.factory.GenerateCodeFactory;
+import com.java110.entity.center.Business;
+import com.java110.event.service.AbstractBusinessServiceDataFlowListener;
+import com.java110.store.dao.IDemoServiceDao;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+/**
+ *
+ * demo 服务侦听 父类
+ * Created by wuxw on 2018/7/4.
+ */
+public abstract class AbstractDemoBusinessServiceDataFlowListener extends AbstractBusinessServiceDataFlowListener{
+    private static Logger logger = LoggerFactory.getLogger(AbstractDemoBusinessServiceDataFlowListener.class);
+
+
+    /**
+     * 获取 DAO工具类
+     * @return
+     */
+    public abstract IDemoServiceDao getDemoServiceDaoImpl();
+
+    /**
+     * 刷新 businessDemoInfo 数据
+     * 主要将 数据库 中字段和 接口传递字段建立关系
+     * @param businessDemoInfo
+     */
+    protected void flushBusinessDemoInfo(Map businessDemoInfo,String statusCd){
+        businessDemoInfo.put("newBId", businessDemoInfo.get("b_id"));
+        businessDemoInfo.put("demoRemark",businessDemoInfo.get("demo_remark"));
+businessDemoInfo.put("demoName",businessDemoInfo.get("demo_name"));
+businessDemoInfo.put("demoValue",businessDemoInfo.get("demo_value"));
+businessDemoInfo.put("operate",businessDemoInfo.get("operate"));
+businessDemoInfo.put("demoId",businessDemoInfo.get("demo_id"));
+businessDemoInfo.put("userId",businessDemoInfo.get("user_id"));
+businessDemoInfo.remove("bId");
+        businessDemoInfo.put("statusCd", statusCd);
+    }
+
+
+    /**
+     * 当修改数据时,查询instance表中的数据 自动保存删除数据到business中
+     * @param businessDemo demo信息
+     */
+    protected void autoSaveDelBusinessDemo(Business business, JSONObject businessDemo){
+//自动插入DEL
+        Map info = new HashMap();
+        info.put("demoId",businessDemo.getString("demoId"));
+        info.put("statusCd",StatusConstant.STATUS_CD_VALID);
+        List<Map> currentDemoInfos = getDemoServiceDaoImpl().getDemoInfo(info);
+        if(currentDemoInfos == null || currentDemoInfos.size() != 1){
+            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR,"未找到需要修改数据信息,入参错误或数据有问题,请检查"+info);
+        }
+
+        Map currentDemoInfo = currentDemoInfos.get(0);
+
+        currentDemoInfo.put("bId",business.getbId());
+
+        currentDemoInfo.put("demoRemark",currentDemoInfo.get("demo_remark"));
+currentDemoInfo.put("demoName",currentDemoInfo.get("demo_name"));
+currentDemoInfo.put("demoValue",currentDemoInfo.get("demo_value"));
+currentDemoInfo.put("operate",currentDemoInfo.get("operate"));
+currentDemoInfo.put("demoId",currentDemoInfo.get("demo_id"));
+currentDemoInfo.put("userId",currentDemoInfo.get("user_id"));
+
+
+        currentDemoInfo.put("operate",StatusConstant.OPERATE_DEL);
+        getDemoServiceDaoImpl().saveBusinessDemoInfo(currentDemoInfo);
+    }
+
+
+
+
+
+}

+ 177 - 0
StoreService/src/main/java/com/java110/store/listener/demo/DeleteDemoInfoListener.java

@@ -0,0 +1,177 @@
+package com.java110.store.listener.demo;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.common.constant.BusinessTypeConstant;
+import com.java110.common.constant.ResponseConstant;
+import com.java110.common.constant.StatusConstant;
+import com.java110.common.exception.ListenerExecuteException;
+import com.java110.common.util.Assert;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.entity.center.Business;
+import com.java110.store.dao.IDemoServiceDao;
+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;
+
+/**
+ * 删除demo信息 侦听
+ *
+ * 处理节点
+ * 1、businessDemo:{} demo基本信息节点
+ * 2、businessDemoAttr:[{}] demo属性信息节点
+ * 3、businessDemoPhoto:[{}] demo照片信息节点
+ * 4、businessDemoCerdentials:[{}] demo证件信息节点
+ * 协议地址 :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("deleteDemoInfoListener")
+@Transactional
+public class DeleteDemoInfoListener extends AbstractDemoBusinessServiceDataFlowListener {
+
+    private final static Logger logger = LoggerFactory.getLogger(DeleteDemoInfoListener.class);
+    @Autowired
+    IDemoServiceDao demoServiceDaoImpl;
+
+    @Override
+    public int getOrder() {
+        return 3;
+    }
+
+    @Override
+    public String getBusinessTypeCd() {
+        return BusinessTypeConstant.BUSINESS_TYPE_DELETE_DEMO_INFO;
+    }
+
+    /**
+     * 根据删除信息 查出Instance表中数据 保存至business表 (状态写DEL) 方便撤单时直接更新回去
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {
+        JSONObject data = business.getDatas();
+
+        Assert.notEmpty(data,"没有datas 节点,或没有子节点需要处理");
+
+        //处理 businessDemo 节点
+        if(data.containsKey("businessDemo")){
+            //处理 businessDemo 节点
+            if(data.containsKey("businessDemo")){
+                Object _obj = data.get("businessDemo");
+                JSONArray businessDemos = null;
+                if(_obj instanceof JSONObject){
+                    businessDemos = new JSONArray();
+                    businessDemos.add(_obj);
+                }else {
+                    businessDemos = (JSONArray)_obj;
+                }
+                //JSONObject businessDemo = data.getJSONObject("businessDemo");
+                for (int _demoIndex = 0; _demoIndex < businessDemos.size();_demoIndex++) {
+                    JSONObject businessDemo = businessDemos.getJSONObject(_demoIndex);
+                    doBusinessDemo(business, businessDemo);
+                    if(_obj instanceof JSONObject) {
+                        dataFlowContext.addParamOut("demoId", businessDemo.getString("demoId"));
+                    }
+                }
+            }
+        }
+
+
+    }
+
+    /**
+     * 删除 instance数据
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doBusinessToInstance(DataFlowContext dataFlowContext, Business business) {
+        String bId = business.getbId();
+        //Assert.hasLength(bId,"请求报文中没有包含 bId");
+
+        //demo信息
+        Map info = new HashMap();
+        info.put("bId",business.getbId());
+        info.put("operate",StatusConstant.OPERATE_DEL);
+
+        //demo信息
+        List<Map> businessDemoInfos = demoServiceDaoImpl.getBusinessDemoInfo(info);
+        if( businessDemoInfos != null && businessDemoInfos.size() >0) {
+            for (int _demoIndex = 0; _demoIndex < businessDemoInfos.size();_demoIndex++) {
+                Map businessDemoInfo = businessDemoInfos.get(_demoIndex);
+                flushBusinessDemoInfo(businessDemoInfo,StatusConstant.STATUS_CD_INVALID);
+                demoServiceDaoImpl.updateDemoInfoInstance(businessDemoInfo);
+                dataFlowContext.addParamOut("demoId",businessDemoInfo.get("demo_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);
+        //demo信息
+        List<Map> demoInfo = demoServiceDaoImpl.getDemoInfo(info);
+        if(demoInfo != null && demoInfo.size() > 0){
+
+            //demo信息
+            List<Map> businessDemoInfos = demoServiceDaoImpl.getBusinessDemoInfo(delInfo);
+            //除非程序出错了,这里不会为空
+            if(businessDemoInfos == null ||  businessDemoInfos.size() == 0){
+                throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_INNER_ERROR,"撤单失败(demo),程序内部异常,请检查! "+delInfo);
+            }
+            for (int _demoIndex = 0; _demoIndex < businessDemoInfos.size();_demoIndex++) {
+                Map businessDemoInfo = businessDemoInfos.get(_demoIndex);
+                flushBusinessDemoInfo(businessDemoInfo,StatusConstant.STATUS_CD_VALID);
+                demoServiceDaoImpl.updateDemoInfoInstance(businessDemoInfo);
+            }
+        }
+    }
+
+
+
+    /**
+     * 处理 businessDemo 节点
+     * @param business 总的数据节点
+     * @param businessDemo demo节点
+     */
+    private void doBusinessDemo(Business business,JSONObject businessDemo){
+
+        Assert.jsonObjectHaveKey(businessDemo,"demoId","businessDemo 节点下没有包含 demoId 节点");
+
+        if(businessDemo.getString("demoId").startsWith("-")){
+            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR,"demoId 错误,不能自动生成(必须已经存在的demoId)"+businessDemo);
+        }
+        //自动插入DEL
+        autoSaveDelBusinessDemo(business,businessDemo);
+    }
+
+    public IDemoServiceDao getDemoServiceDaoImpl() {
+        return demoServiceDaoImpl;
+    }
+
+    public void setDemoServiceDaoImpl(IDemoServiceDao demoServiceDaoImpl) {
+        this.demoServiceDaoImpl = demoServiceDaoImpl;
+    }
+}

+ 175 - 0
StoreService/src/main/java/com/java110/store/listener/demo/SaveDemoInfoListener.java

@@ -0,0 +1,175 @@
+package com.java110.store.listener.demo;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.common.constant.BusinessTypeConstant;
+import com.java110.common.constant.StatusConstant;
+import com.java110.common.util.Assert;
+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.store.dao.IDemoServiceDao;
+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;
+
+/**
+ * 保存 demo信息 侦听
+ * Created by wuxw on 2018/5/18.
+ */
+@Java110Listener("saveDemoInfoListener")
+@Transactional
+public class SaveDemoInfoListener extends AbstractDemoBusinessServiceDataFlowListener{
+
+    private static Logger logger = LoggerFactory.getLogger(SaveDemoInfoListener.class);
+
+    @Autowired
+    private IDemoServiceDao demoServiceDaoImpl;
+
+    @Override
+    public int getOrder() {
+        return 0;
+    }
+
+    @Override
+    public String getBusinessTypeCd() {
+        return BusinessTypeConstant.BUSINESS_TYPE_SAVE_DEMO_INFO;
+    }
+
+    /**
+     * 保存demo信息 business 表中
+     * @param dataFlowContext 数据对象
+     * @param business 当前业务对象
+     */
+    @Override
+    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {
+        JSONObject data = business.getDatas();
+        Assert.notEmpty(data,"没有datas 节点,或没有子节点需要处理");
+
+        //处理 businessDemo 节点
+        if(data.containsKey("businessDemo")){
+            Object bObj = data.get("businessDemo");
+            JSONArray businessDemos = null;
+            if(bObj instanceof JSONObject){
+                businessDemos = new JSONArray();
+                businessDemos.add(bObj);
+            }else {
+                businessDemos = (JSONArray)bObj;
+            }
+            //JSONObject businessDemo = data.getJSONObject("businessDemo");
+            for (int bDemoIndex = 0; bDemoIndex < businessDemos.size();bDemoIndex++) {
+                JSONObject businessDemo = businessDemos.getJSONObject(bDemoIndex);
+                doBusinessDemo(business, businessDemo);
+                if(bObj instanceof JSONObject) {
+                    dataFlowContext.addParamOut("demoId", businessDemo.getString("demoId"));
+                }
+            }
+        }
+    }
+
+    /**
+     * 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);
+
+        //demo信息
+        List<Map> businessDemoInfo = demoServiceDaoImpl.getBusinessDemoInfo(info);
+        if( businessDemoInfo != null && businessDemoInfo.size() >0) {
+            reFreshShareColumn(info, businessDemoInfo.get(0));
+            demoServiceDaoImpl.saveDemoInfoInstance(info);
+            if(businessDemoInfo.size() == 1) {
+                dataFlowContext.addParamOut("demoId", businessDemoInfo.get(0).get("demo_id"));
+            }
+        }
+    }
+
+
+    /**
+     * 刷 分片字段
+     *
+     * @param info         查询对象
+     * @param businessInfo 小区ID
+     */
+    private void reFreshShareColumn(Map info, Map businessInfo) {
+
+        if (info.containsKey("demoId")) {
+            return;
+        }
+
+        if (!businessInfo.containsKey("demo_id")) {
+            return;
+        }
+
+        info.put("demoId", businessInfo.get("demo_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);
+        //demo信息
+        List<Map> demoInfo = demoServiceDaoImpl.getDemoInfo(info);
+        if(demoInfo != null && demoInfo.size() > 0){
+            reFreshShareColumn(paramIn, demoInfo.get(0));
+            demoServiceDaoImpl.updateDemoInfoInstance(paramIn);
+        }
+    }
+
+
+
+    /**
+     * 处理 businessDemo 节点
+     * @param business 总的数据节点
+     * @param businessDemo demo节点
+     */
+    private void doBusinessDemo(Business business,JSONObject businessDemo){
+
+        Assert.jsonObjectHaveKey(businessDemo,"demoId","businessDemo 节点下没有包含 demoId 节点");
+
+        if(businessDemo.getString("demoId").startsWith("-")){
+            //刷新缓存
+            //flushDemoId(business.getDatas());
+
+            businessDemo.put("demoId",GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_demoId));
+
+        }
+
+        businessDemo.put("bId",business.getbId());
+        businessDemo.put("operate", StatusConstant.OPERATE_ADD);
+        //保存demo信息
+        demoServiceDaoImpl.saveBusinessDemoInfo(businessDemo);
+
+    }
+
+    public IDemoServiceDao getDemoServiceDaoImpl() {
+        return demoServiceDaoImpl;
+    }
+
+    public void setDemoServiceDaoImpl(IDemoServiceDao demoServiceDaoImpl) {
+        this.demoServiceDaoImpl = demoServiceDaoImpl;
+    }
+}

+ 190 - 0
StoreService/src/main/java/com/java110/store/listener/demo/UpdateDemoInfoListener.java

@@ -0,0 +1,190 @@
+package com.java110.store.listener.demo;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.common.constant.BusinessTypeConstant;
+import com.java110.common.constant.ResponseConstant;
+import com.java110.common.constant.StatusConstant;
+import com.java110.common.exception.ListenerExecuteException;
+import com.java110.common.util.Assert;
+import com.java110.core.annotation.Java110Listener;
+import com.java110.core.context.DataFlowContext;
+import com.java110.entity.center.Business;
+import com.java110.store.dao.IDemoServiceDao;
+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;
+
+/**
+ * 修改demo信息 侦听
+ *
+ * 处理节点
+ * 1、businessDemo:{} demo基本信息节点
+ * 2、businessDemoAttr:[{}] demo属性信息节点
+ * 3、businessDemoPhoto:[{}] demo照片信息节点
+ * 4、businessDemoCerdentials:[{}] demo证件信息节点
+ * 协议地址 :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("updateDemoInfoListener")
+@Transactional
+public class UpdateDemoInfoListener extends AbstractDemoBusinessServiceDataFlowListener {
+
+    private static Logger logger = LoggerFactory.getLogger(UpdateDemoInfoListener.class);
+    @Autowired
+    private IDemoServiceDao demoServiceDaoImpl;
+
+    @Override
+    public int getOrder() {
+        return 2;
+    }
+
+    @Override
+    public String getBusinessTypeCd() {
+        return BusinessTypeConstant.BUSINESS_TYPE_UPDATE_DEMO_INFO;
+    }
+
+    /**
+     * business过程
+     * @param dataFlowContext 上下文对象
+     * @param business 业务对象
+     */
+    @Override
+    protected void doSaveBusiness(DataFlowContext dataFlowContext, Business business) {
+
+        JSONObject data = business.getDatas();
+
+        Assert.notEmpty(data,"没有datas 节点,或没有子节点需要处理");
+
+        //处理 businessDemo 节点
+        if(data.containsKey("businessDemo")){
+            //处理 businessDemo 节点
+            if(data.containsKey("businessDemo")){
+                Object _obj = data.get("businessDemo");
+                JSONArray businessDemos = null;
+                if(_obj instanceof JSONObject){
+                    businessDemos = new JSONArray();
+                    businessDemos.add(_obj);
+                }else {
+                    businessDemos = (JSONArray)_obj;
+                }
+                //JSONObject businessDemo = data.getJSONObject("businessDemo");
+                for (int _demoIndex = 0; _demoIndex < businessDemos.size();_demoIndex++) {
+                    JSONObject businessDemo = businessDemos.getJSONObject(_demoIndex);
+                    doBusinessDemo(business, businessDemo);
+                    if(_obj instanceof JSONObject) {
+                        dataFlowContext.addParamOut("demoId", businessDemo.getString("demoId"));
+                    }
+                }
+            }
+        }
+    }
+
+
+    /**
+     * 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);
+
+        //demo信息
+        List<Map> businessDemoInfos = demoServiceDaoImpl.getBusinessDemoInfo(info);
+        if( businessDemoInfos != null && businessDemoInfos.size() >0) {
+            for (int _demoIndex = 0; _demoIndex < businessDemoInfos.size();_demoIndex++) {
+                Map businessDemoInfo = businessDemoInfos.get(_demoIndex);
+                flushBusinessDemoInfo(businessDemoInfo,StatusConstant.STATUS_CD_VALID);
+                demoServiceDaoImpl.updateDemoInfoInstance(businessDemoInfo);
+                if(businessDemoInfo.size() == 1) {
+                    dataFlowContext.addParamOut("demoId", businessDemoInfo.get("demo_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);
+        //demo信息
+        List<Map> demoInfo = demoServiceDaoImpl.getDemoInfo(info);
+        if(demoInfo != null && demoInfo.size() > 0){
+
+            //demo信息
+            List<Map> businessDemoInfos = demoServiceDaoImpl.getBusinessDemoInfo(delInfo);
+            //除非程序出错了,这里不会为空
+            if(businessDemoInfos == null || businessDemoInfos.size() == 0){
+                throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_INNER_ERROR,"撤单失败(demo),程序内部异常,请检查! "+delInfo);
+            }
+            for (int _demoIndex = 0; _demoIndex < businessDemoInfos.size();_demoIndex++) {
+                Map businessDemoInfo = businessDemoInfos.get(_demoIndex);
+                flushBusinessDemoInfo(businessDemoInfo,StatusConstant.STATUS_CD_VALID);
+                demoServiceDaoImpl.updateDemoInfoInstance(businessDemoInfo);
+            }
+        }
+
+    }
+
+
+
+    /**
+     * 处理 businessDemo 节点
+     * @param business 总的数据节点
+     * @param businessDemo demo节点
+     */
+    private void doBusinessDemo(Business business,JSONObject businessDemo){
+
+        Assert.jsonObjectHaveKey(businessDemo,"demoId","businessDemo 节点下没有包含 demoId 节点");
+
+        if(businessDemo.getString("demoId").startsWith("-")){
+            throw new ListenerExecuteException(ResponseConstant.RESULT_PARAM_ERROR,"demoId 错误,不能自动生成(必须已经存在的demoId)"+businessDemo);
+        }
+        //自动保存DEL
+        autoSaveDelBusinessDemo(business,businessDemo);
+
+        businessDemo.put("bId",business.getbId());
+        businessDemo.put("operate", StatusConstant.OPERATE_ADD);
+        //保存demo信息
+        demoServiceDaoImpl.saveBusinessDemoInfo(businessDemo);
+
+    }
+
+
+
+
+    public IDemoServiceDao getDemoServiceDaoImpl() {
+        return demoServiceDaoImpl;
+    }
+
+    public void setDemoServiceDaoImpl(IDemoServiceDao demoServiceDaoImpl) {
+        this.demoServiceDaoImpl = demoServiceDaoImpl;
+    }
+
+
+
+}

+ 112 - 0
StoreService/src/main/java/com/java110/store/smo/impl/demo/DemoInnerServiceSMOImpl.java

@@ -0,0 +1,112 @@
+package com.java110.store.smo.impl.demo;
+
+
+import com.java110.common.util.BeanConvertUtil;
+import com.java110.core.base.smo.BaseServiceSMO;
+import com.java110.core.smo.demo.IDemoInnerServiceSMO;
+import com.java110.core.smo.user.IUserInnerServiceSMO;
+import com.java110.dto.PageDto;
+import com.java110.dto.UserDto;
+import com.java110.dto.demo.DemoDto;
+import com.java110.store.dao.IDemoServiceDao;
+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 demo内部服务实现类
+ * @Author wuxw
+ * @Date 2019/4/24 9:20
+ * @Version 1.0
+ * add by wuxw 2019/4/24
+ **/
+@RestController
+public class DemoInnerServiceSMOImpl extends BaseServiceSMO implements IDemoInnerServiceSMO {
+
+    @Autowired
+    private IDemoServiceDao demoServiceDaoImpl;
+
+    @Autowired
+    private IUserInnerServiceSMO userInnerServiceSMOImpl;
+
+    @Override
+    public List<DemoDto> queryDemos(@RequestBody  DemoDto demoDto) {
+
+        //校验是否传了 分页信息
+
+        int page = demoDto.getPage();
+
+        if (page != PageDto.DEFAULT_PAGE) {
+            demoDto.setPage((page - 1) * demoDto.getRow());
+            demoDto.setRow(page * demoDto.getRow());
+        }
+
+        List<DemoDto> demos = BeanConvertUtil.covertBeanList(demoServiceDaoImpl.getDemoInfo(BeanConvertUtil.beanCovertMap(demoDto)), DemoDto.class);
+
+        if (demos == null || demos.size() == 0) {
+            return demos;
+        }
+
+        String[] userIds = getUserIds(demos);
+        //根据 userId 查询用户信息
+        List<UserDto> users = userInnerServiceSMOImpl.getUserInfo(userIds);
+
+        for (DemoDto demo : demos) {
+            refreshDemo(demo, users);
+        }
+        return demos;
+    }
+
+    /**
+     * 从用户列表中查询用户,将用户中的信息 刷新到 floor对象中
+     *
+     * @param demo 小区demo信息
+     * @param users 用户列表
+     */
+    private void refreshDemo(DemoDto demo, List<UserDto> users) {
+        for (UserDto user : users) {
+            if (demo.getUserId().equals(user.getUserId())) {
+                BeanConvertUtil.covertBean(user, demo);
+            }
+        }
+    }
+
+    /**
+     * 获取批量userId
+     *
+     * @param demos 小区楼信息
+     * @return 批量userIds 信息
+     */
+    private String[] getUserIds(List<DemoDto> demos) {
+        List<String> userIds = new ArrayList<String>();
+        for (DemoDto demo : demos) {
+            userIds.add(demo.getUserId());
+        }
+
+        return userIds.toArray(new String[userIds.size()]);
+    }
+
+    @Override
+    public int queryDemosCount(@RequestBody DemoDto demoDto) {
+        return demoServiceDaoImpl.queryDemosCount(BeanConvertUtil.beanCovertMap(demoDto));    }
+
+    public IDemoServiceDao getDemoServiceDaoImpl() {
+        return demoServiceDaoImpl;
+    }
+
+    public void setDemoServiceDaoImpl(IDemoServiceDao demoServiceDaoImpl) {
+        this.demoServiceDaoImpl = demoServiceDaoImpl;
+    }
+
+    public IUserInnerServiceSMO getUserInnerServiceSMOImpl() {
+        return userInnerServiceSMOImpl;
+    }
+
+    public void setUserInnerServiceSMOImpl(IUserInnerServiceSMO userInnerServiceSMOImpl) {
+        this.userInnerServiceSMOImpl = userInnerServiceSMOImpl;
+    }
+}

+ 26 - 0
WebService/src/main/java/com/java110/web/components/demo/ListDemoComponent.java

@@ -0,0 +1,26 @@
+package com.java110.web.components.demo;
+
+import com.java110.core.context.IPageData;
+import com.java110.web.smo.IDemoServiceSMO;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.ResponseEntity;
+import org.springframework.stereotype.Component;
+
+@Component("listDemo")
+public class ListDemoComponent {
+    @Autowired
+    private IDemoServiceSMO demoServiceSMOImpl;
+
+    /**
+     * 查询小区楼信息
+     *
+     * @param pd 页面封装对象 包含页面请求数据
+     * @return ResponseEntity对象返回给页面
+     */
+    public ResponseEntity<String> list(IPageData pd) {
+
+        return demoServiceSMOImpl.listDemo(pd);
+    }
+
+
+}

+ 43 - 0
WebService/src/main/java/com/java110/web/smo/IDemoServiceSMO.java

@@ -0,0 +1,43 @@
+package com.java110.web.smo;
+
+import com.java110.core.context.IPageData;
+import org.springframework.http.ResponseEntity;
+
+/**
+ * 用例接口
+ */
+public interface IDemoServiceSMO {
+
+    /**
+     * 查询用例信息
+     *
+     * @param pd 页面数据封装对象
+     * @return 返回 ResponseEntity对象包含 http状态 信息 body信息
+     */
+    ResponseEntity<String> listDemo(IPageData pd);
+
+
+    /**
+     * 添加用例信息
+     *
+     * @param pd 页面数据封装对象
+     * @return 返回 ResponseEntity对象包含 http状态 信息 body信息
+     */
+    ResponseEntity<String> saveDemo(IPageData pd);
+
+    /**
+     * 编辑用例信息
+     *
+     * @param pd 页面数据封装对象
+     * @return 返回 ResponseEntity对象包含 http状态 信息 body信息
+     */
+    ResponseEntity<String> editDemo(IPageData pd);
+
+    /**
+     * 删除用例
+     *
+     * @param pd 页面数据封装对象
+     * @return 返回 ResponseEntity对象包含 http状态 信息 body信息
+     */
+    ResponseEntity<String> deleteDemo(IPageData pd);
+}

+ 273 - 0
WebService/src/main/java/com/java110/web/smo/impl/DemoServiceSMOImpl.java

@@ -0,0 +1,273 @@
+package com.java110.web.smo.impl;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.common.constant.PrivilegeCodeConstant;
+import com.java110.common.constant.ResponseConstant;
+import com.java110.common.constant.ServiceConstant;
+import com.java110.common.exception.SMOException;
+import com.java110.common.util.Assert;
+import com.java110.core.context.IPageData;
+import com.java110.web.core.BaseComponentSMO;
+import com.java110.web.smo.IDemoServiceSMO;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.HttpMethod;
+import org.springframework.http.HttpStatus;
+import org.springframework.http.ResponseEntity;
+import org.springframework.stereotype.Service;
+import org.springframework.web.client.RestTemplate;
+
+/**
+ * 用例实现类
+ * <p>
+ * add by wuxw 2019-04-22
+ */
+
+@Service("demoServiceSMOImpl")
+public class DemoServiceSMOImpl extends BaseComponentSMO implements IDemoServiceSMO {
+
+    private static Logger logger = LoggerFactory.getLogger(DemoServiceSMOImpl.class);
+
+
+    @Autowired
+    private RestTemplate restTemplate;
+
+    /**
+     * 查询小区楼
+     *
+     * @param pd 页面数据封装对象
+     * @return 返回 ResponseEntity对象包含 http状态 信息 body信息
+     */
+    @Override
+    public ResponseEntity<String> listDemo(IPageData pd) {
+
+        validateListDemo(pd);
+
+        JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
+        int page = Integer.parseInt(paramIn.getString("page"));
+        int row = Integer.parseInt(paramIn.getString("row"));
+
+
+        //校验用户是否有权限
+        //super.checkUserHasPrivilege(pd, restTemplate, PrivilegeCodeConstant.PRIVILEGE_FLOOR);
+
+        ResponseEntity responseEntity = super.getStoreInfo(pd, restTemplate);
+        if (responseEntity.getStatusCode() != HttpStatus.OK) {
+            return responseEntity;
+        }
+        Assert.jsonObjectHaveKey(responseEntity.getBody().toString(), "storeId", "根据用户ID查询商户ID失败,未包含storeId节点");
+        Assert.jsonObjectHaveKey(responseEntity.getBody().toString(), "storeTypeCd", "根据用户ID查询商户类型失败,未包含storeTypeCd节点");
+
+        String storeId = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeId");
+        String storeTypeCd = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeTypeCd");
+        //数据校验是否 商户是否入驻该小区
+       // super.checkStoreEnterCommunity(pd, storeId, storeTypeCd, communityId, restTemplate);
+        String apiUrl = ServiceConstant.SERVICE_API_URL + "/api/demo.queryDemoConfig" + mapToUrlParam(paramIn);
+
+
+        responseEntity = this.callCenterService(restTemplate, pd, "",
+                apiUrl,
+                HttpMethod.GET);
+
+        return responseEntity;
+    }
+
+    @Override
+    public ResponseEntity<String> saveDemo(IPageData pd) {
+
+        validateSaveCar(pd);
+
+        //校验员工是否有权限操作
+        //super.checkUserHasPrivilege(pd, restTemplate, PrivilegeCodeConstant.PRIVILEGE_CAR);
+
+        JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
+        //String communityId = paramIn.getString("communityId");
+        ResponseEntity responseEntity = super.getStoreInfo(pd, restTemplate);
+        if (responseEntity.getStatusCode() != HttpStatus.OK) {
+            return responseEntity;
+        }
+        Assert.jsonObjectHaveKey(responseEntity.getBody().toString(), "storeId", "根据用户ID查询商户ID失败,未包含storeId节点");
+        Assert.jsonObjectHaveKey(responseEntity.getBody().toString(), "storeTypeCd", "根据用户ID查询商户类型失败,未包含storeTypeCd节点");
+
+        String storeId = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeId");
+        String storeTypeCd = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeTypeCd");
+        //数据校验是否 商户是否入驻该小区
+        //super.checkStoreEnterCommunity(pd, storeId, storeTypeCd, communityId, restTemplate);
+
+        paramIn.put("userId", pd.getUserId());
+        paramIn.put("storeId", storeId);
+        responseEntity = this.callCenterService(restTemplate, pd, paramIn.toJSONString(),
+                ServiceConstant.SERVICE_API_URL + "/api/parkingSpace.sellParkingSpace",
+                HttpMethod.POST);
+
+        return responseEntity;
+    }
+
+    /**
+     * 编辑小区楼信息
+     *
+     * @param pd 页面数据封装对象
+     * @return
+     */
+    @Override
+    public ResponseEntity<String> editDemo(IPageData pd) {
+
+        validateEditCar(pd);
+
+        //校验员工是否有权限操作
+        super.checkUserHasPrivilege(pd, restTemplate, PrivilegeCodeConstant.PRIVILEGE_FLOOR);
+
+        JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
+        if (paramIn.getString("carId").equals(paramIn.getString("memberId"))) {
+            paramIn.put("carTypeCd", "1001");
+        } else {
+            paramIn.put("carTypeCd", "1002");
+        }
+        String communityId = paramIn.getString("communityId");
+        ResponseEntity responseEntity = super.getStoreInfo(pd, restTemplate);
+        if (responseEntity.getStatusCode() != HttpStatus.OK) {
+            return responseEntity;
+        }
+        Assert.jsonObjectHaveKey(responseEntity.getBody().toString(), "storeId", "根据用户ID查询商户ID失败,未包含storeId节点");
+        Assert.jsonObjectHaveKey(responseEntity.getBody().toString(), "storeTypeCd", "根据用户ID查询商户类型失败,未包含storeTypeCd节点");
+
+        String storeId = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeId");
+        String storeTypeCd = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeTypeCd");
+        //数据校验是否 商户是否入驻该小区
+        super.checkStoreEnterCommunity(pd, storeId, storeTypeCd, communityId, restTemplate);
+        paramIn.put("userId", pd.getUserId());
+        responseEntity = this.callCenterService(restTemplate, pd, paramIn.toJSONString(),
+                ServiceConstant.SERVICE_API_URL + "/api/car.editCar",
+                HttpMethod.POST);
+
+        return responseEntity;
+    }
+
+    @Override
+    public ResponseEntity<String> deleteDemo(IPageData pd) {
+        validateDeleteCar(pd);
+        //校验员工是否有权限操作
+        super.checkUserHasPrivilege(pd, restTemplate, PrivilegeCodeConstant.PRIVILEGE_FLOOR);
+        JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
+        if (paramIn.getString("carId").equals(paramIn.getString("memberId"))) {
+            paramIn.put("carTypeCd", "1001");
+        } else {
+            paramIn.put("carTypeCd", "1002");
+        }
+        String communityId = paramIn.getString("communityId");
+        ResponseEntity responseEntity = super.getStoreInfo(pd, restTemplate);
+        if (responseEntity.getStatusCode() != HttpStatus.OK) {
+            return responseEntity;
+        }
+        Assert.jsonObjectHaveKey(responseEntity.getBody().toString(), "storeId", "根据用户ID查询商户ID失败,未包含storeId节点");
+        Assert.jsonObjectHaveKey(responseEntity.getBody().toString(), "storeTypeCd", "根据用户ID查询商户类型失败,未包含storeTypeCd节点");
+
+        String storeId = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeId");
+        String storeTypeCd = JSONObject.parseObject(responseEntity.getBody().toString()).getString("storeTypeCd");
+        //数据校验是否 商户是否入驻该小区
+        super.checkStoreEnterCommunity(pd, storeId, storeTypeCd, communityId, restTemplate);
+
+        responseEntity = this.callCenterService(restTemplate, pd, paramIn.toJSONString(),
+                ServiceConstant.SERVICE_API_URL + "/api/car.deleteCar",
+                HttpMethod.POST);
+
+        return responseEntity;
+    }
+
+    /**
+     * 删除小区楼 校验
+     *
+     * @param pd 页面数据封装
+     */
+    private void validateDeleteCar(IPageData pd) {
+
+        Assert.jsonObjectHaveKey(pd.getReqData(), "communityId", "未包含小区ID");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "memberId", "未包含业主ID");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "carId", "未包含业主ID");
+        //Assert.jsonObjectHaveKey(pd.getReqData(), "carTypeCd", "请求报文中未包含carTypeCd节点");
+
+    }
+
+    /**
+     * 校验修改小区楼 信息
+     *
+     * @param pd 页面数据封装
+     */
+    private void validateEditCar(IPageData pd) {
+        Assert.jsonObjectHaveKey(pd.getReqData(), "communityId", "未包含小区ID");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "memberId", "未包含memberId");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "carId", "未包含carId");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "name", "请求报文中未包含name");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "age", "请求报文中未包含age");
+        //Assert.jsonObjectHaveKey(pd.getReqData(), "carTypeCd", "请求报文中未包含carTypeCd节点");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "link", "请求报文中未包含link");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "sex", "请求报文中未包含sex");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "remark", "未包含小区楼备注");
+    }
+
+    /**
+     * 校验保存小区楼 信息
+     *
+     * @param pd 页面数据封装
+     */
+    private void validateSaveCar(IPageData pd) {
+
+        Assert.jsonObjectHaveKey(pd.getReqData(), "communityId", "未包含小区ID");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "ownerId", "请求报文中未包含ownerId");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "carNum", "请求报文中未包含carNum");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "carBrand", "请求报文中未包含carBrand");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "carType", "请求报文中未包含carType");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "carColor", "未包含carColor");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "psId", "未包含psId");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "receivedAmount", "未包含receivedAmount");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "sellOrHire", "未包含sellOrHire");
+
+        JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
+        Assert.hasLength(paramIn.getString("communityId"), "小区ID不能为空");
+        Assert.hasLength(paramIn.getString("ownerId"), "ownerId不能为空");
+        Assert.hasLength(paramIn.getString("psId"), "psId不能为空");
+        Assert.hasLength(paramIn.getString("receivedAmount"), "receivedAmount不能为空");
+
+        if(!"H".equals(paramIn.getString("sellOrHire"))
+                && !"S".equals(paramIn.getString("sellOrHire"))){
+            throw new IllegalArgumentException("入参错误,无法识别该操作");
+        }
+
+        if("H".equals(paramIn.getString("sellOrHire"))){
+            Assert.jsonObjectHaveKey(pd.getReqData(), "cycles", "未包含cycles");
+            Assert.hasLength(paramIn.getString("cycles"), "cycles不能为空");
+        }
+    }
+
+    /**
+     * 校验查询小区楼信息
+     *
+     * @param pd 页面封装对象
+     */
+    private void validateListDemo(IPageData pd) {
+        Assert.jsonObjectHaveKey(pd.getReqData(), "page", "请求报文中未包含page节点");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "row", "请求报文中未包含row节点");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "demoName", "请求中未包含demoName信息");
+        Assert.jsonObjectHaveKey(pd.getReqData(), "demoValue", "请求中未包含demoValue信息");
+        JSONObject paramIn = JSONObject.parseObject(pd.getReqData());
+        Assert.isInteger(paramIn.getString("page"), "page不是数字");
+        Assert.isInteger(paramIn.getString("row"), "rows不是数字");
+        int row = Integer.parseInt(paramIn.getString("row"));
+
+
+        if (row > MAX_ROW) {
+            throw new SMOException(ResponseConstant.RESULT_CODE_ERROR, "row 数量不能大于50");
+        }
+
+    }
+
+
+    public RestTemplate getRestTemplate() {
+        return restTemplate;
+    }
+
+    public void setRestTemplate(RestTemplate restTemplate) {
+        this.restTemplate = restTemplate;
+    }
+}

+ 31 - 0
WebService/src/main/resources/components/add-demo/addDemo.html

@@ -0,0 +1,31 @@
+<div id = "addDemoModel" class="modal fade" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true" >
+    <div class="modal-dialog modal-lg">
+        <div class="modal-content">
+            <div class="modal-body">
+                <h3 class="m-t-none m-b ">添加用例</h3>
+                <div class="ibox-content">
+                    <div>
+                        <div>
+                            <div class="form-group row">
+                                <label class="col-sm-2 col-form-label">用例名称</label>
+                                <div class="col-sm-10"><input v-model="addDemoInfo.demoName" type="text" placeholder="必填,请填写用例名称" class="form-control"></div>
+                            </div>
+                            <div class="form-group row">
+                                <label class="col-sm-2 col-form-label">用例值</label>
+                                <div class="col-sm-10"><input v-model="addDemoInfo.demoValue" type="text" placeholder="必填,请填写用例值" class="form-control"></div>
+                            </div>
+                            <div class="form-group row">
+                                <label class="col-sm-2 col-form-label">备注</label>
+                                <div class="col-sm-10"><input v-model="addDemoInfo.demoRemark" type="text" placeholder="可填,请填写用例备注" class="form-control"></div>
+                            </div>
+                            <div class="ibox-content">
+                                <button class="btn btn-primary float-right" type="button" v-on:click="saveDemoInfo()" ><i class="fa fa-check"></i>&nbsp;保存</button>
+                                <button type="button" class="btn btn-warning float-right" style="margin-right:20px;" data-dismiss="modal">取消</button>
+                            </div>
+                        </div>
+                    </div>
+                </div>
+            </div>
+        </div>
+    </div>
+</div>

+ 103 - 0
WebService/src/main/resources/components/add-demo/addDemo.js

@@ -0,0 +1,103 @@
+(function(vc){
+
+    vc.extends({
+        data:{
+            addDemoInfo:{
+                demoName:'',
+                demoValue:'',
+                demoRemark:''
+            }
+        },
+         _initMethod:function(){
+
+         },
+         _initEvent:function(){
+            vc.on('addDemo','openAddDemoModal',function(){
+                $('#addDemoModel').modal('show');
+            });
+        },
+        methods:{
+            addDemoValidate(){
+                return vc.validate.validate({
+                    addDemoInfo:vc.component.addDemoInfo
+                },{
+                    'addDemoInfo.demoName':[
+                        {
+                            limit:"required",
+                            param:"",
+                            errInfo:"名称不能为空"
+                        },
+                        {
+                            limit:"maxin",
+                            param:"2,20",
+                            errInfo:"名称长度必须在2位至10位"
+                        },
+                    ],
+                    'addDemoInfo.demoValue':[
+                        {
+                            limit:"required",
+                            param:"",
+                            errInfo:"值不能为空"
+                        },
+                        {
+                            limit:"maxin",
+                            param:"2,20",
+                            errInfo:"描述不能为空"
+                        },
+                    ],
+                    'addDemoInfo.demoRemark':[
+
+                        {
+                            limit:"maxLength",
+                            param:"200",
+                            errInfo:"备注长度不能超过200位"
+                        }
+                    ]
+
+                });
+            },
+            saveDemoInfo:function(){
+                if(!vc.component.addDemoValidate()){
+                    vc.message(vc.validate.errInfo);
+
+                    return ;
+                }
+                vc.http.post(
+                    'addDemo',
+                    'saveDemo',
+                    JSON.stringify(vc.component.addDemoInfo),
+                    {
+                        emulateJSON:true
+                     },
+                     function(json,res){
+                        //vm.menus = vm.refreshMenuActive(JSON.parse(json),0);
+                        if(res.status == 200){
+                            //关闭model
+                            $('#addDemoModel').modal('hide');
+                            vc.component.clearAddFloorInfo();
+                            vc.emit('listFloor','listFloorData',{});
+
+                            return ;
+                        }
+                        vc.component.addFloorInfo.errorInfo = json;
+
+                     },
+                     function(errInfo,error){
+                        console.log('请求失败处理');
+
+                        vc.component.addFloorInfo.errorInfo = errInfo;
+
+                     });
+            },
+            clearAddFloorInfo:function(){
+                vc.component.addFloorInfo = {
+                                            name:'',
+                                            floorNum:'',
+                                            remark:'',
+                                            errorInfo:''
+                                        };
+            }
+        }
+    });
+
+})(window.vc);

+ 75 - 0
WebService/src/main/resources/components/list-demo/listDemo.html

@@ -0,0 +1,75 @@
+<div id="component" class="wrapper wrapper-content animated fadeInRight ecommerce">
+    <div class="row">
+        <div class="col-lg-12">
+            <div class="ibox">
+                <div class="ibox-title">
+                    <h5>业主信息</h5>
+                    <div class="ibox-tools" style="top:10px;">
+                        <button type="button" class="btn btn-primary btn-sm" v-on:click="_openAddOwnerModal(-1)">
+                            <i class="glyphicon glyphicon-plus"></i>
+                            添加DEMO
+                        </button>
+                    </div>
+                </div>
+                <div class="ibox-content">
+
+                    <table class="footable table table-stripped toggle-arrow-tiny" data-page-size="15">
+                        <thead>
+                        <tr>
+                            <th>用例ID</th>
+                            <th data-hide="phone">名称</th>
+                            <th data-hide="phone">用例值</th>
+                            <th data-hide="phone">备注</th>
+                            <th class="text-right">操作</th>
+
+                        </tr>
+                        </thead>
+                        <tbody>
+                        <tr v-for="owner in listOwnerInfo.owners">
+                            <td>
+                                {{demos.demoId}}
+                            </td>
+
+                            <td>
+                                {{demos.demoName}}
+                            </td>
+
+                            <td>
+                                {{demos.demoValue}}
+                            </td>
+                            <td>
+                                {{demos.demoRemark}}
+                            </td>
+                            <td class="text-right">
+                                <div class="btn-group">
+                                    <button class="btn-white btn btn-xs" v-on:click="_openEditOwnerModel(owner)">修改</button>
+                                </div>
+                                <div class="btn-group">
+                                    <button class="btn-white btn btn-xs" v-on:click="_openDelOwnerModel(owner)">删除</button>
+                                </div>
+                            </td>
+                        </tr>
+                        </tbody>
+                        <tfoot>
+                        <tr>
+                            <td colspan="7">
+                                <ul class="pagination float-right"></ul>
+                            </td>
+                        </tr>
+                        </tfoot>
+                    </table>
+                    <!-- 分页 -->
+                    <vc:create name="pagination"></vc:create>
+                </div>
+            </div>
+        </div>
+    </div>
+
+    <vc:create
+            name="addDemo"
+    ></vc:create>
+    <vc:create
+            name="addDemo"
+    ></vc:create>
+
+</div>

+ 64 - 0
WebService/src/main/resources/components/list-demo/listDemo.js

@@ -0,0 +1,64 @@
+(function(vc){
+    var DEFAULT_PAGE = 1;
+    var DEFAULT_ROWS = 10;
+    vc.extends({
+        data:{
+            listDemoInfo:{
+                demos:[],
+                total:0,
+                records:1
+            }
+        },
+        _initMethod:function(){
+            vc.component._listOwnerData(DEFAULT_PAGE,DEFAULT_ROWS);
+        },
+        _initEvent:function(){
+            vc.on('listDemo','listDemoData',function(){
+                vc.component._listOwnerData(DEFAULT_PAGE,DEFAULT_ROWS);
+            });
+            vc.on('pagination','page_event',function(_currentPage){
+                vc.component._listOwnerData(_currentPage,DEFAULT_ROWS);
+            });
+        },
+        methods:{
+            _listOwnerData:function(_page,_row){
+                var param = {
+                    params:{
+                        page:_page,
+                        row:_row
+                    }
+                }
+
+               //发送get请求
+               vc.http.get('listDemo',
+                            'list',
+                             param,
+                             function(json,res){
+                                var listDemoDate =JSON.parse(json);
+
+                                vc.component.listDemoInfo.total = listDemoDate.total;
+                                vc.component.listDemoInfo.records = listDemoDate.records;
+                                vc.component.listDemoInfo.demos = listDemoDate.demos;
+
+                                vc.emit('pagination','init',{
+                                    total:vc.component.listOwnerInfo.records,
+                                    currentPage:_page
+                                });
+                             },function(errInfo,error){
+                                console.log('请求失败处理');
+                             }
+                           );
+
+            },
+            _openAddOwnerModal:function(){ //打开添加框
+                vc.emit('addDemo','openAddDemoModal',-1);
+            },
+            _openDelOwnerModel:function(_owner){ // 打开删除对话框
+                vc.emit('deleteOwner','openOwnerModel',_owner);
+            },
+            _openEditOwnerModel:function(_owner){
+                vc.emit('editOwner','openEditOwnerModal',_owner);
+            }
+        }
+    })
+})(window.vc);

+ 33 - 0
WebService/src/main/resources/views/demoFlow.html

@@ -0,0 +1,33 @@
+<!DOCTYPE html>
+<html lang="en"
+      xmlns="http://www.w3.org/1999/xhtml"
+      xmlns:th="http://www.thymeleaf.org"
+      xmlns:vc="http://www.thymeleaf.org">
+<head>
+    <meta charset="UTF-8"/>
+    <title>小区楼初始化|java110</title>
+    <vc:create name="commonTop"></vc:create>
+</head>
+<body>
+<vc:create name="bodyTop"></vc:create>
+<div id="wrapper">
+    <vc:create name="menu"></vc:create>
+
+
+    <div id="page-wrapper" class="gray-bg dashbard-1">
+        <div class="row border-bottom">
+            <vc:create name="nav"></vc:create>
+        </div>
+        <!-- id="component" -->
+        <div class="wrapper wrapper-content animated fadeInRight">
+            <vc:create name="listDemo"></vc:create>
+        </div>
+
+        <vc:create name="copyright"></vc:create>
+
+    </div>
+</div>
+
+<vc:create name="commonBottom"></vc:create>
+</body>
+</html>

+ 114 - 0
docs/services/demo/DeleteDemoInfo.md

@@ -0,0 +1,114 @@
+
+
+**1\. 删除demo**
+###### 接口功能
+> API服务做删除demo时调用该接口
+
+###### URL
+> [http://demo-service/demoApi/service](http://demo-service/demoApi/service)
+
+###### 支持格式
+> JSON
+
+###### HTTP请求方式
+> POST
+
+###### 协议接口
+|父元素名称|参数名称|约束|类型|长度|描述|取值说明|
+| :-: | :-: | :-: | :-: | :-: | :-: | :-:|
+|-|orders|1|Object|-|订单节点|-|
+|-|business|1|Array|-|业务节点|-|
+
+###### orders
+|父元素名称|参数名称|约束|类型|长度|描述|取值说明|
+| :-: | :-: | :-: | :-: | :-: | :-: | :-: |
+|-|orders|1|Object|-|订单节点|-|
+|orders|appId|1|String|10|系统ID|由中心服务提供|
+|orders|transactionId|1|String|30|交互流水|appId+'00'+YYYYMMDD+10位序列|
+|orders|userId|1|String|30|用户ID|已有用户ID|
+|orders|orderTypeCd|1|String|4|订单类型|查看订单类型说明|
+|orders|requestTime|1|String|14|请求时间|YYYYMMDDhhmmss|
+|orders|remark|1|String|200|备注|备注|
+|orders|sign|?|String|64|签名|查看加密说明|
+|orders|attrs|?|Array|-|订单属性|-|
+|attrs|specCd|1|String|12|规格编码|由中心服务提供|
+|attrs|value|1|String|50|属性值|-|
+|orders|response|1|Object|-|返回结果节点|-|
+|response|code|1|String|4|返回状态|查看状态说明|
+|response|message|1|String|200|返回状态描述|-|
+
+###### business
+|父元素名称|参数名称|约束|类型|长度|描述|取值说明|
+| :-: | :-: | :-: | :-: | :-: | :-: | :-: |
+|-|business|?|Array|-|业务节点|-|
+|business|businessTypeCd|1|String|12|业务类型编码|500100030002|
+|business|datas|1|Object|-|数据节点|不同的服务下的节点不一样|
+|datas|businessDemoInfo|1|Object|-|小区成员|小区成员|
+|businessDemoInfo|demoId|1|String|30|-|-|
+
+
+###### 返回协议
+
+当http返回状态不为200 时请求处理失败 body内容为失败的原因
+
+当http返回状态为200时请求处理成功,body内容为返回内容,
+
+
+
+
+
+###### 举例
+> 地址:[http://demo-service/demoApi/service](http://demo-service/demoApi/service)
+
+``` javascript
+请求头信息:
+Content-Type:application/json
+
+请求报文:
+
+{
+  "orders": {
+    "appId": "外系统ID,分配得到",
+    "transactionId": "100000000020180409224736000001",
+    "userId": "用户ID",
+    "orderTypeCd": "订单类型,查询,受理",
+    "requestTime": "20180409224736",
+    "remark": "备注",
+    "sign": "这个服务是否要求MD5签名",
+    "businessType":"I",
+    "attrs": [{
+      "specCd": "配置的字段ID",
+      "value": "具体值"
+    }]
+  },
+  "business": {
+    "businessTypeCd": "900100050001",
+    "bId":"1234567892",
+    "remark": "备注",
+    "datas": {
+      "businessDemoInfo": {
+                "demoId":"填写存在的值"
+      }
+    },
+    "attrs": [{
+      "specCd": "配置的字段ID",
+      "value": "具体值"
+    }]
+  }
+}
+
+返回报文:
+ {
+	"orderTypeCd": "D",
+	"response": {
+		"code": "0000",
+		"message": "成功"
+	},
+	"responseTime": "20190418102004",
+	"bId": "202019041810750003",
+	"businessType": "B",
+	"transactionId": "3a5a411ec65a4c3f895935638aa1d2bc",
+	"dataFlowId": "44fde86d39ce46f4b4aab5f6b14f3947"
+}
+
+```

+ 122 - 0
docs/services/demo/SaveDemoInfo.md

@@ -0,0 +1,122 @@
+
+
+**1\. 保存demo**
+###### 接口功能
+> API服务做保存demo时调用该接口
+
+###### URL
+> [http://demo-service/demoApi/service](http://demo-service/demoApi/service)
+
+###### 支持格式
+> JSON
+
+###### HTTP请求方式
+> POST
+
+###### 协议接口
+|父元素名称|参数名称|约束|类型|长度|描述|取值说明|
+| :-: | :-: | :-: | :-: | :-: | :-: | :-:|
+|-|orders|1|Object|-|订单节点|-|
+|-|business|1|Array|-|业务节点|-|
+
+###### orders
+|父元素名称|参数名称|约束|类型|长度|描述|取值说明|
+| :-: | :-: | :-: | :-: | :-: | :-: | :-: |
+|-|orders|1|Object|-|订单节点|-|
+|orders|appId|1|String|10|系统ID|由中心服务提供|
+|orders|transactionId|1|String|30|交互流水|appId+'00'+YYYYMMDD+10位序列|
+|orders|userId|1|String|30|用户ID|已有用户ID|
+|orders|orderTypeCd|1|String|4|订单类型|查看订单类型说明|
+|orders|requestTime|1|String|14|请求时间|YYYYMMDDhhmmss|
+|orders|remark|1|String|200|备注|备注|
+|orders|sign|?|String|64|签名|查看加密说明|
+|orders|attrs|?|Array|-|订单属性|-|
+|attrs|specCd|1|String|12|规格编码|由中心服务提供|
+|attrs|value|1|String|50|属性值|-|
+|orders|response|1|Object|-|返回结果节点|-|
+|response|code|1|String|4|返回状态|查看状态说明|
+|response|message|1|String|200|返回状态描述|-|
+
+###### business
+|父元素名称|参数名称|约束|类型|长度|描述|取值说明|
+| :-: | :-: | :-: | :-: | :-: | :-: | :-: |
+|-|business|?|Array|-|业务节点|-|
+|business|businessTypeCd|1|String|12|业务类型编码|500100030002|
+|business|datas|1|Object|-|数据节点|不同的服务下的节点不一样|
+|datas|businessDemoInfo|1|Object|-|小区成员|小区成员|
+|businessDemoInfo|demoRemark|1|String|30|-|-|
+|businessDemoInfo|demoName|1|String|30|-|-|
+|businessDemoInfo|demoValue|1|String|30|-|-|
+|businessDemoInfo|demoId|1|String|30|-|-|
+|businessDemoInfo|userId|1|String|30|-|-|
+
+
+###### 返回协议
+
+当http返回状态不为200 时请求处理失败 body内容为失败的原因
+
+当http返回状态为200时请求处理成功,body内容为返回内容,
+
+
+
+
+
+###### 举例
+> 地址:[http://demo-service/demoApi/service](http://demo-service/demoApi/service)
+
+``` javascript
+请求头信息:
+Content-Type:application/json
+
+请求报文:
+
+{
+  "orders": {
+    "appId": "外系统ID,分配得到",
+    "transactionId": "100000000020180409224736000001",
+    "userId": "用户ID",
+    "orderTypeCd": "订单类型,查询,受理",
+    "requestTime": "20180409224736",
+    "remark": "备注",
+    "sign": "这个服务是否要求MD5签名",
+    "businessType":"I",
+    "attrs": [{
+      "specCd": "配置的字段ID",
+      "value": "具体值"
+    }]
+  },
+  "business": {
+    "businessTypeCd": "900100030001",
+    "bId":"1234567892",
+    "remark": "备注",
+    "datas": {
+      "businessDemoInfo": {
+                "demoRemark":"填写具体值",
+        "demoName":"填写具体值",
+        "demoValue":"填写具体值",
+        "demoId":"填写具体值",
+        "userId":"填写具体值"
+      }
+    },
+    "attrs": [{
+      "specCd": "配置的字段ID",
+      "value": "具体值"
+    }]
+  }
+}
+
+返回报文:
+ {
+	"orderTypeCd": "D",
+	"response": {
+		"code": "0000",
+		"message": "成功"
+	},
+	"responseTime": "20190418102004",
+	"bId": "202019041810750003",
+	"businessType": "B",
+	"transactionId": "3a5a411ec65a4c3f895935638aa1d2bc",
+	"dataFlowId": "44fde86d39ce46f4b4aab5f6b14f3947"
+}
+
+```

+ 122 - 0
docs/services/demo/UpdateDemoInfo.md

@@ -0,0 +1,122 @@
+
+
+**1\. 修改demo**
+###### 接口功能
+> API服务做修改demo时调用该接口
+
+###### URL
+> [http://demo-service/demoApi/service](http://demo-service/demoApi/service)
+
+###### 支持格式
+> JSON
+
+###### HTTP请求方式
+> POST
+
+###### 协议接口
+|父元素名称|参数名称|约束|类型|长度|描述|取值说明|
+| :-: | :-: | :-: | :-: | :-: | :-: | :-:|
+|-|orders|1|Object|-|订单节点|-|
+|-|business|1|Array|-|业务节点|-|
+
+###### orders
+|父元素名称|参数名称|约束|类型|长度|描述|取值说明|
+| :-: | :-: | :-: | :-: | :-: | :-: | :-: |
+|-|orders|1|Object|-|订单节点|-|
+|orders|appId|1|String|10|系统ID|由中心服务提供|
+|orders|transactionId|1|String|30|交互流水|appId+'00'+YYYYMMDD+10位序列|
+|orders|userId|1|String|30|用户ID|已有用户ID|
+|orders|orderTypeCd|1|String|4|订单类型|查看订单类型说明|
+|orders|requestTime|1|String|14|请求时间|YYYYMMDDhhmmss|
+|orders|remark|1|String|200|备注|备注|
+|orders|sign|?|String|64|签名|查看加密说明|
+|orders|attrs|?|Array|-|订单属性|-|
+|attrs|specCd|1|String|12|规格编码|由中心服务提供|
+|attrs|value|1|String|50|属性值|-|
+|orders|response|1|Object|-|返回结果节点|-|
+|response|code|1|String|4|返回状态|查看状态说明|
+|response|message|1|String|200|返回状态描述|-|
+
+###### business
+|父元素名称|参数名称|约束|类型|长度|描述|取值说明|
+| :-: | :-: | :-: | :-: | :-: | :-: | :-: |
+|-|business|?|Array|-|业务节点|-|
+|business|businessTypeCd|1|String|12|业务类型编码|500100030002|
+|business|datas|1|Object|-|数据节点|不同的服务下的节点不一样|
+|datas|businessDemoInfo|1|Object|-|小区成员|小区成员|
+|businessDemoInfo|demoRemark|1|String|30|-|-|
+|businessDemoInfo|demoName|1|String|30|-|-|
+|businessDemoInfo|demoValue|1|String|30|-|-|
+|businessDemoInfo|demoId|1|String|30|-|-|
+|businessDemoInfo|userId|1|String|30|-|-|
+
+
+###### 返回协议
+
+当http返回状态不为200 时请求处理失败 body内容为失败的原因
+
+当http返回状态为200时请求处理成功,body内容为返回内容,
+
+
+
+
+
+###### 举例
+> 地址:[http://demo-service/demoApi/service](http://demo-service/demoApi/service)
+
+``` javascript
+请求头信息:
+Content-Type:application/json
+
+请求报文:
+
+{
+  "orders": {
+    "appId": "外系统ID,分配得到",
+    "transactionId": "100000000020180409224736000001",
+    "userId": "用户ID",
+    "orderTypeCd": "订单类型,查询,受理",
+    "requestTime": "20180409224736",
+    "remark": "备注",
+    "sign": "这个服务是否要求MD5签名",
+    "businessType":"I",
+    "attrs": [{
+      "specCd": "配置的字段ID",
+      "value": "具体值"
+    }]
+  },
+  "business": {
+    "businessTypeCd": "900100040001",
+    "bId":"1234567892",
+    "remark": "备注",
+    "datas": {
+      "businessDemoInfo": {
+                "demoRemark":"填写具体值",
+        "demoName":"填写具体值",
+        "demoValue":"填写具体值",
+        "demoId":"填写具体值",
+        "userId":"填写具体值"
+      }
+    },
+    "attrs": [{
+      "specCd": "配置的字段ID",
+      "value": "具体值"
+    }]
+  }
+}
+
+返回报文:
+ {
+	"orderTypeCd": "D",
+	"response": {
+		"code": "0000",
+		"message": "成功"
+	},
+	"responseTime": "20190418102004",
+	"bId": "202019041810750003",
+	"businessType": "B",
+	"transactionId": "3a5a411ec65a4c3f895935638aa1d2bc",
+	"dataFlowId": "44fde86d39ce46f4b4aab5f6b14f3947"
+}
+
+```

+ 77 - 0
java110-bean/src/main/java/com/java110/dto/demo/DemoDto.java

@@ -0,0 +1,77 @@
+package com.java110.dto.demo;
+
+import com.java110.dto.PageDto;
+
+import java.io.Serializable;
+import java.util.Date;
+
+/**
+ * @ClassName FloorDto
+ * @Description demo数据层封装
+ * @Author wuxw
+ * @Date 2019/4/24 8:52
+ * @Version 1.0
+ * add by wuxw 2019/4/24
+ **/
+public class DemoDto extends PageDto implements Serializable {
+
+    private String demoRemark;
+private String demoName;
+private String demoValue;
+private String demoId;
+private String userId;
+
+
+    private Date createTime;
+
+    private String statusCd = "0";
+
+
+    public String getDemoRemark() {
+        return demoRemark;
+    }
+public void setDemoRemark(String demoRemark) {
+        this.demoRemark = demoRemark;
+    }
+public String getDemoName() {
+        return demoName;
+    }
+public void setDemoName(String demoName) {
+        this.demoName = demoName;
+    }
+public String getDemoValue() {
+        return demoValue;
+    }
+public void setDemoValue(String demoValue) {
+        this.demoValue = demoValue;
+    }
+public String getDemoId() {
+        return demoId;
+    }
+public void setDemoId(String demoId) {
+        this.demoId = demoId;
+    }
+public String getUserId() {
+        return userId;
+    }
+public void setUserId(String userId) {
+        this.userId = userId;
+    }
+
+
+    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;
+    }
+}

+ 81 - 0
java110-code-generator/src/main/java/com/java110/DemoGeneratorApplication.java

@@ -0,0 +1,81 @@
+package com.java110;
+
+
+import com.java110.code.*;
+
+import java.util.HashMap;
+import java.util.Map;
+
+/**
+ * Hello world!
+ */
+public class DemoGeneratorApplication {
+
+    protected DemoGeneratorApplication() {
+        // prevents calls from subclass
+        throw new UnsupportedOperationException();
+    }
+
+    /**
+     * 代码生成器 入口方法
+     *
+     * @param args 参数
+     */
+    public static void main(String[] args) {
+        Data data = new Data();
+        data.setId("demoId");//主键ID
+        data.setName("demo");//表名
+        data.setDesc("demo");//中文表名
+        data.setNewBusinessTypeCd("BUSINESS_TYPE_SAVE_DEMO_INFO"); //业务类型
+        data.setUpdateBusinessTypeCd("BUSINESS_TYPE_UPDATE_DEMO_INFO");//修改业务类型
+        data.setDeleteBusinessTypeCd("BUSINESS_TYPE_DELETE_DEMO_INFO");//删除业务类型
+        data.setNewBusinessTypeCdValue("900100030001");//业务类型编码
+        data.setUpdateBusinessTypeCdValue("900100040001");//修修改业务类型编码
+        data.setDeleteBusinessTypeCdValue("900100050001");//删除业务类型编码
+        data.setBusinessTableName("business_demo");//表模型过程表名称
+        data.setTableName("demo");//表模型实列表名称
+        data.setShareParam("demoId");
+        data.setShareColumn("demo_id");
+        Map<String, String> param = new HashMap<String, String>();
+        /**表模型字段绑定**/
+        param.put("demoId", "demo_id");
+        param.put("bId", "b_id");
+        param.put("demoName", "demo_name");
+        param.put("demoValue", "demo_value");
+        param.put("demoRemark", "demo_remark");
+        param.put("userId", "user_id");
+        param.put("operate", "operate");
+        /**表模型字段绑定end  创建时间CREATE_DATE不需要绑定系统默认自带**/
+        data.setParams(param);
+        GeneratorSaveInfoListener generatorSaveInfoListener = new GeneratorSaveInfoListener();
+        generatorSaveInfoListener.generator(data);
+
+        GeneratorAbstractBussiness generatorAbstractBussiness = new GeneratorAbstractBussiness();
+        generatorAbstractBussiness.generator(data);
+
+        GeneratorIServiceDaoListener generatorIServiceDaoListener = new GeneratorIServiceDaoListener();
+        generatorIServiceDaoListener.generator(data);
+
+        GeneratorServiceDaoImplListener generatorServiceDaoImplListener = new GeneratorServiceDaoImplListener();
+        generatorServiceDaoImplListener.generator(data);
+
+        GeneratorServiceDaoImplMapperListener generatorServiceDaoImplMapperListener = null;
+        generatorServiceDaoImplMapperListener = new GeneratorServiceDaoImplMapperListener();
+        generatorServiceDaoImplMapperListener.generator(data);
+
+        GeneratorUpdateInfoListener generatorUpdateInfoListener = new GeneratorUpdateInfoListener();
+        generatorUpdateInfoListener.generator(data);
+
+        GeneratorDeleteInfoListener generatorDeleteInfoListener = new GeneratorDeleteInfoListener();
+        generatorDeleteInfoListener.generator(data);
+
+        GeneratorInnerServiceSMOImpl generatorInnerServiceSMOImpl = new GeneratorInnerServiceSMOImpl();
+        generatorInnerServiceSMOImpl.generator(data);
+
+        GeneratorDtoBean generatorDtoBean = new GeneratorDtoBean();
+        generatorDtoBean.generator(data);
+
+        GeneratorIInnerServiceSMO generatorIInnerServiceSMO = new GeneratorIInnerServiceSMO();
+        generatorIInnerServiceSMO.generator(data);
+    }
+}

+ 13 - 0
java110-common/src/main/java/com/java110/common/constant/BusinessTypeConstant.java

@@ -388,5 +388,18 @@ public class BusinessTypeConstant {
      */
     public static final String BUSINESS_TYPE_DELETE_AGENT_USER = "700100050004";
 
+    /**
+     * 删除方法编码
+     */
+    public static final String BUSINESS_TYPE_DELETE_DEMO_INFO = "900100050001";
+    /**
+     * 保存方法编码
+     */
+    public static final String BUSINESS_TYPE_SAVE_DEMO_INFO = "900100030001";
+    /**
+     * 修改方法编码
+     */
+    public static final String BUSINESS_TYPE_UPDATE_DEMO_INFO = "900100040001";
+
 
 }

+ 3 - 0
java110-common/src/main/java/com/java110/common/constant/ServiceCodeConstant.java

@@ -471,4 +471,7 @@ public class ServiceCodeConstant {
     // 保存停车位信息
     public static final String SERVICE_CODE_EXIT_PARKING_SPACE = "parkingSpace.exitParkingSpace";
 
+    //查询用例配置
+    public static final String SERVICE_CODE_QUERY_DEMO_CONFIG = "demo.queryDemoConfig";
+
 }

+ 2 - 0
java110-core/src/main/java/com/java110/core/factory/GenerateCodeFactory.java

@@ -78,6 +78,8 @@ public class GenerateCodeFactory {
     public static final String CODE_PREFIX_ownerRoomRelId = "78";
     public static final String CODE_PREFIX_psId = "79";
     public static final String CODE_PREFIX_carId = "80";
+    //测试用列
+    public static final String CODE_PREFIX_demoId="90";
 
     /**
      * 只有在不调用服务生成ID时有用

+ 42 - 0
java110-core/src/main/java/com/java110/core/smo/demo/IDemoInnerServiceSMO.java

@@ -0,0 +1,42 @@
+package com.java110.core.smo.demo;
+
+import com.java110.core.feign.FeignConfiguration;
+import com.java110.dto.demo.DemoDto;
+import org.springframework.cloud.netflix.feign.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 IDemoInnerServiceSMO
+ * @Description demo接口类
+ * @Author wuxw
+ * @Date 2019/4/24 9:04
+ * @Version 1.0
+ * add by wuxw 2019/4/24
+ **/
+@FeignClient(name = "store-service", configuration = {FeignConfiguration.class})
+@RequestMapping("/demoApi")
+public interface IDemoInnerServiceSMO {
+
+    /**
+     * <p>查询小区楼信息</p>
+     *
+     *
+     * @param demoDto 数据对象分享
+     * @return DemoDto 对象数据
+     */
+    @RequestMapping(value = "/queryDemos", method = RequestMethod.POST)
+    List<DemoDto> queryDemos(@RequestBody DemoDto demoDto);
+
+    /**
+     * 查询<p>小区楼</p>总记录数
+     *
+     * @param demoDto 数据对象分享
+     * @return 小区下的小区楼记录数
+     */
+    @RequestMapping(value = "/queryDemosCount", method = RequestMethod.POST)
+    int queryDemosCount(@RequestBody DemoDto demoDto);
+}

+ 25 - 0
java110-db/db/DemoService/create.sql

@@ -0,0 +1,25 @@
+-- 费用主表
+
+create table business_demo(
+  demo_id varchar(30) not null comment '费用ID',
+  b_id VARCHAR(30) NOT NULL COMMENT '业务Id',
+  demo_name VARCHAR(20) NOT  null COMMENT '用例名称',
+  demo_value VARCHAR(20) NOT  null COMMENT '用例值',
+  demo_remark VARCHAR(20) NOT  null COMMENT '用例描述',
+  user_id varchar(30) not null comment '创建用户ID',
+  create_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
+  operate VARCHAR(4) NOT NULL COMMENT '数据状态,添加ADD,修改MOD 删除DEL'
+);
+
+create table demo(
+   demo_id varchar(30) not null comment '费用ID',
+  b_id VARCHAR(30) NOT NULL COMMENT '业务Id',
+  demo_name VARCHAR(20) NOT  null COMMENT '用例名称',
+  demo_value VARCHAR(20) NOT  null COMMENT '用例值',
+  demo_remark VARCHAR(20) NOT  null COMMENT '用例描述',
+  user_id varchar(30) not null comment '创建用户ID',
+  create_time TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
+  status_cd VARCHAR(2) NOT NULL DEFAULT '0' COMMENT '数据状态,详细参考c_status表,S 保存,0, 在用 1失效'
+);
+
+

+ 165 - 0
java110-db/src/main/resources/mapper/demo/DemoServiceDaoImplMapper.xml

@@ -0,0 +1,165 @@
+<?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="demoServiceDaoImpl">
+
+    <!-- 保存demo信息 add by wuxw 2018-07-03 -->
+       <insert id="saveBusinessDemoInfo" parameterType="Map">
+           insert into business_demo(
+demo_remark,demo_name,demo_value,operate,demo_id,b_id,user_id
+) values (
+#{demoRemark},#{demoName},#{demoValue},#{operate},#{demoId},#{bId},#{userId}
+)
+       </insert>
+
+
+       <!-- 查询demo信息(Business) add by wuxw 2018-07-03 -->
+       <select id="getBusinessDemoInfo" parameterType="Map" resultType="Map">
+           select  t.demo_remark,t.demo_remark demoRemark,t.demo_name,t.demo_name demoName,t.demo_value,t.demo_value demoValue,t.operate,t.demo_id,t.demo_id demoId,t.b_id,t.b_id bId,t.user_id,t.user_id userId 
+from business_demo t 
+where 1 =1 
+<if test="demoRemark !=null and demoRemark != ''">
+   and t.demo_remark= #{demoRemark}
+</if> 
+<if test="demoName !=null and demoName != ''">
+   and t.demo_name= #{demoName}
+</if> 
+<if test="demoValue !=null and demoValue != ''">
+   and t.demo_value= #{demoValue}
+</if> 
+<if test="operate !=null and operate != ''">
+   and t.operate= #{operate}
+</if> 
+<if test="demoId !=null and demoId != ''">
+   and t.demo_id= #{demoId}
+</if> 
+<if test="bId !=null and bId != ''">
+   and t.b_id= #{bId}
+</if> 
+<if test="userId !=null and userId != ''">
+   and t.user_id= #{userId}
+</if> 
+
+       </select>
+
+
+
+
+
+    <!-- 保存demo信息至 instance表中 add by wuxw 2018-07-03 -->
+    <insert id="saveDemoInfoInstance" parameterType="Map">
+        insert into demo(
+demo_remark,demo_name,demo_value,demo_id,b_id,user_id
+) select t.demo_remark,t.demo_name,t.demo_value,t.demo_id,t.b_id,t.user_id from business_demo t where 1=1
+<if test="demoRemark !=null and demoRemark != ''">
+   and t.demo_remark= #{demoRemark}
+</if> 
+<if test="demoName !=null and demoName != ''">
+   and t.demo_name= #{demoName}
+</if> 
+<if test="demoValue !=null and demoValue != ''">
+   and t.demo_value= #{demoValue}
+</if> 
+   and t.operate= 'ADD'
+<if test="demoId !=null and demoId != ''">
+   and t.demo_id= #{demoId}
+</if> 
+<if test="bId !=null and bId != ''">
+   and t.b_id= #{bId}
+</if> 
+<if test="userId !=null and userId != ''">
+   and t.user_id= #{userId}
+</if> 
+
+    </insert>
+
+
+
+    <!-- 查询demo信息 add by wuxw 2018-07-03 -->
+    <select id="getDemoInfo" parameterType="Map" resultType="Map">
+        select  t.demo_remark,t.demo_remark demoRemark,t.demo_name,t.demo_name demoName,t.demo_value,t.demo_value demoValue,t.demo_id,t.demo_id demoId,t.b_id,t.b_id bId,t.user_id,t.user_id userId 
+from demo t 
+where 1 =1 
+<if test="demoRemark !=null and demoRemark != ''">
+   and t.demo_remark= #{demoRemark}
+</if> 
+<if test="demoName !=null and demoName != ''">
+   and t.demo_name= #{demoName}
+</if> 
+<if test="demoValue !=null and demoValue != ''">
+   and t.demo_value= #{demoValue}
+</if> 
+<if test="demoId !=null and demoId != ''">
+   and t.demo_id= #{demoId}
+</if> 
+<if test="bId !=null and bId != ''">
+   and t.b_id= #{bId}
+</if> 
+<if test="userId !=null and userId != ''">
+   and t.user_id= #{userId}
+</if> 
+<if test="page != -1 and page != null ">
+   limit #{page}, #{row}
+</if> 
+
+    </select>
+
+
+
+
+    <!-- 修改demo信息 add by wuxw 2018-07-03 -->
+    <update id="updateDemoInfoInstance" parameterType="Map">
+        update  demo t set t.status_cd = #{statusCd}
+<if test="newBId != null and newBId != ''">
+,t.b_id = #{newBId}
+</if> 
+<if test="demoRemark !=null and demoRemark != ''">
+, t.demo_remark= #{demoRemark}
+</if> 
+<if test="demoName !=null and demoName != ''">
+, t.demo_name= #{demoName}
+</if> 
+<if test="demoValue !=null and demoValue != ''">
+, t.demo_value= #{demoValue}
+</if> 
+<if test="userId !=null and userId != ''">
+, t.user_id= #{userId}
+</if> 
+ where 1=1 <if test="demoId !=null and demoId != ''">
+and t.demo_id= #{demoId}
+</if> 
+<if test="bId !=null and bId != ''">
+and t.b_id= #{bId}
+</if> 
+
+    </update>
+
+    <!-- 查询demo数量 add by wuxw 2018-07-03 -->
+     <select id="queryDemosCount" parameterType="Map" resultType="Map">
+        select  count(1) count 
+from demo t 
+where 1 =1 
+<if test="demoRemark !=null and demoRemark != ''">
+   and t.demo_remark= #{demoRemark}
+</if> 
+<if test="demoName !=null and demoName != ''">
+   and t.demo_name= #{demoName}
+</if> 
+<if test="demoValue !=null and demoValue != ''">
+   and t.demo_value= #{demoValue}
+</if> 
+<if test="demoId !=null and demoId != ''">
+   and t.demo_id= #{demoId}
+</if> 
+<if test="bId !=null and bId != ''">
+   and t.b_id= #{bId}
+</if> 
+<if test="userId !=null and userId != ''">
+   and t.user_id= #{userId}
+</if> 
+
+
+     </select>
+
+</mapper>