From 23f8f5155749bbe0d2494c52d8adc3e6476b9cac Mon Sep 17 00:00:00 2001
From: Administrator <zhubaomin>
Date: 星期三, 20 十二月 2023 17:23:55 +0800
Subject: [PATCH] 2023-12-20 朱宝民 IC卡15个接口重构,角色授权,获取用户信息

---
 pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/activeCard/ActiveCardCtrl.java |  189 +++++++++++++++++++++++++++-------------------
 1 files changed, 110 insertions(+), 79 deletions(-)

diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/activeCard/ActiveCardCtrl.java b/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/activeCard/ActiveCardCtrl.java
index f7d841d..d04a1e2 100644
--- a/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/activeCard/ActiveCardCtrl.java
+++ b/pipIrr-platform/pipIrr-web/pipIrr-web-sell/src/main/java/com/dy/pipIrrSell/activeCard/ActiveCardCtrl.java
@@ -5,9 +5,16 @@
 import com.dy.common.webUtil.BaseResponseUtils;
 import com.dy.common.webUtil.QueryResultVo;
 import com.dy.common.webUtil.ResultCodeMsg;
-import com.dy.pipIrrGlobal.pojoSe.*;
-import com.dy.pipIrrSell.activeCardHistory.ActiveCardHistorySv;
+import com.dy.pipIrrGlobal.pojoSe.SeActiveCard;
+import com.dy.pipIrrGlobal.pojoSe.SeClientCard;
+import com.dy.pipIrrGlobal.voBa.VoAreaCode;
+import com.dy.pipIrrGlobal.voSe.VoActiveCard;
+import com.dy.pipIrrSell.clientCard.CardStateENUM;
 import com.dy.pipIrrSell.clientCard.ClientCardSv;
+import com.dy.pipIrrSell.clientCard.LastOperateENUM;
+import com.dy.pipIrrSell.recharge.DtoRecharge;
+import com.dy.pipIrrSell.recharge.RechargeCtrl;
+import com.dy.pipIrrSell.result.SellResultCode;
 import io.swagger.v3.oas.annotations.Operation;
 import io.swagger.v3.oas.annotations.Parameter;
 import io.swagger.v3.oas.annotations.media.Content;
@@ -23,11 +30,7 @@
 import org.springframework.validation.BindingResult;
 import org.springframework.web.bind.annotation.*;
 
-import java.time.format.DateTimeFormatter;
-import java.util.Date;
-import java.util.List;
-import java.util.Objects;
-import java.util.Optional;
+import java.util.*;
 
 /**
  * @author ZhuBaoMin
@@ -44,7 +47,7 @@
 public class ActiveCardCtrl {
     private final ActiveCardSv activeCardSv;
     private final ClientCardSv clientCardSv;
-    private final ActiveCardHistorySv activeCardHistorySv;
+    private final RechargeCtrl rechargeCtrl;
 
     @Operation(summary = "鑾峰緱涓�椤靛紑鍗¤褰�", description = "杩斿洖涓�椤靛紑鍗℃暟鎹�")
     @ApiResponses(value = {
@@ -79,78 +82,119 @@
     @PostMapping(path = "add_active", consumes = MediaType.APPLICATION_JSON_VALUE)
     @Transactional(rollbackFor = Exception.class)
     @SsoAop("-1")//@SsoAop(power = "-1")
-    public BaseResponse<Boolean> add_active(@RequestBody @Parameter(description = "form琛ㄥ崟json鏁版嵁", required = true) @Valid PO_ActiveCard po, @Parameter(hidden = true) BindingResult bindingResult){
-        DateTimeFormatter dtf = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
+    public BaseResponse<Boolean> add_active(@RequestBody @Parameter(description = "form琛ㄥ崟json鏁版嵁", required = true) @Valid DtoActiveCard po, @Parameter(hidden = true) BindingResult bindingResult){
         if(bindingResult != null && bindingResult.hasErrors()){
             return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage());
         }
 
         /**
-         * cardId           姘村崱缂栧彿锛堟彃鍏ヨ褰曞悗鐢熸垚锛�
-         * cardAddr         姘村崱鍦板潃
-         * clientId         鍐滄埛缂栧彿
+         * 鑾峰彇5绾ц鏀垮尯鍒掍覆areaCode
+         * provinceId   鐪佺骇鍖哄垝浠g爜
+         * cityId       甯傜骇鍖哄垝浠g爜
+         * countryId    鍘跨骇鍖哄垝浠g爜
+         * townId       闀囩骇鍖哄垝浠g爜
+         * villageId    鏉戠骇鍖哄垝浠g爜
+         */
+        VoAreaCode voAreaCode = activeCardSv.getAreaCodeByNum(po.getClientNum());
+        if(voAreaCode == null) {
+            return BaseResponseUtils.buildFail(SellResultCode.AREA_CODE_MISTAKE.getMessage());
+        }
+        String provinceId = voAreaCode.getProvinceId();
+        String cityId = voAreaCode.getCityId();
+        String countryId = voAreaCode.getCountryId();
+        String townId = voAreaCode.getTownId();
+        String villageId = voAreaCode.getVillageId();
+        String areaCode = provinceId + cityId + countryId + townId + villageId;
+
+        /**
+         * 鏍规嵁琛屾斂鍖哄垝涓诧紙areaCode锛夊湪姘村崱琛ㄤ腑閽堝姘村崱缂栧彿锛坈ardNum锛夎繘琛屾ā绯婃煡璇�
+         * 濡傛灉4浣嶉『搴忓彿宸茬粡杈惧埌鏈�澶у�硷紝鎻愮ず鐢ㄦ埛鑱旂郴绯荤粺绠$悊鍛�
+         * 濡傛灉4浣嶉『搴忓彿鏈揪鍒版渶澶у�硷紝鍒欏姞1
+         * cardNum涓烘柊鐨勫崱鍙�
+         */
+        String cardNum = Optional.ofNullable(activeCardSv.getCardNumOfMax(areaCode)).orElse("");
+        if(cardNum != null && cardNum.trim().length() > 0) {
+            Integer number = Integer.parseInt(cardNum.substring(12));
+            number = number + 1;
+            if(number > 9999) {
+                return BaseResponseUtils.buildFail(SellResultCode.CARD_NUMBER_OVERRUN.getMessage());
+            }
+            cardNum = cardNum.substring(0, 12) + String.format("%04d", number);
+        } else {
+            cardNum = areaCode + "0001";
+        }
+
+
+        /**
+         * cardAddr         姘村崱鍦板潃锛堜粎浠呭啓鍏ワ紝鏃犱笟鍔★級
+         * clientNum        鍐滄埛缂栧彿
          * cardCost         鍗$墖璐圭敤
+         * amount           鍏呭�奸噾棰�
          * reissueAmount    琛ュ崱閲戦锛岃ˉ鍗℃椂浣跨敤
          * paymentId        鏀粯鏂瑰紡缂栧彿
+         * remarks          澶囨敞
          * operator         鎿嶄綔浜虹紪鍙�
          * activeTime       寮�鍗℃椂闂�
          */
-        Long cardId = 0L;
         String cardAddr = po.getCardAddr();
-        Long clientId = po.getClientId();
+        String clientNum = po.getClientNum();
         Integer cardCost = po.getCardCost();
+        Float amount = po.getAmount();
         Long paymentId = po.getPaymentId();
+        String remarks = po.getRemarks();
         Long operator = po.getOperator();
-        Date activeTime = new Date();
-        //LocalDateTime activeTime = LocalDateTime.parse(dtf.format(LocalDateTime.now()), DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
+        Date createTime = new Date();
 
         /**
          * 娣诲姞鍐滄埛鍗¤褰�
          */
-        SeClientCard clientCard = new SeClientCard();
-        clientCard.setCardaddr(cardAddr);
-        clientCard.setClientid(clientId);
-        clientCard.setMoney(0.0);
-        clientCard.setState((byte) 1);
-        clientCard.setCreatedt(activeTime);
-        clientCard.setLastoper((byte) 1);
+        SeClientCard seClientCard = new SeClientCard();
+        seClientCard.setCardaddr(cardAddr);
+        seClientCard.setCardnum(cardNum);
+        seClientCard.setClientnum(clientNum);
+        seClientCard.setMoney(0.0);
+        seClientCard.setState(CardStateENUM.NORMAL.getCode());
+        seClientCard.setCreatedt(createTime);
+        seClientCard.setLastoper(LastOperateENUM.ACTIVE.getCode());
 
-        cardId = Optional.ofNullable(clientCardSv.add(clientCard)).orElse(0L) ;
+        Long cardId = Optional.ofNullable(clientCardSv.add(seClientCard)).orElse(0L) ;
         if(cardId == 0) {
-            return BaseResponseUtils.buildFail("寮�鍗″け璐�-鍐滄埛鍗″啓鍏ュ紓甯�");
+            return BaseResponseUtils.buildFail(SellResultCode.ACTIVE_FAIL_WRITE_CLIENT_CARD_ERROR.getMessage());
         }
 
         /**
          * 娣诲姞寮�鍗¤褰�
          */
         SeActiveCard activeCard = new SeActiveCard();
-        activeCard.setCardid(cardId);
+        activeCard.setCardnum(cardNum);
+        activeCard.setClientnum(clientNum);
         activeCard.setCardcost(cardCost);
         activeCard.setPaymentid(paymentId);
-        activeCard.setOperatetype((byte)1);
+        activeCard.setOperatetype(OperateTypeENUM.ACTIVE.getCode());
+        activeCard.setRemarks(remarks);
         activeCard.setOperator(operator);
-        activeCard.setOperatedt(activeTime);
+        activeCard.setOperatedt(createTime);
         Long rec = Optional.ofNullable(activeCardSv.add(activeCard)).orElse(0L);
         if(rec == 0) {
-            return BaseResponseUtils.buildFail("寮�鍗″け璐�-寮�鍗¤褰曞啓鍏ュ紓甯�");
+            return BaseResponseUtils.buildFail(SellResultCode.ACTIVE_FAIL_WRITE_ACTIVE_CARD_ERROR.getMessage());
         }
 
         /**
-         * 娣诲姞寮�鍗″巻鍙茶褰�
+         * 濡傛灉鎿嶄綔浜哄憳寮�鍗℃椂杈撳叆浜嗗厖鍊奸噾棰濓紝鍒欏紑鍗″悗璋冪敤鍏呭�煎姛鑳�
          */
-        SeActiveCardHistory activeCardHistory = new SeActiveCardHistory();
-        activeCardHistory.setCardid(cardId);
-        activeCardHistory.setCardcost(cardCost);
-        activeCardHistory.setPaymentid(paymentId);
-        activeCardHistory.setOperatetype((byte)1);
-        activeCardHistory.setOperator(operator);
-        activeCardHistory.setOperatedt(activeTime);
-        Long rec_history = Optional.ofNullable(activeCardHistorySv.add(activeCardHistory)).orElse(0L);
-        if(rec_history == 0) {
-            return BaseResponseUtils.buildFail("寮�鍗″け璐�-寮�鍗″巻鍙茶褰曞啓鍏ュ紓甯�");
+        po.setCardNum(cardNum);
+        if(amount != null && amount > 0) {
+            DtoRecharge dtoRecharge = RechargeDtoMapper.INSTANCT.po2vo(po);
+            dtoRecharge.setMoney(0f);
+            dtoRecharge.setGift(0f);
+            dtoRecharge.setPrice(0f);
+            BaseResponse<Boolean> job = rechargeCtrl.addRecharge(dtoRecharge);
+            if(!job.getCode().equals("0001")) {
+                return BaseResponseUtils.buildFail(SellResultCode.ACTIVE_FAIL_RECHARGE_EXCEPTION.getMessage());
+            }
         }
 
-        return BaseResponseUtils.buildSuccess(true) ;
+        return BaseResponseUtils.buildSuccess(cardNum) ;
     }
 
     @Operation(summary = "琛ュ崱", description = "琛ュ崱")
@@ -165,36 +209,41 @@
     @PostMapping(path = "add_reissue", consumes = MediaType.APPLICATION_JSON_VALUE)
     @Transactional(rollbackFor = Exception.class)
     @SsoAop("-1")//@SsoAop(power = "-1")
-    public BaseResponse<Boolean> add_reissue(@RequestBody @Parameter(description = "form琛ㄥ崟json鏁版嵁", required = true) @Valid PO_ActiveCard po, @Parameter(hidden = true) BindingResult bindingResult){
-        DateTimeFormatter dtf = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
+    public BaseResponse<Boolean> add_reissue(@RequestBody @Parameter(description = "form琛ㄥ崟json鏁版嵁", required = true) @Valid DtoActiveCard po, @Parameter(hidden = true) BindingResult bindingResult){
         if(bindingResult != null && bindingResult.hasErrors()){
             return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage());
         }
 
         /**
-         * cardId           姘村崱缂栧彿锛堥潪浼犲叆鍙傛暟锛岀敱cardAddr鍙嶆煡锛�
-         * cardAddr         姘村崱鍦板潃
+         * cardId           姘村崱缂栧彿锛堥潪浼犲叆鍙傛暟锛岀敱cardNum鍙嶆煡锛屾洿鏂版按鍗¤〃鐢級
+         * cardNum          姘村崱缂栧彿
+         * clientNum        鍐滄埛缂栧彿锛堥潪浼犲叆鍙傛暟锛岀敱cardNum鍙嶆煡锛屾坊鍔犺ˉ鍗′娇鐢級
          * cardCost         鍗$墖璐圭敤
          * reissueAmount    琛ュ崱閲戦锛岃ˉ鍗℃椂浣跨敤
          * paymentId        鏀粯鏂瑰紡缂栧彿
+         * remarks          澶囨敞
          * operator         鎿嶄綔浜虹紪鍙�
          * activeTime       琛ュ崱鏃堕棿
          */
         Long cardId = 0L;
-        String cardAddr = po.getCardAddr();
+        String cardNum = po.getCardNum();
+        String clientNum = "";
         Integer cardCost = po.getCardCost();
         Double reissueAmount = po.getReissueAmount();
         Long paymentId = po.getPaymentId();
+        String remarks = po.getRemarks();
         Long operator = po.getOperator();
-        Date activeTime = new Date();
+        Date replaceTime = new Date();
 
         /**
-         * 渚濇嵁姘村崱鍦板潃鑾峰彇姘村崱缂栧彿锛堜富閿級
+         * 渚濇嵁姘村崱缂栧彿鑾峰彇姘村崱琛ㄤ富閿強鍐滄埛缂栧彿
          */
-        cardId = Optional.ofNullable(clientCardSv.getCardIdByAddr(cardAddr)).orElse(0L);
-        if(cardId == 0) {
-            return BaseResponseUtils.buildFail("鍗″彿閿欒锛岃鍗′笉瀛樺湪");
+        Map map = Optional.ofNullable(clientCardSv.getCardIdAndClientNum(cardNum)).orElse(new HashMap());
+        if(map == null || map.size() <= 0) {
+            return BaseResponseUtils.buildFail(SellResultCode.CARD_NUMBER_ERROR.getMessage());
         }
+        cardId = Long.parseLong(map.get("cardId").toString());
+        clientNum = map.get("clientNum").toString();
 
         /**
          * 淇敼鍐滄埛鍗′俊鎭細
@@ -203,47 +252,29 @@
          */
         SeClientCard seClientCard = new SeClientCard();
         seClientCard.setId(cardId);
-        seClientCard.setReplacedt(activeTime);
-        seClientCard.setLastoper((byte)2);
+        seClientCard.setReplacedt(replaceTime);
+        seClientCard.setLastoper(LastOperateENUM.REPLACE.getCode());
         Integer rec_updateClientCard = Optional.ofNullable(clientCardSv.UpdateClientCard(seClientCard)).orElse(0);
         if(rec_updateClientCard == 0) {
-            return BaseResponseUtils.buildFail("琛ュ崱澶辫触-鍐滄埛鍗′慨鏀瑰紓甯�");
+            return BaseResponseUtils.buildFail(SellResultCode.REPLACE_FAIL_WRITE_CLIENT_CARD_ERROR.getMessage());
         }
 
-        /**
-         * 鍒犻櫎寮�鍗�/琛ュ崱琛ㄨ鍗$殑琛ュ崱璁板綍
-         */
-        Integer rec_deleteActiveCard = Optional.ofNullable(activeCardSv.deleteByIdAndOperateType(cardId, (byte)2)).orElse(0);
         /**
          * 娣诲姞琛ュ崱璁板綍
          */
         SeActiveCard activeCard = new SeActiveCard();
-        activeCard.setCardid(cardId);
+        activeCard.setCardnum(cardNum);
+        activeCard.setClientnum(clientNum);
         activeCard.setCardcost(cardCost);
         activeCard.setPaymentid(paymentId);
         activeCard.setReissueamount(reissueAmount);
-        activeCard.setOperatetype((byte)2);
+        activeCard.setOperatetype(OperateTypeENUM.REPLACE.getCode());
+        activeCard.setRemarks(remarks);
         activeCard.setOperator(operator);
-        activeCard.setOperatedt(activeTime);
+        activeCard.setOperatedt(replaceTime);
         Long rec = Optional.ofNullable(activeCardSv.add(activeCard)).orElse(0L);
         if(rec == 0) {
-            return BaseResponseUtils.buildFail("琛ュ崱澶辫触-琛ュ崱璁板綍鍐欏叆寮傚父");
-        }
-
-        /**
-         * 娣诲姞琛ュ崱鍘嗗彶璁板綍
-         */
-        SeActiveCardHistory activeCardHistory = new SeActiveCardHistory();
-        activeCardHistory.setCardid(cardId);
-        activeCardHistory.setCardcost(cardCost);
-        activeCardHistory.setPaymentid(paymentId);
-        activeCard.setReissueamount(reissueAmount);
-        activeCardHistory.setOperatetype((byte)2);
-        activeCardHistory.setOperator(operator);
-        activeCardHistory.setOperatedt(activeTime);
-        Long rec_history = Optional.ofNullable(activeCardHistorySv.add(activeCardHistory)).orElse(0L);
-        if(rec_history == 0) {
-            return BaseResponseUtils.buildFail("琛ュ崱澶辫触-琛ュ崱鍘嗗彶璁板綍鍐欏叆寮傚父");
+            return BaseResponseUtils.buildFail(SellResultCode.REPLACE_FAIL_WRITE_RECHARGE_ERROR.getMessage());
         }
 
         return BaseResponseUtils.buildSuccess(true) ;

--
Gitblit v1.8.0