Przeglądaj źródła

改造 listener to cmd finish

java110 3 lat temu
rodzic
commit
0ee9e50d0e
17 zmienionych plików z 681 dodań i 753 usunięć
  1. 1 2
      service-api/src/main/java/com/java110/api/bmo/machineTranslate/impl/ApplicationKeyMachineTranslateBMOImpl.java
  2. 1 2
      service-api/src/main/java/com/java110/api/bmo/machineTranslate/impl/OwnerMachineTranslateBMOImpl.java
  3. 6 7
      service-api/src/main/java/com/java110/api/bmo/machineTranslate/impl/StaffMachineTranslateBMOImpl.java
  4. 1 2
      service-api/src/main/java/com/java110/api/bmo/machineTranslate/impl/VisitMachineTranslateBMOImpl.java
  5. 0 93
      service-api/src/main/java/com/java110/api/listener/CheckLoginServiceListener.java
  6. 1 2
      service-api/src/main/java/com/java110/api/listener/system/CmdListener.java
  7. 1 2
      service-api/src/main/java/com/java110/api/listener/system/TransferListener.java
  8. 0 185
      service-api/src/main/java/com/java110/api/listener/fee/PayFeePreTempCarInoutListener.java
  9. 0 115
      service-api/src/main/java/com/java110/api/listener/owner/UploadOwnerPhotoListener.java
  10. 13 52
      service-api/src/main/java/com/java110/api/listener/file/GetFileByObjIdListener.java
  11. 13 39
      service-api/src/main/java/com/java110/api/listener/file/GetFileListener.java
  12. 13 42
      service-api/src/main/java/com/java110/api/listener/file/SaveFileListener.java
  13. 216 0
      service-fee/src/main/java/com/java110/fee/cmd/fee/PayFeePreTempCarInoutCmd.java
  14. 173 132
      service-api/src/main/java/com/java110/api/listener/fee/PayOweFeeListener.java
  15. 53 78
      service-api/src/main/java/com/java110/api/listener/fee/RentingPayFeeConfirmListener.java
  16. 146 0
      service-user/src/main/java/com/java110/user/cmd/owner/UploadOwnerPhotoCmd.java
  17. 43 0
      service-user/src/main/java/com/java110/user/cmd/user/CheckServiceLoginCmd.java

+ 1 - 2
service-api/src/main/java/com/java110/api/bmo/machineTranslate/impl/ApplicationKeyMachineTranslateBMOImpl.java

@@ -2,7 +2,6 @@ package com.java110.api.bmo.machineTranslate.impl;
 
 import com.alibaba.fastjson.JSONObject;
 import com.java110.api.bmo.machineTranslate.IApplicationKeyMachineTranslateBMO;
-import com.java110.api.listener.machineTranslate.MachineQueryUserInfoListener;
 import com.java110.intf.common.IApplicationKeyInnerServiceSMO;
 import com.java110.intf.common.IFileInnerServiceSMO;
 import com.java110.intf.common.IFileRelInnerServiceSMO;
@@ -93,7 +92,7 @@ public class ApplicationKeyMachineTranslateBMOImpl implements IApplicationKeyMac
         }
         machineUserResultDto.setRemarks("HC小区管理系统");
         machineUserResultDto.setReserved(applicationKeyDto.getApplicationKeyId());
-        machineUserResultDto.setUserType(MachineQueryUserInfoListener.TYPE_APPLICATION_KEY);
+        machineUserResultDto.setUserType("MachineQueryUserInfoListener.TYPE_APPLICATION_KEY");
 
         //将 设备 待同步 改为同步中
         MachineTranslateDto tmpMtDto = new MachineTranslateDto();

+ 1 - 2
service-api/src/main/java/com/java110/api/bmo/machineTranslate/impl/OwnerMachineTranslateBMOImpl.java

@@ -2,7 +2,6 @@ package com.java110.api.bmo.machineTranslate.impl;
 
 import com.alibaba.fastjson.JSONObject;
 import com.java110.api.bmo.machineTranslate.IOwnerMachineTranslateBMO;
-import com.java110.api.listener.machineTranslate.MachineQueryUserInfoListener;
 import com.java110.intf.community.ICommunityInnerServiceSMO;
 import com.java110.intf.common.IFileInnerServiceSMO;
 import com.java110.intf.common.IFileRelInnerServiceSMO;
@@ -93,7 +92,7 @@ public class OwnerMachineTranslateBMOImpl implements IOwnerMachineTranslateBMO {
         }
         machineUserResultDto.setRemarks("HC小区管理系统");
         machineUserResultDto.setReserved(ownerDto.getMemberId());
-        machineUserResultDto.setUserType(MachineQueryUserInfoListener.TYPE_OWNER);
+        machineUserResultDto.setUserType("MachineQueryUserInfoListener.TYPE_OWNER");
 
         //查询业主是否有欠费
 

+ 6 - 7
service-api/src/main/java/com/java110/api/bmo/machineTranslate/impl/StaffMachineTranslateBMOImpl.java

@@ -2,17 +2,16 @@ package com.java110.api.bmo.machineTranslate.impl;
 
 import com.alibaba.fastjson.JSONObject;
 import com.java110.api.bmo.machineTranslate.IStaffMachineTranslateBMO;
-import com.java110.api.listener.machineTranslate.MachineQueryUserInfoListener;
-import com.java110.intf.common.IFileInnerServiceSMO;
-import com.java110.intf.common.IFileRelInnerServiceSMO;
-import com.java110.intf.common.IMachineTranslateInnerServiceSMO;
-import com.java110.intf.community.ICommunityInnerServiceSMO;
-import com.java110.intf.user.IUserInnerServiceSMO;
 import com.java110.dto.file.FileDto;
 import com.java110.dto.file.FileRelDto;
 import com.java110.dto.machine.MachineTranslateDto;
 import com.java110.dto.machine.MachineUserResultDto;
 import com.java110.dto.user.UserDto;
+import com.java110.intf.common.IFileInnerServiceSMO;
+import com.java110.intf.common.IFileRelInnerServiceSMO;
+import com.java110.intf.common.IMachineTranslateInnerServiceSMO;
+import com.java110.intf.community.ICommunityInnerServiceSMO;
+import com.java110.intf.user.IUserInnerServiceSMO;
 import com.java110.utils.util.DateUtil;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
@@ -95,7 +94,7 @@ public class StaffMachineTranslateBMOImpl implements IStaffMachineTranslateBMO {
         }
         machineUserResultDto.setRemarks("HC小区管理系统");
         machineUserResultDto.setReserved(userDto.getUserId());
-        machineUserResultDto.setUserType(MachineQueryUserInfoListener.TYPE_STAFF);
+        machineUserResultDto.setUserType("MachineQueryUserInfoListener.TYPE_STAFF");
 
         //将 设备 待同步 改为同步中
         MachineTranslateDto tmpMtDto = new MachineTranslateDto();

+ 1 - 2
service-api/src/main/java/com/java110/api/bmo/machineTranslate/impl/VisitMachineTranslateBMOImpl.java

@@ -2,7 +2,6 @@ package com.java110.api.bmo.machineTranslate.impl;
 
 import com.alibaba.fastjson.JSONObject;
 import com.java110.api.bmo.machineTranslate.IVisitMachineTranslateBMO;
-import com.java110.api.listener.machineTranslate.MachineQueryUserInfoListener;
 import com.java110.intf.community.ICommunityInnerServiceSMO;
 import com.java110.intf.common.IFileInnerServiceSMO;
 import com.java110.intf.common.IFileRelInnerServiceSMO;
@@ -93,7 +92,7 @@ public class VisitMachineTranslateBMOImpl implements IVisitMachineTranslateBMO {
         }
         machineUserResultDto.setRemarks("HC小区管理系统");
         machineUserResultDto.setReserved(visitDto.getvId());
-        machineUserResultDto.setUserType(MachineQueryUserInfoListener.TYPE_VISIT);
+        machineUserResultDto.setUserType("MachineQueryUserInfoListener.TYPE_VISIT");
 
         //将 设备 待同步 改为同步中
         MachineTranslateDto tmpMtDto = new MachineTranslateDto();

+ 0 - 93
service-api/src/main/java/com/java110/api/listener/CheckLoginServiceListener.java

@@ -1,93 +0,0 @@
-package com.java110.api.listener;
-
-import com.alibaba.fastjson.JSONObject;
-import com.java110.utils.constant.ServiceCodeConstant;
-import com.java110.utils.util.Assert;
-import com.java110.core.annotation.Java110Listener;
-import com.java110.core.context.DataFlowContext;
-import com.java110.core.factory.AuthenticationFactory;
-import com.java110.entity.center.AppService;
-import com.java110.core.event.service.api.ServiceDataFlowEvent;
-import org.slf4j.Logger;
-import com.java110.core.log.LoggerFactory;
-import org.springframework.http.*;
-
-import javax.naming.AuthenticationException;
-import java.util.Map;
-
-/**
- * 用户注册 侦听
- * Created by wuxw on 2018/5/18.
- */
-@Java110Listener("checkLoginServiceListener")
-public class CheckLoginServiceListener extends AbstractServiceApiDataFlowListener{
-
-    private final static Logger logger = LoggerFactory.getLogger(CheckLoginServiceListener.class);
-
-
-
-    @Override
-    public String getServiceCode() {
-        return ServiceCodeConstant.SERVICE_CODE_CHECK_SERVICE_LOGIN;
-    }
-
-    @Override
-    public HttpMethod getHttpMethod() {
-        return HttpMethod.POST;
-    }
-
-
-    @Override
-    public int getOrder() {
-        return 0;
-    }
-
-
-    /**
-     * 校验用户登录:
-     *
-     * @param event
-     */
-    @Override
-    public void soService(ServiceDataFlowEvent event) {
-        //获取数据上下文对象
-        DataFlowContext dataFlowContext = event.getDataFlowContext();
-        AppService service = event.getAppService();
-        String paramIn = dataFlowContext.getReqData();
-        Assert.isJsonObject(paramIn,"用户注册请求参数有误,不是有效的json格式 "+paramIn);
-        Assert.jsonObjectHaveKey(paramIn,"token","请求报文中未包含token 节点请检查");
-        JSONObject paramObj = JSONObject.parseObject(paramIn);
-        ResponseEntity responseEntity= null;
-        try {
-            Map<String, String> claims = AuthenticationFactory.verifyToken(paramObj.getString("token"));
-            if(claims == null || claims.isEmpty()){
-                throw new AuthenticationException("认证失败,从token中解析到信息为空");
-            }
-            JSONObject resultInfo = new JSONObject();
-            resultInfo.put("userId",claims.get("userId"));
-            responseEntity = new ResponseEntity<String>(resultInfo.toJSONString(), HttpStatus.OK);
-        } catch (Exception e) {
-            //Invalid signature/claims
-            responseEntity = new ResponseEntity<String>("认证失败,不是有效的token", HttpStatus.UNAUTHORIZED);
-        }
-        dataFlowContext.setResponseEntity(responseEntity);
-    }
-
-    /**
-     * 对请求报文处理
-     * @param paramIn
-     * @return
-     */
-    private JSONObject refreshParamIn(String paramIn){
-        JSONObject paramObj = JSONObject.parseObject(paramIn);
-        paramObj.put("userId","-1");
-        paramObj.put("levelCd","0");
-
-        return paramObj;
-    }
-
-
-
-
-
-}

+ 1 - 2
service-api/src/main/java/com/java110/api/listener/system/CmdListener.java

@@ -1,8 +1,7 @@
-package com.java110.api.listener.system;
+package com.java110.api.listener;
 
 import com.alibaba.fastjson.JSONObject;
 import com.aliyuncs.utils.StringUtils;
-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;

+ 1 - 2
service-api/src/main/java/com/java110/api/listener/system/TransferListener.java

@@ -1,8 +1,7 @@
-package com.java110.api.listener.system;
+package com.java110.api.listener;
 
 import com.alibaba.fastjson.JSONObject;
 import com.aliyuncs.utils.StringUtils;
-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;

+ 0 - 185
service-api/src/main/java/com/java110/api/listener/fee/PayFeePreTempCarInoutListener.java

@@ -1,185 +0,0 @@
-package com.java110.api.listener.fee;
-
-import com.alibaba.fastjson.JSONArray;
-import com.alibaba.fastjson.JSONObject;
-import com.java110.api.bmo.fee.IFeeBMO;
-import com.java110.api.listener.AbstractServiceApiDataFlowListener;
-import com.java110.core.annotation.Java110Listener;
-import com.java110.core.context.DataFlowContext;
-import com.java110.intf.fee.IFeeConfigInnerServiceSMO;
-import com.java110.intf.fee.IFeeInnerServiceSMO;
-import com.java110.intf.common.ICarInoutInnerServiceSMO;
-import com.java110.intf.community.IRoomInnerServiceSMO;
-import com.java110.intf.store.ISmallWeChatInnerServiceSMO;
-import com.java110.dto.smallWeChat.SmallWeChatDto;
-import com.java110.entity.center.AppService;
-import com.java110.entity.order.Orders;
-import com.java110.core.event.service.api.ServiceDataFlowEvent;
-import com.java110.utils.constant.CommonConstant;
-import com.java110.utils.constant.ServiceCodeConstant;
-import com.java110.utils.util.Assert;
-import org.slf4j.Logger;
-import com.java110.core.log.LoggerFactory;
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.http.HttpHeaders;
-import org.springframework.http.HttpMethod;
-import org.springframework.http.HttpStatus;
-import org.springframework.http.ResponseEntity;
-
-import java.util.List;
-import java.util.Map;
-
-/**
- * @ClassName PayFeeListener
- * @Description TODO 预交费(临时停车费)侦听
- * @Author wuxw
- * @Date 2019/6/3 13:46
- * @Version 1.0
- * add by wuxw 2019/6/3
- **/
-@Java110Listener("payFeePreTempCarInoutListener")
-public class PayFeePreTempCarInoutListener extends AbstractServiceApiDataFlowListener {
-
-    private static Logger logger = LoggerFactory.getLogger(PayFeePreTempCarInoutListener.class);
-
-    @Autowired
-    private IFeeBMO feeBMOImpl;
-
-    @Autowired
-    private IFeeInnerServiceSMO feeInnerServiceSMOImpl;
-
-    @Autowired
-    private IRoomInnerServiceSMO roomInnerServiceSMOImpl;
-
-    @Autowired
-    private ICarInoutInnerServiceSMO carInoutInnerServiceSMOImpl;
-
-    @Autowired
-    private IFeeConfigInnerServiceSMO feeConfigInnerServiceSMOImpl;
-    @Autowired
-    private ISmallWeChatInnerServiceSMO smallWeChatInnerServiceSMOImpl;
-
-
-    @Override
-    public String getServiceCode() {
-        return ServiceCodeConstant.SERVICE_CODE_PAY_FEE_PRE_TEMP_CAR_INOUT;
-    }
-
-    @Override
-    public HttpMethod getHttpMethod() {
-        return HttpMethod.POST;
-    }
-
-    @Override
-    public void soService(ServiceDataFlowEvent event) {
-
-        logger.debug("ServiceDataFlowEvent : {}", event);
-
-        DataFlowContext dataFlowContext = event.getDataFlowContext();
-        AppService service = event.getAppService();
-
-        String paramIn = dataFlowContext.getReqData();
-
-        //校验数据
-        validate(paramIn);
-        JSONObject paramObj = JSONObject.parseObject(paramIn);
-
-        HttpHeaders header = new HttpHeaders();
-        dataFlowContext.getRequestCurrentHeaders().put(CommonConstant.HTTP_ORDER_TYPE_CD, "D");
-        JSONArray businesses = new JSONArray();
-        paramObj.put("cycles", 0);
-        //添加单元信息
-        businesses.add(feeBMOImpl.addFeeTempDetail(paramObj, dataFlowContext));
-        businesses.add(feeBMOImpl.modifyTempFee(paramObj, dataFlowContext));
-        businesses.add(feeBMOImpl.modifyTempCarInout(paramObj, dataFlowContext));
-
-        dataFlowContext.getRequestCurrentHeaders().put(CommonConstant.ORDER_PROCESS,Orders.ORDER_PROCESS_ORDER_PRE_SUBMIT);
-        ResponseEntity<String> responseEntity = feeBMOImpl.callService(dataFlowContext, service.getServiceCode(), businesses);
-        if (responseEntity.getStatusCode() != HttpStatus.OK) {
-            dataFlowContext.setResponseEntity(responseEntity);
-            return;
-        }
-
-        JSONObject paramOut = JSONObject.parseObject(responseEntity.getBody());
-        paramOut.put("receivableAmount", paramObj.getString("receivableAmount"));
-        SmallWeChatDto smallWeChatDto = new SmallWeChatDto();
-        smallWeChatDto.setObjId((String) paramObj.get("communityId"));
-        smallWeChatDto.setAppId((String) paramObj.get("appId"));
-        List<SmallWeChatDto> smallWeChatDtos = smallWeChatInnerServiceSMOImpl.querySmallWeChats(smallWeChatDto);
-        if(smallWeChatDtos.size() <= 0){
-            throw new IllegalArgumentException("支付失败,小区未配置小程序信息");
-        }
-        //指定支付小区
-        if("1000".equals(smallWeChatDtos.get(0).getObjType())){
-            paramOut.put("payAppId",smallWeChatDtos.get(0).getAppId());
-            paramOut.put("payMchId",smallWeChatDtos.get(0).getMchId());
-        }
-
-        responseEntity = new ResponseEntity<>(paramOut.toJSONString(), HttpStatus.OK);
-        dataFlowContext.setResponseEntity(responseEntity);
-    }
-
-
-
-    /**
-     * 刷入order信息
-     *
-     * @param orders  订单信息
-     * @param headers 头部信息
-     */
-    protected void freshOrderProtocol(JSONObject orders, Map<String, String> headers) {
-        feeBMOImpl.freshOrderProtocol(orders, headers);
-        orders.put("orderProcess", Orders.ORDER_PROCESS_ORDER_PRE_SUBMIT);
-
-    }
-
-
-    /**
-     * 数据校验
-     *
-     * @param paramIn "communityId": "7020181217000001",
-     *                "memberId": "3456789",
-     *                "memberTypeCd": "390001200001"
-     */
-    private void validate(String paramIn) {
-        Assert.jsonObjectHaveKey(paramIn, "communityId", "请求报文中未包含communityId节点");
-        Assert.jsonObjectHaveKey(paramIn, "receivedAmount", "请求报文中未包含receivedAmount节点");
-        Assert.jsonObjectHaveKey(paramIn, "feeId", "请求报文中未包含feeId节点");
-
-        JSONObject paramInObj = JSONObject.parseObject(paramIn);
-        Assert.hasLength(paramInObj.getString("communityId"), "小区ID不能为空");
-        Assert.hasLength(paramInObj.getString("receivedAmount"), "实收金额不能为空");
-        Assert.hasLength(paramInObj.getString("feeId"), "费用ID不能为空");
-
-    }
-
-    @Override
-    public int getOrder() {
-        return DEFAULT_ORDER;
-    }
-
-
-    public IFeeInnerServiceSMO getFeeInnerServiceSMOImpl() {
-        return feeInnerServiceSMOImpl;
-    }
-
-    public void setFeeInnerServiceSMOImpl(IFeeInnerServiceSMO feeInnerServiceSMOImpl) {
-        this.feeInnerServiceSMOImpl = feeInnerServiceSMOImpl;
-    }
-
-    public IFeeConfigInnerServiceSMO getFeeConfigInnerServiceSMOImpl() {
-        return feeConfigInnerServiceSMOImpl;
-    }
-
-    public void setFeeConfigInnerServiceSMOImpl(IFeeConfigInnerServiceSMO feeConfigInnerServiceSMOImpl) {
-        this.feeConfigInnerServiceSMOImpl = feeConfigInnerServiceSMOImpl;
-    }
-
-    public IRoomInnerServiceSMO getRoomInnerServiceSMOImpl() {
-        return roomInnerServiceSMOImpl;
-    }
-
-    public void setRoomInnerServiceSMOImpl(IRoomInnerServiceSMO roomInnerServiceSMOImpl) {
-        this.roomInnerServiceSMOImpl = roomInnerServiceSMOImpl;
-    }
-}

+ 0 - 115
service-api/src/main/java/com/java110/api/listener/owner/UploadOwnerPhotoListener.java

@@ -1,115 +0,0 @@
-package com.java110.api.listener.owner;
-
-import com.alibaba.fastjson.JSONObject;
-import com.java110.api.bmo.owner.IOwnerBMO;
-import com.java110.api.listener.AbstractServiceApiPlusListener;
-import com.java110.core.annotation.Java110Listener;
-import com.java110.core.context.DataFlowContext;
-import com.java110.core.factory.GenerateCodeFactory;
-import com.java110.intf.common.IFileInnerServiceSMO;
-import com.java110.intf.common.IFileRelInnerServiceSMO;
-import com.java110.intf.user.IOwnerInnerServiceSMO;
-import com.java110.dto.file.FileDto;
-import com.java110.core.event.service.api.ServiceDataFlowEvent;
-import com.java110.utils.constant.ServiceCodeConstant;
-import com.java110.utils.util.Assert;
-import org.apache.commons.lang3.StringUtils;
-import org.slf4j.Logger;
-import com.java110.core.log.LoggerFactory;
-import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.http.HttpMethod;
-
-/**
- * @ClassName EditOwnerListener
- * @Description TODO 上传业主照片
- * @Author wuxw
- * @Date 2019/4/28 15:19
- * @Version 1.0
- * add by wuxw 2019/4/28
- **/
-@Java110Listener("uploadOwnerPhotoListener")
-public class UploadOwnerPhotoListener extends AbstractServiceApiPlusListener {
-
-    private static Logger logger = LoggerFactory.getLogger(UploadOwnerPhotoListener.class);
-
-    @Autowired
-    private IOwnerBMO ownerBMOImpl;
-
-    @Autowired
-    private IFileInnerServiceSMO fileInnerServiceSMOImpl;
-
-    @Autowired
-    private IOwnerInnerServiceSMO ownerInnerServiceSMOImpl;
-
-    @Autowired
-    private IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl;
-
-    @Override
-    public String getServiceCode() {
-        return ServiceCodeConstant.SERVICE_CODE_UPLOAD_OWNER_PHOTO;
-    }
-
-    @Override
-    public HttpMethod getHttpMethod() {
-        return HttpMethod.POST;
-    }
-
-    @Override
-    protected void validate(ServiceDataFlowEvent event, JSONObject reqJson) {
-        Assert.jsonObjectHaveKey(reqJson, "memberId", "请求报文中未包含ownerId");
-        Assert.jsonObjectHaveKey(reqJson, "photo", "请求报文中未包含photo");
-        Assert.jsonObjectHaveKey(reqJson, "communityId", "请求报文中未包含communityId");
-    }
-
-    @Override
-    protected void doSoService(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson) {
-
-
-        if (reqJson.containsKey("photo") && !StringUtils.isEmpty(reqJson.getString("photo"))) {
-            FileDto fileDto = new FileDto();
-            fileDto.setFileId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_file_id));
-            fileDto.setFileName(fileDto.getFileId());
-            fileDto.setContext(reqJson.getString("photo"));
-            fileDto.setSuffix("jpeg");
-            fileDto.setCommunityId(reqJson.getString("communityId"));
-            String fileName = fileInnerServiceSMOImpl.saveFile(fileDto);
-            reqJson.put("ownerPhotoId", fileDto.getFileId());
-            reqJson.put("fileSaveName", fileName);
-
-            ownerBMOImpl.editOwnerPhoto(reqJson, context);
-
-        }
-        //添加小区楼
-        ownerBMOImpl.editOwner(reqJson, context);
-
-    }
-
-    @Override
-    public int getOrder() {
-        return DEFAULT_ORDER;
-    }
-
-    public IFileInnerServiceSMO getFileInnerServiceSMOImpl() {
-        return fileInnerServiceSMOImpl;
-    }
-
-    public void setFileInnerServiceSMOImpl(IFileInnerServiceSMO fileInnerServiceSMOImpl) {
-        this.fileInnerServiceSMOImpl = fileInnerServiceSMOImpl;
-    }
-
-    public IFileRelInnerServiceSMO getFileRelInnerServiceSMOImpl() {
-        return fileRelInnerServiceSMOImpl;
-    }
-
-    public void setFileRelInnerServiceSMOImpl(IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl) {
-        this.fileRelInnerServiceSMOImpl = fileRelInnerServiceSMOImpl;
-    }
-
-    public IOwnerInnerServiceSMO getOwnerInnerServiceSMOImpl() {
-        return ownerInnerServiceSMOImpl;
-    }
-
-    public void setOwnerInnerServiceSMOImpl(IOwnerInnerServiceSMO ownerInnerServiceSMOImpl) {
-        this.ownerInnerServiceSMOImpl = ownerInnerServiceSMOImpl;
-    }
-}

+ 13 - 52
service-api/src/main/java/com/java110/api/listener/file/GetFileByObjIdListener.java

@@ -1,31 +1,27 @@
-package com.java110.api.listener.file;
+package com.java110.common.cmd.file;
 
 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.intf.common.IFileInnerServiceSMO;
-import com.java110.intf.common.IFileRelInnerServiceSMO;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
 import com.java110.dto.file.FileDto;
 import com.java110.dto.file.FileRelDto;
-import com.java110.core.event.service.api.ServiceDataFlowEvent;
-import com.java110.utils.constant.ServiceCodeServiceConstant;
+import com.java110.intf.common.IFileInnerServiceSMO;
+import com.java110.intf.common.IFileRelInnerServiceSMO;
+import com.java110.utils.exception.CmdException;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.BeanConvertUtil;
 import com.java110.vo.api.file.ApiFileVo;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.http.HttpMethod;
 import org.springframework.http.HttpStatus;
 import org.springframework.http.ResponseEntity;
 
+import java.text.ParseException;
 import java.util.List;
 
-
-/**
- * 查询小区侦听类
- */
-@Java110Listener("getFileByObjIdListener")
-public class GetFileByObjIdListener extends AbstractServiceApiListener {
+@Java110Cmd(serviceCode = "file.getFileByObjId")
+public class GetFileByObjIdCmd extends Cmd {
 
     @Autowired
     private IFileInnerServiceSMO fileInnerServiceSMOImpl;
@@ -34,24 +30,7 @@ public class GetFileByObjIdListener extends AbstractServiceApiListener {
     private IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl;
 
     @Override
-    public String getServiceCode() {
-        return ServiceCodeServiceConstant.GET_FILE_BY_OBJ_ID;
-    }
-
-    @Override
-    public HttpMethod getHttpMethod() {
-        return HttpMethod.GET;
-    }
-
-
-    @Override
-    public int getOrder() {
-        return DEFAULT_ORDER;
-    }
-
-
-    @Override
-    protected void validate(ServiceDataFlowEvent event, JSONObject reqJson) {
+    public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
         Assert.hasKeyAndValue(reqJson,"objId", "未包含文件ID");
         Assert.hasKeyAndValue(reqJson,"fileTypeCd", "未包含文件类型");
         Assert.hasKeyAndValue(reqJson,"communityId", "未包含小区ID");
@@ -59,8 +38,7 @@ public class GetFileByObjIdListener extends AbstractServiceApiListener {
     }
 
     @Override
-    protected void doSoService(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson) {
-
+    public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException {
         FileRelDto fileRelDto = new FileRelDto();
         fileRelDto.setObjId(reqJson.getString("objId"));
         fileRelDto.setRelTypeCd(reqJson.getString("fileTypeCd"));
@@ -80,22 +58,5 @@ public class GetFileByObjIdListener extends AbstractServiceApiListener {
         ResponseEntity<String> responseEntity = new ResponseEntity<String>(JSONObject.toJSONString(fileVo), HttpStatus.OK);
 
         context.setResponseEntity(responseEntity);
-
-    }
-
-    public IFileInnerServiceSMO getFileInnerServiceSMOImpl() {
-        return fileInnerServiceSMOImpl;
-    }
-
-    public void setFileInnerServiceSMOImpl(IFileInnerServiceSMO fileInnerServiceSMOImpl) {
-        this.fileInnerServiceSMOImpl = fileInnerServiceSMOImpl;
-    }
-
-    public IFileRelInnerServiceSMO getFileRelInnerServiceSMOImpl() {
-        return fileRelInnerServiceSMOImpl;
-    }
-
-    public void setFileRelInnerServiceSMOImpl(IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl) {
-        this.fileRelInnerServiceSMOImpl = fileRelInnerServiceSMOImpl;
     }
 }

+ 13 - 39
service-api/src/main/java/com/java110/api/listener/file/GetFileListener.java

@@ -1,66 +1,41 @@
-package com.java110.api.listener.file;
+package com.java110.common.cmd.file;
 
 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.intf.common.IFileInnerServiceSMO;
-import com.java110.intf.common.IFileRelInnerServiceSMO;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
 import com.java110.dto.file.FileDto;
 import com.java110.dto.file.FileRelDto;
-import com.java110.core.event.service.api.ServiceDataFlowEvent;
-import com.java110.utils.constant.ServiceCodeServiceConstant;
+import com.java110.intf.common.IFileInnerServiceSMO;
+import com.java110.intf.common.IFileRelInnerServiceSMO;
+import com.java110.utils.exception.CmdException;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.BeanConvertUtil;
 import com.java110.vo.api.file.ApiFileVo;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.http.HttpMethod;
 import org.springframework.http.HttpStatus;
 import org.springframework.http.ResponseEntity;
 
+import java.text.ParseException;
 import java.util.List;
 
-
-/**
- * 查询小区侦听类
- */
-@Java110Listener("getFileListener")
-public class GetFileListener extends AbstractServiceApiListener {
-
+@Java110Cmd(serviceCode = "file.getFile")
+public class GetFileCmd extends Cmd {
     @Autowired
     private IFileInnerServiceSMO fileInnerServiceSMOImpl;
 
     @Autowired
     private IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl;
-
     @Override
-    public String getServiceCode() {
-        return ServiceCodeServiceConstant.GET_FILE;
-    }
-
-    @Override
-    public HttpMethod getHttpMethod() {
-        return HttpMethod.GET;
-    }
-
-
-    @Override
-    public int getOrder() {
-        return DEFAULT_ORDER;
-    }
-
-
-    @Override
-    protected void validate(ServiceDataFlowEvent event, JSONObject reqJson) {
+    public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
         Assert.hasKeyAndValue(reqJson, "fileId", "未包含文件ID");
         Assert.hasKeyAndValue(reqJson, "communityId", "未包含小区ID");
         //super.validatePageInfo(reqJson);
     }
 
     @Override
-    protected void doSoService(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson) {
-
-
+    public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException {
         FileRelDto fileRelDto = new FileRelDto();
         fileRelDto.setFileRealName(reqJson.getString("fileId"));
         List<FileRelDto> fileRelDtos = fileRelInnerServiceSMOImpl.queryFileRels(fileRelDto);
@@ -80,6 +55,5 @@ public class GetFileListener extends AbstractServiceApiListener {
         ResponseEntity<String> responseEntity = new ResponseEntity<String>(JSONObject.toJSONString(fileVo), HttpStatus.OK);
 
         context.setResponseEntity(responseEntity);
-
     }
 }

+ 13 - 42
service-api/src/main/java/com/java110/api/listener/file/SaveFileListener.java

@@ -1,45 +1,39 @@
-package com.java110.api.listener.file;
+package com.java110.common.cmd.file;
 
 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.annotation.Java110Cmd;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
 import com.java110.core.factory.GenerateCodeFactory;
-import com.java110.intf.common.IFileInnerServiceSMO;
 import com.java110.dto.file.FileDto;
-import com.java110.core.event.service.api.ServiceDataFlowEvent;
-import com.java110.utils.constant.ServiceCodeServiceConstant;
+import com.java110.intf.common.IFileInnerServiceSMO;
+import com.java110.utils.exception.CmdException;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.BeanConvertUtil;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.http.HttpMethod;
 import org.springframework.http.HttpStatus;
 import org.springframework.http.ResponseEntity;
 
-/**
- * 保存小区侦听
- * add by wuxw 2019-06-30
- */
-@Java110Listener("saveFileListener")
-public class SaveFileListener extends AbstractServiceApiListener {
+import java.text.ParseException;
+
+@Java110Cmd(serviceCode = "file.saveFile")
+public class SaveFileCmd extends Cmd {
 
     @Autowired
     private IFileInnerServiceSMO fileInnerServiceSMOImpl;
 
     @Override
-    protected void validate(ServiceDataFlowEvent event, JSONObject reqJson) {
-        //Assert.hasKeyAndValue(reqJson, "xxx", "xxx");
+    public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
 
         Assert.hasKeyAndValue(reqJson, "fileName", "必填,请填写文件名称");
         Assert.hasKeyAndValue(reqJson, "communityId", "必填,请填写小区ID");
         Assert.hasKeyAndValue(reqJson, "context", "必填,请填写文件内容");
         Assert.hasKeyAndValue(reqJson, "suffix", "必填,请填写文件扩展");
-
     }
 
     @Override
-    protected void doSoService(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson) {
-
+    public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException {
         FileDto fileDto = BeanConvertUtil.covertBean(reqJson, FileDto.class);
 
         fileDto.setFileId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_file_id));
@@ -53,27 +47,4 @@ public class SaveFileListener extends AbstractServiceApiListener {
 
         context.setResponseEntity(responseEntity);
     }
-
-    @Override
-    public String getServiceCode() {
-        return ServiceCodeServiceConstant.SAVE_FILE;
-    }
-
-    @Override
-    public HttpMethod getHttpMethod() {
-        return HttpMethod.POST;
-    }
-
-    @Override
-    public int getOrder() {
-        return DEFAULT_ORDER;
-    }
-
-    public IFileInnerServiceSMO getFileInnerServiceSMOImpl() {
-        return fileInnerServiceSMOImpl;
-    }
-
-    public void setFileInnerServiceSMOImpl(IFileInnerServiceSMO fileInnerServiceSMOImpl) {
-        this.fileInnerServiceSMOImpl = fileInnerServiceSMOImpl;
-    }
 }

+ 216 - 0
service-fee/src/main/java/com/java110/fee/cmd/fee/PayFeePreTempCarInoutCmd.java

@@ -0,0 +1,216 @@
+package com.java110.fee.cmd.fee;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.context.DataFlowContext;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
+import com.java110.dto.fee.FeeConfigDto;
+import com.java110.dto.fee.FeeDto;
+import com.java110.dto.machine.CarInoutDto;
+import com.java110.dto.smallWeChat.SmallWeChatDto;
+import com.java110.intf.common.ICarInoutInnerServiceSMO;
+import com.java110.intf.common.ICarInoutV1InnerServiceSMO;
+import com.java110.intf.community.IRoomInnerServiceSMO;
+import com.java110.intf.fee.IFeeConfigInnerServiceSMO;
+import com.java110.intf.fee.IFeeInnerServiceSMO;
+import com.java110.intf.fee.IPayFeeDetailV1InnerServiceSMO;
+import com.java110.intf.fee.IPayFeeV1InnerServiceSMO;
+import com.java110.intf.store.ISmallWeChatInnerServiceSMO;
+import com.java110.po.car.CarInoutPo;
+import com.java110.po.fee.PayFeeDetailPo;
+import com.java110.po.fee.PayFeePo;
+import com.java110.utils.constant.BusinessTypeConstant;
+import com.java110.utils.constant.CommonConstant;
+import com.java110.utils.constant.ResponseConstant;
+import com.java110.utils.exception.CmdException;
+import com.java110.utils.exception.ListenerExecuteException;
+import com.java110.utils.util.Assert;
+import com.java110.utils.util.BeanConvertUtil;
+import com.java110.utils.util.DateUtil;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.HttpStatus;
+import org.springframework.http.ResponseEntity;
+
+import java.math.BigDecimal;
+import java.text.ParseException;
+import java.util.Date;
+import java.util.List;
+import java.util.Map;
+
+@Java110Cmd(serviceCode = "fee.payFeePreTempCarInout")
+public class PayFeePreTempCarInoutCmd extends Cmd {
+
+    @Autowired
+    private IFeeInnerServiceSMO feeInnerServiceSMOImpl;
+
+    @Autowired
+    private IRoomInnerServiceSMO roomInnerServiceSMOImpl;
+
+    @Autowired
+    private ICarInoutInnerServiceSMO carInoutInnerServiceSMOImpl;
+
+    @Autowired
+    private IFeeConfigInnerServiceSMO feeConfigInnerServiceSMOImpl;
+    @Autowired
+    private ISmallWeChatInnerServiceSMO smallWeChatInnerServiceSMOImpl;
+
+
+    @Autowired
+    private IPayFeeV1InnerServiceSMO payFeeV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IPayFeeDetailV1InnerServiceSMO payFeeDetailV1InnerServiceSMOImpl;
+
+    @Autowired
+    private ICarInoutV1InnerServiceSMO carInoutV1InnerServiceSMOImpl;
+
+
+    @Override
+    public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
+        Assert.jsonObjectHaveKey(reqJson, "communityId", "请求报文中未包含communityId节点");
+        Assert.jsonObjectHaveKey(reqJson, "receivedAmount", "请求报文中未包含receivedAmount节点");
+        Assert.jsonObjectHaveKey(reqJson, "feeId", "请求报文中未包含feeId节点");
+
+        Assert.hasLength(reqJson.getString("communityId"), "小区ID不能为空");
+        Assert.hasLength(reqJson.getString("receivedAmount"), "实收金额不能为空");
+        Assert.hasLength(reqJson.getString("feeId"), "费用ID不能为空");
+    }
+
+    @Override
+    public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject paramObj) throws CmdException, ParseException {
+
+        paramObj.put("cycles", 0);
+        //添加单元信息
+        addFeeTempDetail(paramObj, context);
+        modifyTempFee(paramObj, context);
+        modifyTempCarInout(paramObj, context);
+
+
+        SmallWeChatDto smallWeChatDto = new SmallWeChatDto();
+        smallWeChatDto.setObjId((String) paramObj.get("communityId"));
+        smallWeChatDto.setAppId((String) paramObj.get("appId"));
+        List<SmallWeChatDto> smallWeChatDtos = smallWeChatInnerServiceSMOImpl.querySmallWeChats(smallWeChatDto);
+        if (smallWeChatDtos.size() <= 0) {
+            throw new IllegalArgumentException("支付失败,小区未配置小程序信息");
+        }
+        //指定支付小区
+        if ("1000".equals(smallWeChatDtos.get(0).getObjType())) {
+            paramObj.put("payAppId", smallWeChatDtos.get(0).getAppId());
+            paramObj.put("payMchId", smallWeChatDtos.get(0).getMchId());
+        }
+
+        ResponseEntity responseEntity = new ResponseEntity<>(paramObj.toJSONString(), HttpStatus.OK);
+        context.setResponseEntity(responseEntity);
+    }
+
+    public void addFeeTempDetail(JSONObject paramInJson, ICmdDataFlowContext dataFlowContext) {
+
+        JSONObject businessFeeDetail = new JSONObject();
+        businessFeeDetail.putAll(paramInJson);
+        businessFeeDetail.put("detailId", "-1");
+        businessFeeDetail.put("primeRate", paramInJson.getString("primeRate"));
+        if (!businessFeeDetail.containsKey("state")) {
+            businessFeeDetail.put("state", "1400");
+        }
+        //计算 应收金额
+        FeeDto feeDto = new FeeDto();
+        feeDto.setFeeId(paramInJson.getString("feeId"));
+        feeDto.setCommunityId(paramInJson.getString("communityId"));
+        List<FeeDto> feeDtos = feeInnerServiceSMOImpl.queryFees(feeDto);
+        if (feeDtos == null || feeDtos.size() != 1) {
+            throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_ERROR, "查询费用信息失败,未查到数据或查到多条数据");
+        }
+        feeDto = feeDtos.get(0);
+        paramInJson.put("feeInfo", feeDto);
+        FeeConfigDto feeConfigDto = new FeeConfigDto();
+        feeConfigDto.setFeeTypeCd(feeDto.getFeeTypeCd());
+        feeConfigDto.setConfigId(feeDto.getConfigId());
+        feeConfigDto.setCommunityId(feeDto.getCommunityId());
+        List<FeeConfigDto> feeConfigDtos = feeConfigInnerServiceSMOImpl.queryFeeConfigs(feeConfigDto);
+        if (feeConfigDtos == null || feeConfigDtos.size() != 1) {
+            throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_ERROR, "未查到费用配置信息,查询多条数据");
+        }
+        feeConfigDto = feeConfigDtos.get(0);
+        Date nowTime = new Date();
+
+        long diff = nowTime.getTime() - feeDto.getStartTime().getTime();
+        long nd = 1000 * 24 * 60 * 60;// 一天的毫秒数
+        long nh = 1000 * 60 * 60;// 一小时的毫秒数
+        long nm = 1000 * 60;// 一分钟的毫秒数
+        double day = 0;
+        double hour = 0;
+        double min = 0;
+        day = diff / nd;// 计算差多少天
+        hour = diff % nd / nh + day * 24;// 计算差多少小时
+        min = diff % nd % nh / nm + day * 24 * 60;// 计算差多少分钟
+        double money = 0.00;
+        double newHour = hour;
+        if (min > 0) { //一小时超过
+            newHour += 1;
+        }
+        if (newHour <= 2) {
+            money = Double.parseDouble(feeConfigDto.getAdditionalAmount());
+        } else {
+            BigDecimal lastHour = new BigDecimal(newHour - 2);
+            BigDecimal squarePrice = new BigDecimal(Double.parseDouble(feeDto.getSquarePrice()));
+            BigDecimal additionalAmount = new BigDecimal(Double.parseDouble(feeDto.getAdditionalAmount()));
+            money = squarePrice.multiply(lastHour).add(additionalAmount).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue();
+        }
+        double receivableAmount = money;
+        businessFeeDetail.put("receivableAmount", receivableAmount);
+        PayFeeDetailPo payFeeDetailPo = BeanConvertUtil.covertBean(businessFeeDetail, PayFeeDetailPo.class);
+        int flag = payFeeDetailV1InnerServiceSMOImpl.savePayFeeDetailNew(payFeeDetailPo);
+
+        if (flag < 1) {
+            throw new CmdException("保存明细失败");
+        }
+        paramInJson.put("receivableAmount", receivableAmount);
+    }
+
+    /**
+     * 修改费用信息
+     *
+     * @param paramInJson     接口调用放传入入参
+     * @param dataFlowContext 数据上下文
+     * @return 订单服务能够接受的报文
+     */
+    public void modifyTempFee(JSONObject paramInJson, ICmdDataFlowContext dataFlowContext) {
+
+        JSONObject businessFee = new JSONObject();
+        FeeDto feeInfo = (FeeDto) paramInJson.get("feeInfo");
+        Map feeMap = BeanConvertUtil.beanCovertMap(feeInfo);
+        feeMap.put("startTime", DateUtil.getFormatTimeString(feeInfo.getStartTime(), DateUtil.DATE_FORMATE_STRING_A));
+        feeMap.put("endTime", DateUtil.getFormatTimeString(new Date(), DateUtil.DATE_FORMATE_STRING_A));
+        feeMap.put("amount", paramInJson.getString("receivableAmount"));
+        feeMap.put("state", "2009001");
+        businessFee.putAll(feeMap);
+        PayFeePo payFeePo =  BeanConvertUtil.covertBean(businessFee,PayFeePo.class);
+        int flag = payFeeV1InnerServiceSMOImpl.updatePayFee(payFeePo);
+        if (flag < 1) {
+            throw new CmdException("保存失败");
+        }
+    }
+
+
+    public void modifyTempCarInout(JSONObject reqJson, ICmdDataFlowContext context) {
+        FeeDto feeDto = (FeeDto) reqJson.get("feeInfo");
+        CarInoutDto tempCarInoutDto = new CarInoutDto();
+        tempCarInoutDto.setCommunityId(reqJson.getString("communityId"));
+        tempCarInoutDto.setInoutId(feeDto.getPayerObjId());
+        List<CarInoutDto> carInoutDtos = carInoutInnerServiceSMOImpl.queryCarInouts(tempCarInoutDto);
+        Assert.listOnlyOne(carInoutDtos, "根据费用信息反差车辆进场记录未查到 或查到多条");
+        CarInoutDto carInoutDto = carInoutDtos.get(0);
+
+        JSONObject businessCarInout = new JSONObject();
+        businessCarInout.putAll(BeanConvertUtil.beanCovertMap(carInoutDto));
+        businessCarInout.put("state", "100400");
+        //计算 应收金额
+        CarInoutPo carInoutPo = BeanConvertUtil.covertBean(businessCarInout,CarInoutPo.class);
+       int flag = carInoutV1InnerServiceSMOImpl.updateCarInout(carInoutPo);
+        if (flag < 1) {
+            throw new CmdException("保存失败");
+        }
+    }
+}

+ 173 - 132
service-api/src/main/java/com/java110/api/listener/fee/PayOweFeeListener.java

@@ -1,64 +1,52 @@
-package com.java110.api.listener.fee;
+package com.java110.fee.cmd.fee;
 
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
-import com.java110.api.bmo.fee.IFeeBMO;
-import com.java110.api.listener.AbstractServiceApiDataFlowListener;
-import com.java110.core.annotation.Java110Listener;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.annotation.Java110Transactional;
 import com.java110.core.context.DataFlowContext;
-import com.java110.core.event.service.api.ServiceDataFlowEvent;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
 import com.java110.core.factory.GenerateCodeFactory;
+import com.java110.core.log.LoggerFactory;
+import com.java110.core.smo.IComputeFeeSMO;
 import com.java110.dto.app.AppDto;
 import com.java110.dto.fee.FeeAttrDto;
 import com.java110.dto.fee.FeeDetailDto;
+import com.java110.dto.fee.FeeDto;
 import com.java110.dto.feeReceipt.FeeReceiptDetailDto;
+import com.java110.dto.owner.OwnerDto;
 import com.java110.dto.repair.RepairDto;
 import com.java110.dto.repair.RepairUserDto;
-import com.java110.entity.center.AppService;
-import com.java110.intf.community.IParkingSpaceInnerServiceSMO;
-import com.java110.intf.community.IRepairInnerServiceSMO;
-import com.java110.intf.community.IRepairUserInnerServiceSMO;
-import com.java110.intf.community.IRoomInnerServiceSMO;
+import com.java110.intf.community.*;
 import com.java110.intf.fee.*;
+import com.java110.po.fee.PayFeeDetailPo;
+import com.java110.po.fee.PayFeePo;
 import com.java110.po.feeReceipt.FeeReceiptPo;
 import com.java110.po.feeReceiptDetail.FeeReceiptDetailPo;
 import com.java110.po.owner.RepairPoolPo;
 import com.java110.po.owner.RepairUserPo;
 import com.java110.utils.constant.BusinessTypeConstant;
 import com.java110.utils.constant.CommonConstant;
-import com.java110.utils.constant.ServiceCodeConstant;
+import com.java110.utils.constant.ResponseConstant;
+import com.java110.utils.exception.CmdException;
+import com.java110.utils.exception.ListenerExecuteException;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.BeanConvertUtil;
 import com.java110.utils.util.DateUtil;
 import com.java110.utils.util.StringUtil;
 import com.java110.vo.ResultVo;
 import org.slf4j.Logger;
-import com.java110.core.log.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.http.HttpHeaders;
-import org.springframework.http.HttpMethod;
-import org.springframework.http.HttpStatus;
-import org.springframework.http.ResponseEntity;
-
-import java.util.ArrayList;
-import java.util.List;
-
-/**
- * @ClassName payOweFeeListener
- * @Description TODO 缴费侦听
- * @Author wuxw
- * @Date 2019/6/3 13:46
- * @Version 1.0
- * add by wuxw 2019/6/3
- **/
-@Java110Listener("payOweFeeListener")
-public class PayOweFeeListener extends AbstractServiceApiDataFlowListener {
-
-    private static Logger logger = LoggerFactory.getLogger(PayOweFeeListener.class);
 
-    @Autowired
-    private IFeeBMO feeBMOImpl;
+import java.math.BigDecimal;
+import java.text.ParseException;
+import java.util.*;
 
+@Java110Cmd(serviceCode = "fee.payOweFee")
+public class PayOweFeeCmd extends Cmd {
+    private static Logger logger = LoggerFactory.getLogger(PayOweFeeCmd.class);
     @Autowired
     private IParkingSpaceInnerServiceSMO parkingSpaceInnerServiceSMOImpl;
     @Autowired
@@ -85,40 +73,52 @@ public class PayOweFeeListener extends AbstractServiceApiDataFlowListener {
     @Autowired
     private IRepairInnerServiceSMO repairInnerServiceSMO;
 
+    @Autowired
+    private IPayFeeV1InnerServiceSMO payFeeV1InnerServiceSMOImpl;
 
-    @Override
-    public String getServiceCode() {
-        return ServiceCodeConstant.SERVICE_CODE_PAY_OWE_FEE;
-    }
+    @Autowired
+    private IPayFeeDetailV1InnerServiceSMO payFeeDetailV1InnerServiceSMOImpl;
+
+
+    @Autowired
+    private IRepairPoolV1InnerServiceSMO repairPoolV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IRepairUserV1InnerServiceSMO repairUserV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IComputeFeeSMO computeFeeSMOImpl;
 
-    @Override
-    public HttpMethod getHttpMethod() {
-        return HttpMethod.POST;
-    }
 
     @Override
-    public void soService(ServiceDataFlowEvent event) {
+    public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
 
-        logger.debug("ServiceDataFlowEvent : {}", event);
+        Assert.hasKey(reqJson, "fees", "请求报文中未包含费用信息");
 
-        DataFlowContext dataFlowContext = event.getDataFlowContext();
-        AppService service = event.getAppService();
+        JSONArray fees = reqJson.getJSONArray("fees");
 
-        String paramIn = dataFlowContext.getReqData();
+        JSONObject feeObject = null;
 
-        //校验数据
-        validate(paramIn);
-        JSONObject paramObj = JSONObject.parseObject(paramIn);
+        for (int feeIndex = 0; feeIndex < fees.size(); feeIndex++) {
+            feeObject = fees.getJSONObject(feeIndex);
+            Assert.hasKeyAndValue(feeObject, "feeId", "未包含费用信息");
+            Assert.hasKeyAndValue(feeObject, "startTime", "未包含开始时间");
+            Assert.hasKeyAndValue(feeObject, "endTime", "未包含结束时间");
+            Assert.hasKeyAndValue(feeObject, "receivedAmount", "未包含实收金额");
+        }
+    }
+
+    @Override
+    @Java110Transactional
+    public void doCmd(CmdEvent event, ICmdDataFlowContext dataFlowContext, JSONObject paramObj) throws CmdException, ParseException {
         logger.info("======欠费缴费返回======:" + JSONArray.toJSONString(paramObj));
-        HttpHeaders header = new HttpHeaders();
-        dataFlowContext.getRequestCurrentHeaders().put(CommonConstant.HTTP_ORDER_TYPE_CD, "D");
-        JSONArray businesses = new JSONArray();
+
         //添加单元信息
         List<FeeReceiptPo> feeReceiptPos = new ArrayList<>();
         List<FeeReceiptDetailPo> feeReceiptDetailPos = new ArrayList<>();
         JSONArray fees = paramObj.getJSONArray("fees");
         JSONObject feeObj = null;
-        String appId = event.getDataFlowContext().getAppId();
+        String appId = dataFlowContext.getReqHeaders().get("app-id");
 
         for (int feeIndex = 0; feeIndex < fees.size(); feeIndex++) {
             feeObj = fees.getJSONObject(feeIndex);
@@ -130,14 +130,7 @@ public class PayOweFeeListener extends AbstractServiceApiDataFlowListener {
                 feeObj.put("remark", "线上公众号支付");
             }
 
-            getFeeReceiptDetailPo(dataFlowContext, feeObj, businesses, feeReceiptDetailPos, feeReceiptPos);
-        }
-
-        ResponseEntity<String> responseEntity = feeBMOImpl.callService(dataFlowContext, service.getServiceCode(), businesses);
-        dataFlowContext.setResponseEntity(responseEntity);
-
-        if (responseEntity.getStatusCode() != HttpStatus.OK) {
-            return;
+            getFeeReceiptDetailPo(dataFlowContext, feeObj, feeReceiptDetailPos, feeReceiptPos);
         }
 
         //这里只是写入 收据表,暂不考虑 事务一致性问题,就算写入失败 也只是影响 收据打印,如果 贵公司对 收据要求 比较高,不能有失败的情况 请加入事务管理
@@ -166,11 +159,12 @@ public class PayOweFeeListener extends AbstractServiceApiDataFlowListener {
         dataFlowContext.setResponseEntity(ResultVo.createResponseEntity(feeReceiptDetailDtos));
     }
 
-    private void getFeeReceiptDetailPo(DataFlowContext dataFlowContext, JSONObject paramObj, JSONArray businesses, List<FeeReceiptDetailPo> feeReceiptDetailPos, List<FeeReceiptPo> feeReceiptPos) {
+    private void getFeeReceiptDetailPo(ICmdDataFlowContext dataFlowContext, JSONObject paramObj, List<FeeReceiptDetailPo> feeReceiptDetailPos, List<FeeReceiptPo> feeReceiptPos) {
+        int flag = 0;
         if (!paramObj.containsKey("primeRate")) {
             paramObj.put("primeRate", "6");
         }
-        String appId = dataFlowContext.getAppId();
+        String appId = dataFlowContext.getReqHeaders().get("app-id");
         logger.info("======支付方式======:" + appId + "+======+" + paramObj.containsKey("primeRate") + "======:" + JSONArray.toJSONString(dataFlowContext));
         if (AppDto.OWNER_WECHAT_PAY.equals(appId)
                 && FeeDetailDto.PRIME_REATE_WECHAT.equals(paramObj.getString("primeRate"))) {  //微信支付(欠费缴费无法区分小程序还是微信公众号)
@@ -180,8 +174,8 @@ public class PayOweFeeListener extends AbstractServiceApiDataFlowListener {
             paramObj.put("remark", "线上小程序支付");
         }
         paramObj.put("state", "1400");
-        businesses.add(feeBMOImpl.addOweFeeDetail(paramObj, dataFlowContext, feeReceiptDetailPos, feeReceiptPos));
-        businesses.add(feeBMOImpl.modifyOweFee(paramObj, dataFlowContext));
+        addOweFeeDetail(paramObj, dataFlowContext, feeReceiptDetailPos, feeReceiptPos);
+        modifyOweFee(paramObj, dataFlowContext);
 
         //判断是否有派单属性ID
         FeeAttrDto feeAttrDto = new FeeAttrDto();
@@ -192,23 +186,19 @@ public class PayOweFeeListener extends AbstractServiceApiDataFlowListener {
 
         //修改 派单状态
         if (feeAttrDtos != null && feeAttrDtos.size() > 0) {
-            JSONObject business = JSONObject.parseObject("{\"datas\":{}}");
-            business.put(CommonConstant.HTTP_BUSINESS_TYPE_CD, BusinessTypeConstant.BUSINESS_TYPE_UPDATE_REPAIR);
-            business.put(CommonConstant.HTTP_SEQ, DEFAULT_SEQ + 2);
-            business.put(CommonConstant.HTTP_INVOKE_MODEL, CommonConstant.HTTP_INVOKE_MODEL_S);
+
             RepairPoolPo repairPoolPo = new RepairPoolPo();
             repairPoolPo.setRepairId(feeAttrDtos.get(0).getValue());
             repairPoolPo.setCommunityId(paramObj.getString("communityId"));
             repairPoolPo.setState(RepairDto.STATE_APPRAISE);
-            business.getJSONObject(CommonConstant.HTTP_BUSINESS_DATAS).put(RepairPoolPo.class.getSimpleName(), BeanConvertUtil.beanCovertMap(repairPoolPo));
-            businesses.add(business);
+            flag = repairPoolV1InnerServiceSMOImpl.updateRepairPoolNew(repairPoolPo);
+            if(flag < 1){
+                throw new CmdException("修改失败");
+            }
         }
         //修改 派单流程状态
         if (feeAttrDtos != null && feeAttrDtos.size() > 0) {
-            JSONObject business = JSONObject.parseObject("{\"datas\":{}}");
-            business.put(CommonConstant.HTTP_BUSINESS_TYPE_CD, BusinessTypeConstant.BUSINESS_TYPE_UPDATE_REPAIR_USER);
-            business.put(CommonConstant.HTTP_SEQ, DEFAULT_SEQ + 3);
-            business.put(CommonConstant.HTTP_INVOKE_MODEL, CommonConstant.HTTP_INVOKE_MODEL_S);
+
             RepairDto repairDto = new RepairDto();
             repairDto.setRepairId(feeAttrDtos.get(0).getValue());
             //查询报修记录
@@ -230,10 +220,6 @@ public class PayOweFeeListener extends AbstractServiceApiDataFlowListener {
                 repairUserPo.setEndTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
                 repairUserPo.setContext("已支付" + paramObj.getString("receivedAmount") + "元");
                 //新增待评价状态
-                JSONObject object = JSONObject.parseObject("{\"datas\":{}}");
-                object.put(CommonConstant.HTTP_BUSINESS_TYPE_CD, BusinessTypeConstant.BUSINESS_TYPE_SAVE_REPAIR_USER);
-                object.put(CommonConstant.HTTP_SEQ, DEFAULT_SEQ + 4);
-                object.put(CommonConstant.HTTP_INVOKE_MODEL, CommonConstant.HTTP_INVOKE_MODEL_S);
                 RepairUserPo repairUser = new RepairUserPo();
                 repairUser.setRuId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_ruId));
                 repairUser.setStartTime(repairUserPo.getEndTime());
@@ -248,77 +234,132 @@ public class PayOweFeeListener extends AbstractServiceApiDataFlowListener {
                 repairUser.setPreStaffName(repairUserDtoList.get(0).getStaffName());
                 repairUser.setPreRuId(repairUserDtoList.get(0).getRuId());
                 repairUser.setRepairEvent("auditUser");
-                object.getJSONObject(CommonConstant.HTTP_BUSINESS_DATAS).put(RepairUserPo.class.getSimpleName(), BeanConvertUtil.beanCovertMap(repairUser));
-                businesses.add(object);
+                flag = repairUserV1InnerServiceSMOImpl.saveRepairUserNew(repairUserPo);
+                if(flag < 1){
+                    throw new CmdException("修改失败");
+                }
             } else {  //如果是员工代客报修或电话报修,状态就变成已支付
                 repairUserPo.setState(RepairUserDto.STATE_FINISH_PAY_FEE);
                 //如果是已支付状态,就更新结束时间
                 repairUserPo.setEndTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
                 repairUserPo.setContext("已支付" + paramObj.getString("receivedAmount") + "元");
+                flag = repairUserV1InnerServiceSMOImpl.updateRepairUserNew(repairUserPo);
+                if(flag < 1){
+                    throw new CmdException("修改失败");
+                }
             }
-            business.getJSONObject(CommonConstant.HTTP_BUSINESS_DATAS).put(RepairUserPo.class.getSimpleName(), BeanConvertUtil.beanCovertMap(repairUserPo));
-            businesses.add(business);
         }
 
 
     }
 
-
     /**
-     * 数据校验
+     * 修改费用信息
      *
-     * @param paramIn "communityId": "7020181217000001",
-     *                "memberId": "3456789",
-     *                "memberTypeCd": "390001200001"
+     * @param paramInJson     接口调用放传入入参
+     * @param dataFlowContext 数据上下文
+     * @return 订单服务能够接受的报文
      */
-    private void validate(String paramIn) {
-        Assert.jsonObjectHaveKey(paramIn, "communityId", "请求报文中未包含communityId节点");
-        JSONObject reqJson = JSONObject.parseObject(paramIn);
-        Assert.hasKey(reqJson, "fees", "请求报文中未包含费用信息");
-
-        JSONArray fees = reqJson.getJSONArray("fees");
-
-        JSONObject feeObject = null;
-
-        for (int feeIndex = 0; feeIndex < fees.size(); feeIndex++) {
-            feeObject = fees.getJSONObject(feeIndex);
-            Assert.hasKeyAndValue(feeObject, "feeId", "未包含费用信息");
-            Assert.hasKeyAndValue(feeObject, "startTime", "未包含开始时间");
-            Assert.hasKeyAndValue(feeObject, "endTime", "未包含结束时间");
-            Assert.hasKeyAndValue(feeObject, "receivedAmount", "未包含实收金额");
+    public void modifyOweFee(JSONObject paramInJson, ICmdDataFlowContext dataFlowContext) {
+
+        JSONObject businessFee = new JSONObject();
+        FeeDto feeInfo = (FeeDto) paramInJson.get("feeInfo");
+        Map feeMap = BeanConvertUtil.beanCovertMap(feeInfo);
+        feeMap.put("startTime", DateUtil.getFormatTimeString(feeInfo.getStartTime(), DateUtil.DATE_FORMATE_STRING_A));
+        feeMap.put("endTime", paramInJson.getString("endTime"));
+        feeMap.put("cycles", paramInJson.getString("cycles"));
+        feeMap.put("configEndTime", feeInfo.getConfigEndTime());
+        if (FeeDto.FEE_FLAG_ONCE.equals(feeInfo.getFeeFlag())) { //缴费结束
+            feeMap.put("state", FeeDto.STATE_FINISH);
+        }
+        Date maxEndTime = feeInfo.getConfigEndTime();
+        if (!FeeDto.FEE_FLAG_CYCLE.equals(feeInfo.getFeeFlag())) {
+            maxEndTime = feeInfo.getDeadlineTime();
+        }
+        if(maxEndTime != null) { //这里数据问题的情况下
+            Date endTime = DateUtil.getDateFromStringA(paramInJson.getString("endTime"));
+            if (endTime.getTime() >= maxEndTime.getTime()) {
+                feeMap.put("state", FeeDto.STATE_FINISH);
+            }
         }
 
+        businessFee.putAll(feeMap);
+        PayFeePo payFeePo =  BeanConvertUtil.covertBean(businessFee,PayFeePo.class);
+        int flag = payFeeV1InnerServiceSMOImpl.savePayFee(payFeePo);
+        if (flag < 1) {
+            throw new CmdException("保存失败");
+        }
     }
 
-    @Override
-    public int getOrder() {
-        return DEFAULT_ORDER;
-    }
-
-
-    public IFeeInnerServiceSMO getFeeInnerServiceSMOImpl() {
-        return feeInnerServiceSMOImpl;
-    }
-
-    public void setFeeInnerServiceSMOImpl(IFeeInnerServiceSMO feeInnerServiceSMOImpl) {
-        this.feeInnerServiceSMOImpl = feeInnerServiceSMOImpl;
-    }
-
-    public IFeeConfigInnerServiceSMO getFeeConfigInnerServiceSMOImpl() {
-        return feeConfigInnerServiceSMOImpl;
-    }
-
-    public void setFeeConfigInnerServiceSMOImpl(IFeeConfigInnerServiceSMO feeConfigInnerServiceSMOImpl) {
-        this.feeConfigInnerServiceSMOImpl = feeConfigInnerServiceSMOImpl;
-    }
-
-    public IRoomInnerServiceSMO getRoomInnerServiceSMOImpl() {
-        return roomInnerServiceSMOImpl;
-    }
+    public void addOweFeeDetail(JSONObject paramInJson, ICmdDataFlowContext dataFlowContext,
+                                      List<FeeReceiptDetailPo> feeReceiptDetailPos,
+                                      List<FeeReceiptPo> feeReceiptPos) {
+
+        JSONObject businessFeeDetail = new JSONObject();
+        businessFeeDetail.putAll(paramInJson);
+        businessFeeDetail.put("detailId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_detailId));
+        businessFeeDetail.put("primeRate", paramInJson.getString("primeRate"));
+        //计算 应收金额
+        FeeDto feeDto = new FeeDto();
+        feeDto.setFeeId(paramInJson.getString("feeId"));
+        feeDto.setCommunityId(paramInJson.getString("communityId"));
+        List<FeeDto> feeDtos = feeInnerServiceSMOImpl.queryFees(feeDto);
+        if (feeDtos == null || feeDtos.size() != 1) {
+            throw new ListenerExecuteException(ResponseConstant.RESULT_CODE_ERROR, "查询费用信息失败,未查到数据或查到多条数据");
+        }
+        if (!businessFeeDetail.containsKey("state") || StringUtil.isEmpty(businessFeeDetail.getString("state"))) {
+            businessFeeDetail.put("state", "1400");
+        }
+        feeDto = feeDtos.get(0);
+        businessFeeDetail.put("startTime", paramInJson.getString("startTime"));
+        BigDecimal cycles = null;
+        Map feePriceAll = computeFeeSMOImpl.getFeePrice(feeDto);
+        BigDecimal feePrice = new BigDecimal(feePriceAll.get("feePrice").toString());
+        Date endTime = feeDto.getEndTime();
+        Calendar endCalender = Calendar.getInstance();
+        endCalender.setTime(endTime);
+        BigDecimal receivedAmount = new BigDecimal(Double.parseDouble(paramInJson.getString("receivedAmount")));
+        cycles = receivedAmount.divide(feePrice, 4, BigDecimal.ROUND_HALF_EVEN);
+        businessFeeDetail.put("cycles", cycles.doubleValue());
+        businessFeeDetail.put("receivableAmount", paramInJson.getString("receivedAmount"));
+        businessFeeDetail.put("receivedAmount", paramInJson.getString("receivedAmount"));
+        businessFeeDetail.put("endTime", paramInJson.getString("endTime"));
+        paramInJson.put("feeInfo", feeDto);
+        paramInJson.put("cycles", cycles.doubleValue());
+        PayFeeDetailPo payFeeDetailPo = BeanConvertUtil.covertBean(businessFeeDetail, PayFeeDetailPo.class);
+        int flag = payFeeDetailV1InnerServiceSMOImpl.savePayFeeDetailNew(payFeeDetailPo);
+
+        if (flag < 1) {
+            throw new CmdException("保存明细失败");
+        }
 
-    public void setRoomInnerServiceSMOImpl(IRoomInnerServiceSMO roomInnerServiceSMOImpl) {
-        this.roomInnerServiceSMOImpl = roomInnerServiceSMOImpl;
+        paramInJson.put("detailId", businessFeeDetail.getString("detailId"));
+        FeeReceiptPo feeReceiptPo = new FeeReceiptPo();
+        FeeReceiptDetailPo feeReceiptDetailPo = new FeeReceiptDetailPo();
+        feeReceiptDetailPo.setAmount(businessFeeDetail.getString("receivedAmount"));
+        feeReceiptDetailPo.setCommunityId(feeDto.getCommunityId());
+        feeReceiptDetailPo.setCycle(businessFeeDetail.getString("cycles"));
+        feeReceiptDetailPo.setDetailId(businessFeeDetail.getString("detailId"));
+        feeReceiptDetailPo.setEndTime(businessFeeDetail.getString("endTime"));
+        feeReceiptDetailPo.setFeeId(feeDto.getFeeId());
+        feeReceiptDetailPo.setFeeName(StringUtil.isEmpty(feeDto.getImportFeeName()) ? feeDto.getFeeName() : feeDto.getImportFeeName());
+        feeReceiptDetailPo.setStartTime(businessFeeDetail.getString("startTime"));
+        feeReceiptDetailPo.setReceiptId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_receiptId));
+
+        computeFeeSMOImpl.freshFeeReceiptDetail(feeDto, feeReceiptDetailPo);
+        //查询业主信息
+        OwnerDto ownerDto = computeFeeSMOImpl.getFeeOwnerDto(feeDto);
+
+        feeReceiptDetailPos.add(feeReceiptDetailPo);
+        feeReceiptPo.setAmount(feeReceiptDetailPo.getAmount());
+        feeReceiptPo.setCommunityId(feeReceiptDetailPo.getCommunityId());
+        feeReceiptPo.setReceiptId(feeReceiptDetailPo.getReceiptId());
+        feeReceiptPo.setObjType(feeDto.getPayerObjType());
+        feeReceiptPo.setObjId(feeDto.getPayerObjId());
+        feeReceiptPo.setObjName(computeFeeSMOImpl.getFeeObjName(feeDto));
+        feeReceiptPo.setPayObjId(ownerDto.getOwnerId());
+        feeReceiptPo.setPayObjName(ownerDto.getName());
+        feeReceiptPos.add(feeReceiptPo);
     }
 
-
 }

+ 53 - 78
service-api/src/main/java/com/java110/api/listener/fee/RentingPayFeeConfirmListener.java

@@ -1,56 +1,43 @@
-package com.java110.api.listener.fee;
+package com.java110.fee.cmd.fee;
 
 import com.alibaba.fastjson.JSONArray;
 import com.alibaba.fastjson.JSONObject;
-import com.java110.api.bmo.fee.IFeeBMO;
-import com.java110.api.listener.AbstractServiceApiDataFlowListener;
-import com.java110.core.annotation.Java110Listener;
-import com.java110.core.context.DataFlowContext;
-import com.java110.core.event.service.api.ServiceDataFlowEvent;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.annotation.Java110Transactional;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
 import com.java110.core.factory.GenerateCodeFactory;
 import com.java110.dto.CommunityMemberDto;
 import com.java110.dto.fee.FeeConfigDto;
 import com.java110.dto.fee.FeeDto;
 import com.java110.dto.rentingPool.RentingPoolDto;
-import com.java110.entity.center.AppService;
 import com.java110.intf.community.ICommunityInnerServiceSMO;
 import com.java110.intf.fee.IFeeAttrInnerServiceSMO;
 import com.java110.intf.fee.IFeeInnerServiceSMO;
+import com.java110.intf.fee.IPayFeeDetailV1InnerServiceSMO;
+import com.java110.intf.fee.IPayFeeV1InnerServiceSMO;
 import com.java110.intf.order.IOrderInnerServiceSMO;
 import com.java110.intf.user.IRentingPoolInnerServiceSMO;
 import com.java110.po.fee.PayFeeDetailPo;
 import com.java110.po.fee.PayFeePo;
 import com.java110.po.rentingPool.RentingPoolPo;
 import com.java110.utils.constant.CommonConstant;
-import com.java110.utils.constant.ServiceCodeConstant;
+import com.java110.utils.exception.CmdException;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.BeanConvertUtil;
 import com.java110.utils.util.DateUtil;
-import org.slf4j.Logger;
-import com.java110.core.log.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.http.HttpMethod;
 import org.springframework.http.HttpStatus;
 import org.springframework.http.ResponseEntity;
 
 import java.math.BigDecimal;
+import java.text.ParseException;
 import java.util.List;
 
-/**
- * @ClassName PayFeeListener
- * @Description TODO 交费通知侦听
- * @Author wuxw
- * @Date 2019/6/3 13:46
- * @Version 1.0
- * add by wuxw 2019/6/3
- **/
-@Java110Listener("rentingPayFeeConfirmListener")
-public class RentingPayFeeConfirmListener extends AbstractServiceApiDataFlowListener {
+@Java110Cmd(serviceCode = "fee.rentingPayFeeConfirm")
+public class RentingPayFeeConfirmCmd extends Cmd {
 
-    private static Logger logger = LoggerFactory.getLogger(RentingPayFeeConfirmListener.class);
-
-    @Autowired
-    private IFeeBMO feeBMOImpl;
 
     @Autowired
     private IFeeAttrInnerServiceSMO feeAttrInnerServiceSMOImpl;
@@ -67,35 +54,30 @@ public class RentingPayFeeConfirmListener extends AbstractServiceApiDataFlowList
     @Autowired
     private IRentingPoolInnerServiceSMO rentingPoolInnerServiceSMOImpl;
 
-    @Override
-    public String getServiceCode() {
-        return ServiceCodeConstant.SERVICE_CODE_RENTING_PAY_CONFIRM_PRE;
-    }
 
-    @Override
-    public HttpMethod getHttpMethod() {
-        return HttpMethod.POST;
-    }
-
-    @Override
-    public void soService(ServiceDataFlowEvent event) {
+    @Autowired
+    private IPayFeeV1InnerServiceSMO payFeeV1InnerServiceSMOImpl;
 
-        logger.debug("ServiceDataFlowEvent : {}", event);
+    @Autowired
+    private IPayFeeDetailV1InnerServiceSMO payFeeDetailV1InnerServiceSMOImpl;
 
-        DataFlowContext dataFlowContext = event.getDataFlowContext();
-        AppService service = event.getAppService();
 
-        String paramIn = dataFlowContext.getReqData();
+    @Override
+    public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
+        Assert.jsonObjectHaveKey(reqJson, "oId", "请求报文中未包含订单信息");
 
-        //校验数据
-        validate(paramIn);
-        JSONObject paramObj = JSONObject.parseObject(paramIn);
+        Assert.hasLength(reqJson.getString("oId"), "订单信息不能为空");
+    }
 
+    @Override
+    @Java110Transactional
+    public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject paramObj) throws CmdException, ParseException {
         String oId = paramObj.getString("oId");
         String money = paramObj.getString("money");
         String feeName = paramObj.getString("feeName");
-        dataFlowContext.getRequestCurrentHeaders().put(CommonConstant.O_ID, oId);
+        context.getReqHeaders().put(CommonConstant.O_ID, oId);
         RentingPoolDto rentingPoolDto = BeanConvertUtil.covertBean(paramObj, RentingPoolDto.class);
+        int flag = 0;
 
         JSONArray businesses = new JSONArray();
         BigDecimal serviceDec = null;
@@ -112,7 +94,7 @@ public class RentingPayFeeConfirmListener extends AbstractServiceApiDataFlowList
             payMoney = new BigDecimal(money);
             receivableAmount = serviceDec.multiply(payMoney).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue();
             payFeeDetailPo = new PayFeeDetailPo();
-            payFeeDetailPo.setDetailId("-1");
+            payFeeDetailPo.setDetailId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_detailId));
             payFeeDetailPo.setEndTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
             payFeeDetailPo.setStartTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
             payFeeDetailPo.setFeeId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_feeId));
@@ -124,7 +106,10 @@ public class RentingPayFeeConfirmListener extends AbstractServiceApiDataFlowList
 
             payFeeDetailPo.setState("1400");
             //添加单元信息
-            businesses.add(feeBMOImpl.addSimpleFeeDetail(payFeeDetailPo, dataFlowContext));
+            flag = payFeeDetailV1InnerServiceSMOImpl.savePayFeeDetailNew(payFeeDetailPo);
+            if (flag < 1) {
+                throw new CmdException("添加费用异常");
+            }
 
             communityMemberDto = new CommunityMemberDto();
             communityMemberDto.setCommunityId(rentingPoolDto.getCommunityId());
@@ -149,7 +134,10 @@ public class RentingPayFeeConfirmListener extends AbstractServiceApiDataFlowList
             payFeePo.setStartTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
             payFeePo.setPayerObjType(FeeDto.PAYER_OBJ_TYPE_RENTING);
             payFeePo.setConfigId(FeeConfigDto.CONFIG_ID_RENTING);
-            businesses.add(feeBMOImpl.addSimpleFee(payFeePo, dataFlowContext));
+            flag = payFeeV1InnerServiceSMOImpl.savePayFee(payFeePo);
+            if (flag < 1) {
+                throw new CmdException("添加费用异常");
+            }
         }
 
         //代理商分成
@@ -160,7 +148,7 @@ public class RentingPayFeeConfirmListener extends AbstractServiceApiDataFlowList
             payMoney = new BigDecimal(money);
             receivableAmount = serviceDec.multiply(payMoney).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue();
             payFeeDetailPo = new PayFeeDetailPo();
-            payFeeDetailPo.setDetailId("-2");
+            payFeeDetailPo.setDetailId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_detailId));
             payFeeDetailPo.setEndTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
             payFeeDetailPo.setStartTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
             payFeeDetailPo.setFeeId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_feeId));
@@ -170,7 +158,10 @@ public class RentingPayFeeConfirmListener extends AbstractServiceApiDataFlowList
             payFeeDetailPo.setReceivedAmount(receivableAmount + "");
             payFeeDetailPo.setCommunityId(rentingPoolDto.getCommunityId());
             //添加单元信息
-            businesses.add(feeBMOImpl.addSimpleFeeDetail(payFeeDetailPo, dataFlowContext));
+            flag = payFeeDetailV1InnerServiceSMOImpl.savePayFeeDetailNew(payFeeDetailPo);
+            if (flag < 1) {
+                throw new CmdException("添加费用异常");
+            }
 
             communityMemberDto = new CommunityMemberDto();
             communityMemberDto.setCommunityId(rentingPoolDto.getCommunityId());
@@ -195,7 +186,10 @@ public class RentingPayFeeConfirmListener extends AbstractServiceApiDataFlowList
             payFeePo.setStartTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
             payFeePo.setPayerObjType(FeeDto.PAYER_OBJ_TYPE_RENTING);
             payFeePo.setConfigId(FeeConfigDto.CONFIG_ID_RENTING);
-            businesses.add(feeBMOImpl.addSimpleFee(payFeePo, dataFlowContext));
+            flag = payFeeV1InnerServiceSMOImpl.savePayFee(payFeePo);
+            if (flag < 1) {
+                throw new CmdException("添加费用异常");
+            }
         }
         //运营分成
         //物业 收取费用
@@ -206,7 +200,7 @@ public class RentingPayFeeConfirmListener extends AbstractServiceApiDataFlowList
             payMoney = new BigDecimal(money);
             receivableAmount = serviceDec.multiply(payMoney).setScale(2, BigDecimal.ROUND_HALF_EVEN).doubleValue();
             payFeeDetailPo = new PayFeeDetailPo();
-            payFeeDetailPo.setDetailId("-3");
+            payFeeDetailPo.setDetailId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_detailId));
             payFeeDetailPo.setEndTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
             payFeeDetailPo.setStartTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
             payFeeDetailPo.setFeeId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_feeId));
@@ -216,7 +210,10 @@ public class RentingPayFeeConfirmListener extends AbstractServiceApiDataFlowList
             payFeeDetailPo.setReceivedAmount(receivableAmount + "");
             payFeeDetailPo.setCommunityId(rentingPoolDto.getCommunityId());
             //添加单元信息
-            businesses.add(feeBMOImpl.addSimpleFeeDetail(payFeeDetailPo, dataFlowContext));
+            flag = payFeeDetailV1InnerServiceSMOImpl.savePayFeeDetailNew(payFeeDetailPo);
+            if (flag < 1) {
+                throw new CmdException("添加费用异常");
+            }
 
             communityMemberDto = new CommunityMemberDto();
             communityMemberDto.setCommunityId(rentingPoolDto.getCommunityId());
@@ -241,15 +238,12 @@ public class RentingPayFeeConfirmListener extends AbstractServiceApiDataFlowList
             payFeePo.setStartTime(DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A));
             payFeePo.setPayerObjType(FeeDto.PAYER_OBJ_TYPE_RENTING);
             payFeePo.setConfigId(FeeConfigDto.CONFIG_ID_RENTING);
-            businesses.add(feeBMOImpl.addSimpleFee(payFeePo, dataFlowContext));
-        }
-        ResponseEntity<String> responseEntity = feeBMOImpl.callService(dataFlowContext, service.getServiceCode(), businesses);
-        dataFlowContext.setResponseEntity(responseEntity);
-        if (responseEntity.getStatusCode() != HttpStatus.OK) {
-            return;
+            flag = payFeeV1InnerServiceSMOImpl.savePayFee(payFeePo);
+            if (flag < 1) {
+                throw new CmdException("添加费用异常");
+            }
         }
 
-
         RentingPoolPo rentingPoolPo = new RentingPoolPo();
         rentingPoolPo.setRentingId(rentingPoolDto.getRentingId());
         rentingPoolPo.setCommunityId(rentingPoolDto.getCommunityId());
@@ -258,23 +252,4 @@ public class RentingPayFeeConfirmListener extends AbstractServiceApiDataFlowList
     }
 
 
-    /**
-     * 数据校验
-     *
-     * @param paramIn "communityId": "7020181217000001",
-     *                "memberId": "3456789",
-     *                "memberTypeCd": "390001200001"
-     */
-    private void validate(String paramIn) {
-        Assert.jsonObjectHaveKey(paramIn, "oId", "请求报文中未包含订单信息");
-        JSONObject paramInObj = JSONObject.parseObject(paramIn);
-        Assert.hasLength(paramInObj.getString("oId"), "订单信息不能为空");
-
-    }
-
-    @Override
-    public int getOrder() {
-        return DEFAULT_ORDER;
-    }
-
 }

+ 146 - 0
service-user/src/main/java/com/java110/user/cmd/owner/UploadOwnerPhotoCmd.java

@@ -0,0 +1,146 @@
+package com.java110.user.cmd.owner;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.context.DataFlowContext;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
+import com.java110.core.factory.GenerateCodeFactory;
+import com.java110.dto.file.FileDto;
+import com.java110.dto.file.FileRelDto;
+import com.java110.dto.owner.OwnerAppUserDto;
+import com.java110.dto.owner.OwnerDto;
+import com.java110.intf.common.IFileInnerServiceSMO;
+import com.java110.intf.common.IFileRelInnerServiceSMO;
+import com.java110.intf.user.IOwnerAppUserInnerServiceSMO;
+import com.java110.intf.user.IOwnerAppUserV1InnerServiceSMO;
+import com.java110.intf.user.IOwnerInnerServiceSMO;
+import com.java110.intf.user.IOwnerV1InnerServiceSMO;
+import com.java110.po.file.FileRelPo;
+import com.java110.po.owner.OwnerAppUserPo;
+import com.java110.po.owner.OwnerPo;
+import com.java110.utils.constant.BusinessTypeConstant;
+import com.java110.utils.exception.CmdException;
+import com.java110.utils.util.Assert;
+import com.java110.utils.util.BeanConvertUtil;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+
+import java.text.ParseException;
+import java.util.List;
+
+@Java110Cmd(serviceCode = "owner.uploadOwnerPhoto")
+public class UploadOwnerPhotoCmd extends Cmd {
+
+
+    @Autowired
+    private IFileInnerServiceSMO fileInnerServiceSMOImpl;
+
+    @Autowired
+    private IOwnerInnerServiceSMO ownerInnerServiceSMOImpl;
+
+    @Autowired
+    private IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl;
+
+    @Autowired
+    private IOwnerV1InnerServiceSMO ownerV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IOwnerAppUserInnerServiceSMO ownerAppUserInnerServiceSMOImpl;
+    @Autowired
+    private IOwnerAppUserV1InnerServiceSMO ownerAppUserV1InnerServiceSMOImpl;
+
+
+    @Override
+    public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
+        Assert.jsonObjectHaveKey(reqJson, "memberId", "请求报文中未包含ownerId");
+        Assert.jsonObjectHaveKey(reqJson, "photo", "请求报文中未包含photo");
+        Assert.jsonObjectHaveKey(reqJson, "communityId", "请求报文中未包含communityId");
+    }
+
+    @Override
+    public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException {
+        if (reqJson.containsKey("photo") && !StringUtils.isEmpty(reqJson.getString("photo"))) {
+            FileDto fileDto = new FileDto();
+            fileDto.setFileId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_file_id));
+            fileDto.setFileName(fileDto.getFileId());
+            fileDto.setContext(reqJson.getString("photo"));
+            fileDto.setSuffix("jpeg");
+            fileDto.setCommunityId(reqJson.getString("communityId"));
+            String fileName = fileInnerServiceSMOImpl.saveFile(fileDto);
+            reqJson.put("ownerPhotoId", fileDto.getFileId());
+            reqJson.put("fileSaveName", fileName);
+
+            editOwnerPhoto(reqJson);
+
+        }
+        //添加小区楼
+        editOwner(reqJson);
+    }
+
+    public void editOwnerPhoto(JSONObject paramInJson) {
+
+        FileRelDto fileRelDto = new FileRelDto();
+        fileRelDto.setRelTypeCd("10000");
+        fileRelDto.setObjId(paramInJson.getString("memberId"));
+        List<FileRelDto> fileRelDtos = fileRelInnerServiceSMOImpl.queryFileRels(fileRelDto);
+        if (fileRelDtos == null || fileRelDtos.size() == 0) {
+            JSONObject businessUnit = new JSONObject();
+            businessUnit.put("fileRelId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_fileRelId));
+            businessUnit.put("relTypeCd", "10000");
+            businessUnit.put("saveWay", "table");
+            businessUnit.put("objId", paramInJson.getString("memberId"));
+            businessUnit.put("fileRealName", paramInJson.getString("ownerPhotoId"));
+            businessUnit.put("fileSaveName", paramInJson.getString("ownerPhotoId"));
+            FileRelPo fileRelPo = BeanConvertUtil.covertBean(businessUnit, FileRelPo.class);
+            fileRelInnerServiceSMOImpl.saveFileRel(fileRelPo);
+            return;
+        }
+
+        JSONObject businessUnit = new JSONObject();
+        businessUnit.putAll(BeanConvertUtil.beanCovertMap(fileRelDtos.get(0)));
+        businessUnit.put("fileRealName", paramInJson.getString("ownerPhotoId"));
+        businessUnit.put("fileSaveName", paramInJson.getString("fileSaveName"));
+        FileRelPo fileRelPo = BeanConvertUtil.covertBean(businessUnit, FileRelPo.class);
+        fileRelInnerServiceSMOImpl.updateFileRel(fileRelPo);
+
+
+    }
+
+    public void editOwner(JSONObject paramInJson) {
+
+        OwnerDto ownerDto = new OwnerDto();
+        ownerDto.setMemberId(paramInJson.getString("memberId"));
+        List<OwnerDto> ownerDtos = ownerInnerServiceSMOImpl.queryOwnerMembers(ownerDto);
+
+        Assert.listOnlyOne(ownerDtos, "未查询到业主信息或查询到多条");
+
+        JSONObject businessOwner = new JSONObject();
+        businessOwner.putAll(BeanConvertUtil.beanCovertMap(ownerDtos.get(0)));
+        businessOwner.putAll(paramInJson);
+
+        if (paramInJson.containsKey("wxPhoto")) {
+            businessOwner.put("link", paramInJson.getString("wxPhoto"));
+        }
+        businessOwner.put("state", ownerDtos.get(0).getState());
+        OwnerPo ownerPo = BeanConvertUtil.covertBean(businessOwner, OwnerPo.class);
+        int flag = ownerV1InnerServiceSMOImpl.updateOwner(ownerPo);
+        if(flag < 1){
+            throw new CmdException("修改业主");
+        }
+        OwnerAppUserDto ownerAppUserDto = new OwnerAppUserDto();
+        ownerAppUserDto.setMemberId(paramInJson.getString("ownerId"));
+        //查询app用户表
+        List<OwnerAppUserDto> ownerAppUserDtos = ownerAppUserInnerServiceSMOImpl.queryOwnerAppUsers(ownerAppUserDto);
+        if (ownerAppUserDtos != null && ownerAppUserDtos.size() > 0) {
+            for (OwnerAppUserDto ownerAppUser : ownerAppUserDtos) {
+                OwnerAppUserPo ownerAppUserPo = BeanConvertUtil.covertBean(ownerAppUser, OwnerAppUserPo.class);
+                ownerAppUserPo.setLink(paramInJson.getString("link"));
+                ownerAppUserPo.setIdCard(paramInJson.getString("idCard"));
+                ownerAppUserV1InnerServiceSMOImpl.updateOwnerAppUser(ownerAppUserPo);
+            }
+        }
+    }
+
+}

+ 43 - 0
service-user/src/main/java/com/java110/user/cmd/user/CheckServiceLoginCmd.java

@@ -0,0 +1,43 @@
+package com.java110.user.cmd.user;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
+import com.java110.core.factory.AuthenticationFactory;
+import com.java110.utils.exception.CmdException;
+import com.java110.utils.util.Assert;
+import org.springframework.http.HttpStatus;
+import org.springframework.http.ResponseEntity;
+
+import javax.naming.AuthenticationException;
+import java.text.ParseException;
+import java.util.Map;
+
+@Java110Cmd(serviceCode = "check.service.login")
+public class CheckServiceLoginCmd extends Cmd {
+    @Override
+    public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
+
+    }
+
+    @Override
+    public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException {
+        Assert.jsonObjectHaveKey(reqJson,"token","请求报文中未包含token 节点请检查");
+        ResponseEntity responseEntity= null;
+        try {
+            Map<String, String> claims = AuthenticationFactory.verifyToken(reqJson.getString("token"));
+            if(claims == null || claims.isEmpty()){
+                throw new AuthenticationException("认证失败,从token中解析到信息为空");
+            }
+            JSONObject resultInfo = new JSONObject();
+            resultInfo.put("userId",claims.get("userId"));
+            responseEntity = new ResponseEntity<String>(resultInfo.toJSONString(), HttpStatus.OK);
+        } catch (Exception e) {
+            //Invalid signature/claims
+            responseEntity = new ResponseEntity<String>("认证失败,不是有效的token", HttpStatus.UNAUTHORIZED);
+        }
+        context.setResponseEntity(responseEntity);
+    }
+}