From 75bf0fa6a3e113bd77191ace7e46f557b27552ee Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期一, 19 九月 2022 18:55:42 +0800
Subject: [PATCH] 优化代码
---
service-common/src/main/java/com/java110/common/cmd/machine/CustomCarInOutCmd.java | 53 +++++++++++++++++++++++++++++++++++++++++++----------
1 files changed, 43 insertions(+), 10 deletions(-)
diff --git a/service-common/src/main/java/com/java110/common/cmd/machine/CustomCarInOutCmd.java b/service-common/src/main/java/com/java110/common/cmd/machine/CustomCarInOutCmd.java
index 6dc3a9c..99a4565 100644
--- a/service-common/src/main/java/com/java110/common/cmd/machine/CustomCarInOutCmd.java
+++ b/service-common/src/main/java/com/java110/common/cmd/machine/CustomCarInOutCmd.java
@@ -17,18 +17,21 @@
import com.alibaba.fastjson.JSONObject;
import com.java110.common.bmo.machine.IMachineOpenDoorBMO;
+import com.java110.common.dao.ICarBlackWhiteServiceDao;
import com.java110.common.dao.ICarInoutV1ServiceDao;
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.dto.machine.CarBlackWhiteDto;
import com.java110.dto.machine.CarInoutDto;
import com.java110.dto.parkingBoxArea.ParkingBoxAreaDto;
import com.java110.dto.tempCarFeeConfig.TempCarPayOrderDto;
import com.java110.intf.common.ICarInoutV1InnerServiceSMO;
import com.java110.intf.community.IParkingBoxAreaV1InnerServiceSMO;
import com.java110.intf.job.IDataBusInnerServiceSMO;
+import com.java110.intf.user.ICarBlackWhiteV1InnerServiceSMO;
import com.java110.utils.exception.CmdException;
import com.java110.utils.util.Assert;
import com.java110.utils.util.DateUtil;
@@ -71,16 +74,15 @@
@Autowired
private ICarInoutV1InnerServiceSMO carInoutV1InnerServiceSMOImpl;
+ @Autowired
+ private ICarBlackWhiteV1InnerServiceSMO carBlackWhiteV1InnerServiceSMOImpl;
+
@Override
public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
Assert.hasKeyAndValue(reqJson, "communityId", "璇锋眰鎶ユ枃涓湭鍖呭惈灏忓尯淇℃伅");
Assert.hasKeyAndValue(reqJson, "machineId", "璇锋眰鎶ユ枃涓湭鍖呭惈璁惧淇℃伅");
Assert.hasKeyAndValue(reqJson, "carNum", "璇锋眰鎶ユ枃涓湭鍖呭惈杞︾墝鍙�");
Assert.hasKeyAndValue(reqJson, "type", "璇锋眰鎶ユ枃涓湭鍖呭惈绫诲瀷");
-
- if("1101".equals(reqJson.getString("type"))) {
- return;
- }
CarInoutDto carInoutDto = new CarInoutDto();
carInoutDto.setCarNum(reqJson.getString("carNum"));
@@ -90,9 +92,27 @@
});
int count = carInoutV1InnerServiceSMOImpl.queryCarInoutsCount(carInoutDto);
- if(count < 1){
- throw new CmdException("杞﹁締鏈叆鍦�");
+ //鍑哄満
+ if(!"1101".equals(reqJson.getString("type"))) {
+ Assert.hasKeyAndValue(reqJson,"payType","鏈寘鍚敮浠樻柟寮�");
+ Assert.hasKeyAndValue(reqJson,"amount","鏈寘鍚敮浠橀噾棰�");
+ if(count < 1){
+ throw new CmdException("杞﹁締鏈叆鍦�");
+ }
+ }else{
+ if(count > 0){
+ throw new CmdException("杞﹁締宸茬粡鍦ㄥ満锛岃鍏堝嚭鍦�");
+ }
+ //杩涘満鏃� 鍒ゆ柇鏄惁涓洪粦鍚嶅崟
+ CarBlackWhiteDto carBlackWhiteDto = new CarBlackWhiteDto();
+ carBlackWhiteDto.setCarNum(reqJson.getString("carNum"));
+ count = carBlackWhiteV1InnerServiceSMOImpl.queryCarBlackWhitesCount(carBlackWhiteDto);
+ if(count > 0){
+ throw new CmdException("榛戝悕鍗曡溅杈嗙姝㈠叆鍦�");
+ }
}
+
+
}
@@ -110,15 +130,28 @@
if(parkingBoxAreaDtos == null || parkingBoxAreaDtos.size()< 1){
throw new CmdException("鏈寘鍚仠杞﹀満淇℃伅");
}
-
TempCarPayOrderDto tempCarPayOrderDto = new TempCarPayOrderDto();
tempCarPayOrderDto.setCarNum(reqJson.getString("carNum"));
tempCarPayOrderDto.setPaId(parkingBoxAreaDtos.get(0).getPaId());
- tempCarPayOrderDto.setOrderId(reqJson.getString("inoutId"));
- tempCarPayOrderDto.setAmount(Double.parseDouble(reqJson.getString("payCharge")));
+ ResultVo resultVo = dataBusInnerServiceSMOImpl.getTempCarFeeOrder(tempCarPayOrderDto);
+ if(resultVo.getCode() != ResultVo.CODE_OK){
+ throw new CmdException(resultVo.getMsg());
+ }
+
+ JSONObject orderInfo = JSONObject.parseObject(resultVo.getData().toString());
+
+ tempCarPayOrderDto = new TempCarPayOrderDto();
+ tempCarPayOrderDto.setCarNum(reqJson.getString("carNum"));
+ tempCarPayOrderDto.setPaId(parkingBoxAreaDtos.get(0).getPaId());
+ tempCarPayOrderDto.setOrderId(orderInfo.getString("orderId"));
+ tempCarPayOrderDto.setAmount(Double.parseDouble(reqJson.getString("amount")));
+ tempCarPayOrderDto.setPayCharge(Double.parseDouble(reqJson.getString("payCharge")));
tempCarPayOrderDto.setPayType(reqJson.getString("payType"));
//tempCarPayOrderDto.setMachineId(reqJson.getString("machineId"));
- ResultVo resultVo = dataBusInnerServiceSMOImpl.notifyTempCarFeeOrder(tempCarPayOrderDto);
+ resultVo = dataBusInnerServiceSMOImpl.notifyTempCarFeeOrder(tempCarPayOrderDto);
+ if(resultVo.getCode() != ResultVo.CODE_OK){
+ throw new CmdException(resultVo.getMsg());
+ }
}
ResponseEntity<String> responseEntity = machineOpenDoorBMOImpl.customCarInOut(reqJson);
cmdDataFlowContext.setResponseEntity(responseEntity);
--
Gitblit v1.8.0